From 1837d78aa611c261998a130b1e5e2b2a9d729f12 Mon Sep 17 00:00:00 2001
From: Felix Tjahyadi <felix.tjahyadi@ui.ac.id>
Date: Sat, 24 Feb 2024 20:45:17 +0700
Subject: [PATCH] Read by Id

---
 .../filters => detail_item}/__init__.py       |    0
 detail_item/admin.py                          |    3 +
 detail_item/apps.py                           |    6 +
 .../migrations/__init__.py                    |    0
 detail_item/models.py                         |    8 +
 detail_item/templates/template.html           |    3 +
 detail_item/tests.py                          |    3 +
 detail_item/urls.py                           |    8 +
 detail_item/views.py                          |   10 +
 .../pip-21.1.3.dist-info/INSTALLER            |    1 -
 .../pip-21.1.3.dist-info/LICENSE.txt          |   20 -
 .../pip-21.1.3.dist-info/METADATA             |   91 -
 .../site-packages/pip-21.1.3.dist-info/RECORD |  797 --
 .../site-packages/pip-21.1.3.dist-info/WHEEL  |    5 -
 .../pip-21.1.3.dist-info/entry_points.txt     |    5 -
 .../pip-21.1.3.dist-info/top_level.txt        |    1 -
 env/Lib/site-packages/pip/__init__.py         |    5 +-
 env/Lib/site-packages/pip/__main__.py         |    7 -
 .../pip/__pycache__/__init__.cpython-39.pyc   |  Bin 618 -> 0 bytes
 .../pip/__pycache__/__main__.cpython-39.pyc   |  Bin 615 -> 0 bytes
 .../site-packages/pip/_internal/__init__.py   |    8 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 667 -> 0 bytes
 .../__pycache__/build_env.cpython-39.pyc      |  Bin 8980 -> 0 bytes
 .../__pycache__/cache.cpython-39.pyc          |  Bin 7870 -> 0 bytes
 .../__pycache__/configuration.cpython-39.pyc  |  Bin 10722 -> 0 bytes
 .../__pycache__/exceptions.cpython-39.pyc     |  Bin 15671 -> 0 bytes
 .../_internal/__pycache__/main.cpython-39.pyc |  Bin 604 -> 0 bytes
 .../__pycache__/pyproject.cpython-39.pyc      |  Bin 3482 -> 0 bytes
 .../self_outdated_check.cpython-39.pyc        |  Bin 4367 -> 0 bytes
 .../__pycache__/wheel_builder.cpython-39.pyc  |  Bin 8305 -> 0 bytes
 .../site-packages/pip/_internal/build_env.py  |  301 +-
 env/Lib/site-packages/pip/_internal/cache.py  |  175 +-
 .../cli/__pycache__/__init__.cpython-39.pyc   |  Bin 300 -> 0 bytes
 .../__pycache__/autocompletion.cpython-39.pyc |  Bin 4998 -> 0 bytes
 .../__pycache__/base_command.cpython-39.pyc   |  Bin 5821 -> 0 bytes
 .../cli/__pycache__/cmdoptions.cpython-39.pyc |  Bin 21055 -> 0 bytes
 .../command_context.cpython-39.pyc            |  Bin 1249 -> 0 bytes
 .../cli/__pycache__/main.cpython-39.pyc       |  Bin 1349 -> 0 bytes
 .../__pycache__/main_parser.cpython-39.pyc    |  Bin 2130 -> 0 bytes
 .../cli/__pycache__/parser.cpython-39.pyc     |  Bin 9394 -> 0 bytes
 .../__pycache__/progress_bars.cpython-39.pyc  |  Bin 7466 -> 0 bytes
 .../__pycache__/req_command.cpython-39.pyc    |  Bin 11309 -> 0 bytes
 .../cli/__pycache__/spinners.cpython-39.pyc   |  Bin 4637 -> 0 bytes
 .../__pycache__/status_codes.cpython-39.pyc   |  Bin 379 -> 0 bytes
 .../pip/_internal/cli/autocompletion.py       |   33 +-
 .../pip/_internal/cli/base_command.py         |  173 +-
 .../pip/_internal/cli/cmdoptions.py           |  460 +-
 .../pip/_internal/cli/command_context.py      |   11 +-
 .../site-packages/pip/_internal/cli/main.py   |   12 +-
 .../pip/_internal/cli/main_parser.py          |   55 +-
 .../site-packages/pip/_internal/cli/parser.py |   71 +-
 .../pip/_internal/cli/progress_bars.py        |  309 +-
 .../pip/_internal/cli/req_command.py          |  192 +-
 .../pip/_internal/cli/spinners.py             |   63 +-
 .../pip/_internal/commands/__init__.py        |  174 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 2893 -> 0 bytes
 .../commands/__pycache__/cache.cpython-39.pyc |  Bin 5775 -> 0 bytes
 .../commands/__pycache__/check.cpython-39.pyc |  Bin 1541 -> 0 bytes
 .../__pycache__/completion.cpython-39.pyc     |  Bin 3097 -> 0 bytes
 .../__pycache__/configuration.cpython-39.pyc  |  Bin 8078 -> 0 bytes
 .../commands/__pycache__/debug.cpython-39.pyc |  Bin 6462 -> 0 bytes
 .../__pycache__/download.cpython-39.pyc       |  Bin 3948 -> 0 bytes
 .../__pycache__/freeze.cpython-39.pyc         |  Bin 2946 -> 0 bytes
 .../commands/__pycache__/hash.cpython-39.pyc  |  Bin 2058 -> 0 bytes
 .../commands/__pycache__/help.cpython-39.pyc  |  Bin 1277 -> 0 bytes
 .../__pycache__/install.cpython-39.pyc        |  Bin 16724 -> 0 bytes
 .../commands/__pycache__/list.cpython-39.pyc  |  Bin 8835 -> 0 bytes
 .../__pycache__/search.cpython-39.pyc         |  Bin 4934 -> 0 bytes
 .../commands/__pycache__/show.cpython-39.pyc  |  Bin 6333 -> 0 bytes
 .../__pycache__/uninstall.cpython-39.pyc      |  Bin 2882 -> 0 bytes
 .../commands/__pycache__/wheel.cpython-39.pyc |  Bin 4821 -> 0 bytes
 .../pip/_internal/commands/cache.py           |  148 +-
 .../pip/_internal/commands/check.py           |   18 +-
 .../pip/_internal/commands/completion.py      |   98 +-
 .../pip/_internal/commands/configuration.py   |  142 +-
 .../pip/_internal/commands/debug.py           |  130 +-
 .../pip/_internal/commands/download.py        |   42 +-
 .../pip/_internal/commands/freeze.py          |  106 +-
 .../pip/_internal/commands/hash.py            |   31 +-
 .../pip/_internal/commands/help.py            |    5 +-
 .../pip/_internal/commands/install.py         |  520 +-
 .../pip/_internal/commands/list.py            |  307 +-
 .../pip/_internal/commands/search.py          |  116 +-
 .../pip/_internal/commands/show.py            |  232 +-
 .../pip/_internal/commands/uninstall.py       |   73 +-
 .../pip/_internal/commands/wheel.py           |   79 +-
 .../pip/_internal/configuration.py            |  188 +-
 .../pip/_internal/distributions/__init__.py   |    5 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 796 -> 0 bytes
 .../__pycache__/base.cpython-39.pyc           |  Bin 1852 -> 0 bytes
 .../__pycache__/installed.cpython-39.pyc      |  Bin 1197 -> 0 bytes
 .../__pycache__/sdist.cpython-39.pyc          |  Bin 3460 -> 0 bytes
 .../__pycache__/wheel.cpython-39.pyc          |  Bin 1541 -> 0 bytes
 .../pip/_internal/distributions/base.py       |   18 +-
 .../pip/_internal/distributions/installed.py  |   17 +-
 .../pip/_internal/distributions/sdist.py      |  127 +-
 .../pip/_internal/distributions/wheel.py      |   36 +-
 .../site-packages/pip/_internal/exceptions.py |  598 +-
 .../index/__pycache__/__init__.cpython-39.pyc |  Bin 254 -> 0 bytes
 .../__pycache__/collector.cpython-39.pyc      |  Bin 15110 -> 0 bytes
 .../__pycache__/package_finder.cpython-39.pyc |  Bin 26637 -> 0 bytes
 .../index/__pycache__/sources.cpython-39.pyc  |  Bin 7219 -> 0 bytes
 .../pip/_internal/index/collector.py          |  473 +-
 .../pip/_internal/index/package_finder.py     |  521 +-
 .../pip/_internal/index/sources.py            |    1 -
 .../pip/_internal/locations/__init__.py       |  431 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 3710 -> 0 bytes
 .../__pycache__/_distutils.cpython-39.pyc     |  Bin 3907 -> 0 bytes
 .../__pycache__/_sysconfig.cpython-39.pyc     |  Bin 4525 -> 0 bytes
 .../locations/__pycache__/base.cpython-39.pyc |  Bin 1238 -> 0 bytes
 .../pip/_internal/locations/_distutils.py     |  103 +-
 .../pip/_internal/locations/_sysconfig.py     |   97 +-
 .../pip/_internal/locations/base.py           |   45 +-
 env/Lib/site-packages/pip/_internal/main.py   |    3 +-
 .../pip/_internal/metadata/__init__.py        |  114 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 1753 -> 0 bytes
 .../metadata/__pycache__/base.cpython-39.pyc  |  Bin 5327 -> 0 bytes
 .../__pycache__/pkg_resources.cpython-39.pyc  |  Bin 4281 -> 0 bytes
 .../pip/_internal/metadata/base.py            |  628 +-
 .../pip/_internal/metadata/pkg_resources.py   |  258 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 288 -> 0 bytes
 .../__pycache__/candidate.cpython-39.pyc      |  Bin 1401 -> 0 bytes
 .../__pycache__/direct_url.cpython-39.pyc     |  Bin 6314 -> 0 bytes
 .../__pycache__/format_control.cpython-39.pyc |  Bin 2558 -> 0 bytes
 .../models/__pycache__/index.cpython-39.pyc   |  Bin 1211 -> 0 bytes
 .../models/__pycache__/link.cpython-39.pyc    |  Bin 7215 -> 0 bytes
 .../models/__pycache__/scheme.cpython-39.pyc  |  Bin 966 -> 0 bytes
 .../__pycache__/search_scope.cpython-39.pyc   |  Bin 3367 -> 0 bytes
 .../selection_prefs.cpython-39.pyc            |  Bin 1601 -> 0 bytes
 .../__pycache__/target_python.cpython-39.pyc  |  Bin 3298 -> 0 bytes
 .../models/__pycache__/wheel.cpython-39.pyc   |  Bin 4213 -> 0 bytes
 .../pip/_internal/models/candidate.py         |   24 +-
 .../pip/_internal/models/direct_url.py        |  130 +-
 .../pip/_internal/models/format_control.py    |   64 +-
 .../pip/_internal/models/index.py             |   22 +-
 .../pip/_internal/models/link.py              |  533 +-
 .../pip/_internal/models/scheme.py            |   14 +-
 .../pip/_internal/models/search_scope.py      |   67 +-
 .../pip/_internal/models/selection_prefs.py   |   22 +-
 .../pip/_internal/models/target_python.py     |   36 +-
 .../pip/_internal/models/wheel.py             |   51 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 276 -> 0 bytes
 .../network/__pycache__/auth.cpython-39.pyc   |  Bin 7073 -> 0 bytes
 .../network/__pycache__/cache.cpython-39.pyc  |  Bin 2755 -> 0 bytes
 .../__pycache__/download.cpython-39.pyc       |  Bin 5115 -> 0 bytes
 .../__pycache__/lazy_wheel.cpython-39.pyc     |  Bin 7940 -> 0 bytes
 .../__pycache__/session.cpython-39.pyc        |  Bin 9523 -> 0 bytes
 .../network/__pycache__/utils.cpython-39.pyc  |  Bin 1342 -> 0 bytes
 .../network/__pycache__/xmlrpc.cpython-39.pyc |  Bin 1921 -> 0 bytes
 .../pip/_internal/network/auth.py             |  431 +-
 .../pip/_internal/network/cache.py            |   25 +-
 .../pip/_internal/network/download.py         |   88 +-
 .../pip/_internal/network/lazy_wheel.py       |  122 +-
 .../pip/_internal/network/session.py          |  302 +-
 .../pip/_internal/network/utils.py            |   27 +-
 .../pip/_internal/network/xmlrpc.py           |   27 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 224 -> 0 bytes
 .../__pycache__/check.cpython-39.pyc          |  Bin 3720 -> 0 bytes
 .../__pycache__/freeze.cpython-39.pyc         |  Bin 5673 -> 0 bytes
 .../__pycache__/prepare.cpython-39.pyc        |  Bin 14260 -> 0 bytes
 .../build/__pycache__/__init__.cpython-39.pyc |  Bin 230 -> 0 bytes
 .../build/__pycache__/metadata.cpython-39.pyc |  Bin 1176 -> 0 bytes
 .../metadata_legacy.cpython-39.pyc            |  Bin 1950 -> 0 bytes
 .../build/__pycache__/wheel.cpython-39.pyc    |  Bin 1155 -> 0 bytes
 .../__pycache__/wheel_legacy.cpython-39.pyc   |  Bin 2549 -> 0 bytes
 .../_internal/operations/build/metadata.py    |   26 +-
 .../operations/build/metadata_legacy.py       |   62 +-
 .../pip/_internal/operations/build/wheel.py   |   19 +-
 .../operations/build/wheel_legacy.py          |   68 +-
 .../pip/_internal/operations/check.py         |  136 +-
 .../pip/_internal/operations/freeze.py        |  277 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 288 -> 0 bytes
 .../editable_legacy.cpython-39.pyc            |  Bin 1331 -> 0 bytes
 .../install/__pycache__/legacy.cpython-39.pyc |  Bin 3219 -> 0 bytes
 .../install/__pycache__/wheel.cpython-39.pyc  |  Bin 20841 -> 0 bytes
 .../operations/install/editable_legacy.py     |   29 +-
 .../_internal/operations/install/legacy.py    |  125 -
 .../pip/_internal/operations/install/wheel.py |  433 +-
 .../pip/_internal/operations/prepare.py       |  552 +-
 .../site-packages/pip/_internal/pyproject.py  |  104 +-
 .../pip/_internal/req/__init__.py             |   50 +-
 .../req/__pycache__/__init__.cpython-39.pyc   |  Bin 2371 -> 0 bytes
 .../__pycache__/constructors.cpython-39.pyc   |  Bin 11031 -> 0 bytes
 .../req/__pycache__/req_file.cpython-39.pyc   |  Bin 12464 -> 0 bytes
 .../__pycache__/req_install.cpython-39.pyc    |  Bin 20542 -> 0 bytes
 .../req/__pycache__/req_set.cpython-39.pyc    |  Bin 5708 -> 0 bytes
 .../__pycache__/req_tracker.cpython-39.pyc    |  Bin 4053 -> 0 bytes
 .../__pycache__/req_uninstall.cpython-39.pyc  |  Bin 17489 -> 0 bytes
 .../pip/_internal/req/constructors.py         |  308 +-
 .../pip/_internal/req/req_file.py             |  261 +-
 .../pip/_internal/req/req_install.py          |  700 +-
 .../pip/_internal/req/req_set.py              |  214 +-
 .../pip/_internal/req/req_tracker.py          |  140 -
 .../pip/_internal/req/req_uninstall.py        |  506 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 224 -> 0 bytes
 .../__pycache__/base.cpython-39.pyc           |  Bin 967 -> 0 bytes
 .../pip/_internal/resolution/base.py          |   16 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 231 -> 0 bytes
 .../__pycache__/resolver.cpython-39.pyc       |  Bin 11504 -> 0 bytes
 .../_internal/resolution/legacy/resolver.py   |  280 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 235 -> 0 bytes
 .../__pycache__/base.cpython-39.pyc           |  Bin 6337 -> 0 bytes
 .../__pycache__/candidates.cpython-39.pyc     |  Bin 17917 -> 0 bytes
 .../__pycache__/factory.cpython-39.pyc        |  Bin 16384 -> 0 bytes
 .../found_candidates.cpython-39.pyc           |  Bin 4683 -> 0 bytes
 .../__pycache__/provider.cpython-39.pyc       |  Bin 6603 -> 0 bytes
 .../__pycache__/reporter.cpython-39.pyc       |  Bin 3167 -> 0 bytes
 .../__pycache__/requirements.cpython-39.pyc   |  Bin 7072 -> 0 bytes
 .../__pycache__/resolver.cpython-39.pyc       |  Bin 8079 -> 0 bytes
 .../_internal/resolution/resolvelib/base.py   |   72 +-
 .../resolution/resolvelib/candidates.py       |  357 +-
 .../resolution/resolvelib/factory.py          |  287 +-
 .../resolution/resolvelib/found_candidates.py |   56 +-
 .../resolution/resolvelib/provider.py         |  226 +-
 .../resolution/resolvelib/reporter.py         |   60 +-
 .../resolution/resolvelib/requirements.py     |  101 +-
 .../resolution/resolvelib/resolver.py         |  212 +-
 .../pip/_internal/self_outdated_check.py      |  243 +-
 .../utils/__pycache__/__init__.cpython-39.pyc |  Bin 219 -> 0 bytes
 .../utils/__pycache__/appdirs.cpython-39.pyc  |  Bin 1284 -> 0 bytes
 .../utils/__pycache__/compat.cpython-39.pyc   |  Bin 1486 -> 0 bytes
 .../compatibility_tags.cpython-39.pyc         |  Bin 3862 -> 0 bytes
 .../utils/__pycache__/datetime.cpython-39.pyc |  Bin 490 -> 0 bytes
 .../__pycache__/deprecation.cpython-39.pyc    |  Bin 2785 -> 0 bytes
 .../direct_url_helpers.cpython-39.pyc         |  Bin 2539 -> 0 bytes
 .../__pycache__/distutils_args.cpython-39.pyc |  Bin 1084 -> 0 bytes
 .../utils/__pycache__/encoding.cpython-39.pyc |  Bin 1249 -> 0 bytes
 .../__pycache__/entrypoints.cpython-39.pyc    |  Bin 1288 -> 0 bytes
 .../__pycache__/filesystem.cpython-39.pyc     |  Bin 4958 -> 0 bytes
 .../__pycache__/filetypes.cpython-39.pyc      |  Bin 831 -> 0 bytes
 .../utils/__pycache__/glibc.cpython-39.pyc    |  Bin 1641 -> 0 bytes
 .../utils/__pycache__/hashes.cpython-39.pyc   |  Bin 5023 -> 0 bytes
 .../inject_securetransport.cpython-39.pyc     |  Bin 992 -> 0 bytes
 .../utils/__pycache__/logging.cpython-39.pyc  |  Bin 8943 -> 0 bytes
 .../utils/__pycache__/misc.cpython-39.pyc     |  Bin 21547 -> 0 bytes
 .../utils/__pycache__/models.cpython-39.pyc   |  Bin 1923 -> 0 bytes
 .../__pycache__/packaging.cpython-39.pyc      |  Bin 2547 -> 0 bytes
 .../utils/__pycache__/parallel.cpython-39.pyc |  Bin 3064 -> 0 bytes
 .../__pycache__/pkg_resources.cpython-39.pyc  |  Bin 1745 -> 0 bytes
 .../setuptools_build.cpython-39.pyc           |  Bin 2989 -> 0 bytes
 .../__pycache__/subprocess.cpython-39.pyc     |  Bin 5712 -> 0 bytes
 .../utils/__pycache__/temp_dir.cpython-39.pyc |  Bin 6863 -> 0 bytes
 .../__pycache__/unpacking.cpython-39.pyc      |  Bin 6484 -> 0 bytes
 .../utils/__pycache__/urls.cpython-39.pyc     |  Bin 1375 -> 0 bytes
 .../__pycache__/virtualenv.cpython-39.pyc     |  Bin 3242 -> 0 bytes
 .../utils/__pycache__/wheel.cpython-39.pyc    |  Bin 5993 -> 0 bytes
 .../pip/_internal/utils/appdirs.py            |   48 +-
 .../pip/_internal/utils/compat.py             |    6 +-
 .../pip/_internal/utils/compatibility_tags.py |   45 +-
 .../pip/_internal/utils/datetime.py           |    3 +-
 .../pip/_internal/utils/deprecation.py        |   84 +-
 .../pip/_internal/utils/direct_url_helpers.py |   56 +-
 .../pip/_internal/utils/distutils_args.py     |   43 -
 .../pip/_internal/utils/encoding.py           |    9 +-
 .../pip/_internal/utils/entrypoints.py        |   60 +-
 .../pip/_internal/utils/filesystem.py         |   64 +-
 .../pip/_internal/utils/filetypes.py          |   13 +-
 .../pip/_internal/utils/glibc.py              |   20 +-
 .../pip/_internal/utils/hashes.py             |   56 +-
 .../_internal/utils/inject_securetransport.py |    3 +-
 .../pip/_internal/utils/logging.py            |  259 +-
 .../site-packages/pip/_internal/utils/misc.py |  490 +-
 .../pip/_internal/utils/models.py             |   24 +-
 .../pip/_internal/utils/packaging.py          |   80 +-
 .../pip/_internal/utils/parallel.py           |  101 -
 .../pip/_internal/utils/pkg_resources.py      |   40 -
 .../pip/_internal/utils/setuptools_build.py   |  161 +-
 .../pip/_internal/utils/subprocess.py         |  155 +-
 .../pip/_internal/utils/temp_dir.py           |   58 +-
 .../pip/_internal/utils/unpacking.py          |   38 +-
 .../site-packages/pip/_internal/utils/urls.py |   29 +-
 .../pip/_internal/utils/virtualenv.py         |   29 +-
 .../pip/_internal/utils/wheel.py              |   67 +-
 .../pip/_internal/vcs/__init__.py             |    1 +
 .../vcs/__pycache__/__init__.cpython-39.pyc   |  Bin 512 -> 0 bytes
 .../vcs/__pycache__/bazaar.cpython-39.pyc     |  Bin 3028 -> 0 bytes
 .../vcs/__pycache__/git.cpython-39.pyc        |  Bin 10004 -> 0 bytes
 .../vcs/__pycache__/mercurial.cpython-39.pyc  |  Bin 4649 -> 0 bytes
 .../vcs/__pycache__/subversion.cpython-39.pyc |  Bin 7983 -> 0 bytes
 .../__pycache__/versioncontrol.cpython-39.pyc |  Bin 19128 -> 0 bytes
 .../site-packages/pip/_internal/vcs/bazaar.py |   84 +-
 .../site-packages/pip/_internal/vcs/git.py    |  312 +-
 .../pip/_internal/vcs/mercurial.py            |  107 +-
 .../pip/_internal/vcs/subversion.py           |  165 +-
 .../pip/_internal/vcs/versioncontrol.py       |  362 +-
 .../pip/_internal/wheel_builder.py            |  217 +-
 env/Lib/site-packages/pip/_vendor/__init__.py |   17 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 2974 -> 0 bytes
 .../__pycache__/appdirs.cpython-39.pyc        |  Bin 21427 -> 0 bytes
 .../_vendor/__pycache__/distro.cpython-39.pyc |  Bin 36906 -> 0 bytes
 .../__pycache__/pyparsing.cpython-39.pyc      |  Bin 240463 -> 0 bytes
 .../_vendor/__pycache__/six.cpython-39.pyc    |  Bin 26973 -> 0 bytes
 env/Lib/site-packages/pip/_vendor/appdirs.py  |  633 --
 .../pip/_vendor/cachecontrol/__init__.py      |    9 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 577 -> 0 bytes
 .../__pycache__/_cmd.cpython-39.pyc           |  Bin 1598 -> 0 bytes
 .../__pycache__/adapter.cpython-39.pyc        |  Bin 3103 -> 0 bytes
 .../__pycache__/cache.cpython-39.pyc          |  Bin 1850 -> 0 bytes
 .../__pycache__/compat.cpython-39.pyc         |  Bin 774 -> 0 bytes
 .../__pycache__/controller.cpython-39.pyc     |  Bin 7791 -> 0 bytes
 .../__pycache__/filewrapper.cpython-39.pyc    |  Bin 2199 -> 0 bytes
 .../__pycache__/heuristics.cpython-39.pyc     |  Bin 4731 -> 0 bytes
 .../__pycache__/serialize.cpython-39.pyc      |  Bin 4250 -> 0 bytes
 .../__pycache__/wrapper.cpython-39.pyc        |  Bin 701 -> 0 bytes
 .../pip/_vendor/cachecontrol/_cmd.py          |    4 +
 .../pip/_vendor/cachecontrol/adapter.py       |   10 +-
 .../pip/_vendor/cachecontrol/cache.py         |   30 +-
 .../_vendor/cachecontrol/caches/__init__.py   |   11 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 321 -> 0 bytes
 .../__pycache__/file_cache.cpython-39.pyc     |  Bin 3337 -> 0 bytes
 .../__pycache__/redis_cache.cpython-39.pyc    |  Bin 1593 -> 0 bytes
 .../_vendor/cachecontrol/caches/file_cache.py |   58 +-
 .../cachecontrol/caches/redis_cache.py        |    8 +-
 .../pip/_vendor/cachecontrol/compat.py        |    5 +-
 .../pip/_vendor/cachecontrol/controller.py    |  111 +-
 .../pip/_vendor/cachecontrol/filewrapper.py   |   39 +-
 .../pip/_vendor/cachecontrol/heuristics.py    |    4 +
 .../pip/_vendor/cachecontrol/serialize.py     |   52 +-
 .../pip/_vendor/cachecontrol/wrapper.py       |    4 +
 .../pip/_vendor/certifi/__init__.py           |    3 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 303 -> 0 bytes
 .../__pycache__/__main__.cpython-39.pyc       |  Bin 480 -> 0 bytes
 .../certifi/__pycache__/core.cpython-39.pyc   |  Bin 1571 -> 0 bytes
 .../pip/_vendor/certifi/cacert.pem            | 1824 +++--
 .../site-packages/pip/_vendor/certifi/core.py |   86 +-
 .../pip/_vendor/chardet/__init__.py           |  100 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 1927 -> 0 bytes
 .../__pycache__/big5freq.cpython-39.pyc       |  Bin 27206 -> 0 bytes
 .../__pycache__/big5prober.cpython-39.pyc     |  Bin 1161 -> 0 bytes
 .../chardistribution.cpython-39.pyc           |  Bin 6247 -> 0 bytes
 .../charsetgroupprober.cpython-39.pyc         |  Bin 2288 -> 0 bytes
 .../__pycache__/charsetprober.cpython-39.pyc  |  Bin 3510 -> 0 bytes
 .../codingstatemachine.cpython-39.pyc         |  Bin 2937 -> 0 bytes
 .../chardet/__pycache__/compat.cpython-39.pyc |  Bin 426 -> 0 bytes
 .../__pycache__/cp949prober.cpython-39.pyc    |  Bin 1168 -> 0 bytes
 .../chardet/__pycache__/enums.cpython-39.pyc  |  Bin 2675 -> 0 bytes
 .../__pycache__/escprober.cpython-39.pyc      |  Bin 2660 -> 0 bytes
 .../chardet/__pycache__/escsm.cpython-39.pyc  |  Bin 7109 -> 0 bytes
 .../__pycache__/eucjpprober.cpython-39.pyc    |  Bin 2474 -> 0 bytes
 .../__pycache__/euckrfreq.cpython-39.pyc      |  Bin 12090 -> 0 bytes
 .../__pycache__/euckrprober.cpython-39.pyc    |  Bin 1169 -> 0 bytes
 .../__pycache__/euctwfreq.cpython-39.pyc      |  Bin 27210 -> 0 bytes
 .../__pycache__/euctwprober.cpython-39.pyc    |  Bin 1169 -> 0 bytes
 .../__pycache__/gb2312freq.cpython-39.pyc     |  Bin 19134 -> 0 bytes
 .../__pycache__/gb2312prober.cpython-39.pyc   |  Bin 1177 -> 0 bytes
 .../__pycache__/hebrewprober.cpython-39.pyc   |  Bin 3046 -> 0 bytes
 .../__pycache__/jisfreq.cpython-39.pyc        |  Bin 22162 -> 0 bytes
 .../chardet/__pycache__/jpcntx.cpython-39.pyc |  Bin 37635 -> 0 bytes
 .../langbulgarianmodel.cpython-39.pyc         |  Bin 21837 -> 0 bytes
 .../__pycache__/langgreekmodel.cpython-39.pyc |  Bin 20513 -> 0 bytes
 .../langhebrewmodel.cpython-39.pyc            |  Bin 20581 -> 0 bytes
 .../langhungarianmodel.cpython-39.pyc         |  Bin 21782 -> 0 bytes
 .../langrussianmodel.cpython-39.pyc           |  Bin 26385 -> 0 bytes
 .../__pycache__/langthaimodel.cpython-39.pyc  |  Bin 20757 -> 0 bytes
 .../langturkishmodel.cpython-39.pyc           |  Bin 20597 -> 0 bytes
 .../__pycache__/latin1prober.cpython-39.pyc   |  Bin 2982 -> 0 bytes
 .../mbcharsetprober.cpython-39.pyc            |  Bin 2289 -> 0 bytes
 .../mbcsgroupprober.cpython-39.pyc            |  Bin 1158 -> 0 bytes
 .../chardet/__pycache__/mbcssm.cpython-39.pyc |  Bin 15745 -> 0 bytes
 .../sbcharsetprober.cpython-39.pyc            |  Bin 3142 -> 0 bytes
 .../sbcsgroupprober.cpython-39.pyc            |  Bin 1727 -> 0 bytes
 .../__pycache__/sjisprober.cpython-39.pyc     |  Bin 2510 -> 0 bytes
 .../universaldetector.cpython-39.pyc          |  Bin 5858 -> 0 bytes
 .../__pycache__/utf8prober.cpython-39.pyc     |  Bin 2019 -> 0 bytes
 .../__pycache__/version.cpython-39.pyc        |  Bin 466 -> 0 bytes
 .../pip/_vendor/chardet/big5freq.py           |    6 +-
 .../pip/_vendor/chardet/big5prober.py         |   12 +-
 .../pip/_vendor/chardet/chardistribution.py   |  148 +-
 .../pip/_vendor/chardet/charsetgroupprober.py |   45 +-
 .../pip/_vendor/chardet/charsetprober.py      |   74 +-
 .../pip/_vendor/chardet/cli/__init__.py       |    1 -
 .../cli/__pycache__/__init__.cpython-39.pyc   |  Bin 223 -> 0 bytes
 .../cli/__pycache__/chardetect.cpython-39.pyc |  Bin 2717 -> 0 bytes
 .../pip/_vendor/chardet/cli/chardetect.py     |   90 +-
 .../pip/_vendor/chardet/codingstatemachine.py |   32 +-
 .../pip/_vendor/chardet/compat.py             |   36 -
 .../pip/_vendor/chardet/cp949prober.py        |    8 +-
 .../pip/_vendor/chardet/enums.py              |   23 +-
 .../pip/_vendor/chardet/escprober.py          |   45 +-
 .../pip/_vendor/chardet/escsm.py              |  385 +-
 .../pip/_vendor/chardet/eucjpprober.py        |   60 +-
 .../pip/_vendor/chardet/euckrfreq.py          |    3 +-
 .../pip/_vendor/chardet/euckrprober.py        |   12 +-
 .../pip/_vendor/chardet/euctwfreq.py          |  677 +-
 .../pip/_vendor/chardet/euctwprober.py        |   13 +-
 .../pip/_vendor/chardet/gb2312freq.py         |    3 +-
 .../pip/_vendor/chardet/gb2312prober.py       |   13 +-
 .../pip/_vendor/chardet/hebrewprober.py       |  110 +-
 .../pip/_vendor/chardet/jisfreq.py            |    4 +-
 .../pip/_vendor/chardet/jpcntx.py             |  219 +-
 .../pip/_vendor/chardet/langbulgarianmodel.py | 1061 ++-
 .../pip/_vendor/chardet/langgreekmodel.py     | 1061 ++-
 .../pip/_vendor/chardet/langhebrewmodel.py    |  533 +-
 .../pip/_vendor/chardet/langhungarianmodel.py | 1061 ++-
 .../pip/_vendor/chardet/langrussianmodel.py   | 3173 ++++----
 .../pip/_vendor/chardet/langthaimodel.py      |  533 +-
 .../pip/_vendor/chardet/langturkishmodel.py   |  533 +-
 .../pip/_vendor/chardet/latin1prober.py       |   44 +-
 .../pip/_vendor/chardet/mbcharsetprober.py    |   62 +-
 .../pip/_vendor/chardet/mbcsgroupprober.py    |   19 +-
 .../pip/_vendor/chardet/mbcssm.py             |  813 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 228 -> 0 bytes
 .../__pycache__/languages.cpython-39.pyc      |  Bin 7959 -> 0 bytes
 .../pip/_vendor/chardet/metadata/languages.py |  574 +-
 .../pip/_vendor/chardet/sbcharsetprober.py    |   95 +-
 .../pip/_vendor/chardet/sbcsgroupprober.py    |   33 +-
 .../pip/_vendor/chardet/sjisprober.py         |   65 +-
 .../pip/_vendor/chardet/universaldetector.py  |  236 +-
 .../pip/_vendor/chardet/utf8prober.py         |   32 +-
 .../pip/_vendor/chardet/version.py            |    6 +-
 .../pip/_vendor/colorama/__init__.py          |    5 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 471 -> 0 bytes
 .../colorama/__pycache__/ansi.cpython-39.pyc  |  Bin 3256 -> 0 bytes
 .../__pycache__/ansitowin32.cpython-39.pyc    |  Bin 7722 -> 0 bytes
 .../__pycache__/initialise.cpython-39.pyc     |  Bin 1738 -> 0 bytes
 .../colorama/__pycache__/win32.cpython-39.pyc |  Bin 3970 -> 0 bytes
 .../__pycache__/winterm.cpython-39.pyc        |  Bin 4692 -> 0 bytes
 .../pip/_vendor/colorama/ansitowin32.py       |   27 +-
 .../pip/_vendor/colorama/initialise.py        |   51 +-
 .../pip/_vendor/colorama/win32.py             |   28 +
 .../pip/_vendor/colorama/winterm.py           |   28 +-
 .../pip/_vendor/distlib/__init__.py           |    4 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 1084 -> 0 bytes
 .../distlib/__pycache__/compat.cpython-39.pyc |  Bin 32186 -> 0 bytes
 .../__pycache__/database.cpython-39.pyc       |  Bin 42508 -> 0 bytes
 .../distlib/__pycache__/index.cpython-39.pyc  |  Bin 17529 -> 0 bytes
 .../__pycache__/locators.cpython-39.pyc       |  Bin 38517 -> 0 bytes
 .../__pycache__/manifest.cpython-39.pyc       |  Bin 10220 -> 0 bytes
 .../__pycache__/markers.cpython-39.pyc        |  Bin 4511 -> 0 bytes
 .../__pycache__/metadata.cpython-39.pyc       |  Bin 26437 -> 0 bytes
 .../__pycache__/resources.cpython-39.pyc      |  Bin 11050 -> 0 bytes
 .../__pycache__/scripts.cpython-39.pyc        |  Bin 10958 -> 0 bytes
 .../distlib/__pycache__/util.cpython-39.pyc   |  Bin 48230 -> 0 bytes
 .../__pycache__/version.cpython-39.pyc        |  Bin 20335 -> 0 bytes
 .../distlib/__pycache__/wheel.cpython-39.pyc  |  Bin 26419 -> 0 bytes
 .../pip/_vendor/distlib/_backport/__init__.py |    6 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 511 -> 0 bytes
 .../_backport/__pycache__/misc.cpython-39.pyc |  Bin 1131 -> 0 bytes
 .../__pycache__/shutil.cpython-39.pyc         |  Bin 21705 -> 0 bytes
 .../__pycache__/sysconfig.cpython-39.pyc      |  Bin 15995 -> 0 bytes
 .../__pycache__/tarfile.cpython-39.pyc        |  Bin 62759 -> 0 bytes
 .../pip/_vendor/distlib/_backport/misc.py     |   41 -
 .../pip/_vendor/distlib/_backport/shutil.py   |  764 --
 .../_vendor/distlib/_backport/sysconfig.cfg   |   84 -
 .../_vendor/distlib/_backport/sysconfig.py    |  786 --
 .../pip/_vendor/distlib/_backport/tarfile.py  | 2607 ------
 .../pip/_vendor/distlib/compat.py             |   52 +-
 .../pip/_vendor/distlib/database.py           |   67 +-
 .../pip/_vendor/distlib/index.py              |   40 +-
 .../pip/_vendor/distlib/locators.py           |   26 +-
 .../pip/_vendor/distlib/markers.py            |   29 +-
 .../pip/_vendor/distlib/metadata.py           |   54 +-
 .../pip/_vendor/distlib/resources.py          |    7 +-
 .../pip/_vendor/distlib/scripts.py            |   46 +-
 .../site-packages/pip/_vendor/distlib/t32.exe |  Bin 96768 -> 97792 bytes
 .../site-packages/pip/_vendor/distlib/t64.exe |  Bin 105984 -> 108032 bytes
 .../site-packages/pip/_vendor/distlib/util.py |  295 +-
 .../pip/_vendor/distlib/version.py            |    5 +-
 .../site-packages/pip/_vendor/distlib/w32.exe |  Bin 90112 -> 91648 bytes
 .../site-packages/pip/_vendor/distlib/w64.exe |  Bin 99840 -> 101888 bytes
 .../pip/_vendor/distlib/wheel.py              |   96 +-
 env/Lib/site-packages/pip/_vendor/distro.py   | 1230 ---
 .../pip/_vendor/html5lib/__init__.py          |   35 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 1330 -> 0 bytes
 .../__pycache__/_ihatexml.cpython-39.pyc      |  Bin 13799 -> 0 bytes
 .../__pycache__/_inputstream.cpython-39.pyc   |  Bin 21658 -> 0 bytes
 .../__pycache__/_tokenizer.cpython-39.pyc     |  Bin 39753 -> 0 bytes
 .../__pycache__/_utils.cpython-39.pyc         |  Bin 4830 -> 0 bytes
 .../__pycache__/constants.cpython-39.pyc      |  Bin 66368 -> 0 bytes
 .../__pycache__/html5parser.cpython-39.pyc    |  Bin 91039 -> 0 bytes
 .../__pycache__/serializer.cpython-39.pyc     |  Bin 10841 -> 0 bytes
 .../pip/_vendor/html5lib/_ihatexml.py         |  289 -
 .../pip/_vendor/html5lib/_inputstream.py      |  918 ---
 .../pip/_vendor/html5lib/_tokenizer.py        | 1735 ----
 .../pip/_vendor/html5lib/_trie/__init__.py    |    5 -
 .../_trie/__pycache__/__init__.cpython-39.pyc |  Bin 380 -> 0 bytes
 .../_trie/__pycache__/_base.cpython-39.pyc    |  Bin 1624 -> 0 bytes
 .../_trie/__pycache__/py.cpython-39.pyc       |  Bin 2285 -> 0 bytes
 .../pip/_vendor/html5lib/_trie/_base.py       |   40 -
 .../pip/_vendor/html5lib/_trie/py.py          |   67 -
 .../pip/_vendor/html5lib/_utils.py            |  159 -
 .../pip/_vendor/html5lib/constants.py         | 2946 -------
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 228 -> 0 bytes
 .../alphabeticalattributes.cpython-39.pyc     |  Bin 1350 -> 0 bytes
 .../filters/__pycache__/base.cpython-39.pyc   |  Bin 898 -> 0 bytes
 .../inject_meta_charset.cpython-39.pyc        |  Bin 1904 -> 0 bytes
 .../filters/__pycache__/lint.cpython-39.pyc   |  Bin 2646 -> 0 bytes
 .../__pycache__/optionaltags.cpython-39.pyc   |  Bin 2791 -> 0 bytes
 .../__pycache__/sanitizer.cpython-39.pyc      |  Bin 16914 -> 0 bytes
 .../__pycache__/whitespace.cpython-39.pyc     |  Bin 1396 -> 0 bytes
 .../filters/alphabeticalattributes.py         |   29 -
 .../pip/_vendor/html5lib/filters/base.py      |   12 -
 .../html5lib/filters/inject_meta_charset.py   |   73 -
 .../pip/_vendor/html5lib/filters/lint.py      |   93 -
 .../_vendor/html5lib/filters/optionaltags.py  |  207 -
 .../pip/_vendor/html5lib/filters/sanitizer.py |  916 ---
 .../_vendor/html5lib/filters/whitespace.py    |   38 -
 .../pip/_vendor/html5lib/html5parser.py       | 2795 -------
 .../pip/_vendor/html5lib/serializer.py        |  409 -
 .../_vendor/html5lib/treeadapters/__init__.py |   30 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 965 -> 0 bytes
 .../__pycache__/genshi.cpython-39.pyc         |  Bin 1573 -> 0 bytes
 .../__pycache__/sax.cpython-39.pyc            |  Bin 1492 -> 0 bytes
 .../_vendor/html5lib/treeadapters/genshi.py   |   54 -
 .../pip/_vendor/html5lib/treeadapters/sax.py  |   50 -
 .../_vendor/html5lib/treebuilders/__init__.py |   88 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 3360 -> 0 bytes
 .../__pycache__/base.cpython-39.pyc           |  Bin 11344 -> 0 bytes
 .../__pycache__/dom.cpython-39.pyc            |  Bin 9481 -> 0 bytes
 .../__pycache__/etree.cpython-39.pyc          |  Bin 11849 -> 0 bytes
 .../__pycache__/etree_lxml.cpython-39.pyc     |  Bin 13032 -> 0 bytes
 .../pip/_vendor/html5lib/treebuilders/base.py |  417 -
 .../pip/_vendor/html5lib/treebuilders/dom.py  |  239 -
 .../_vendor/html5lib/treebuilders/etree.py    |  343 -
 .../html5lib/treebuilders/etree_lxml.py       |  392 -
 .../_vendor/html5lib/treewalkers/__init__.py  |  154 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 4026 -> 0 bytes
 .../__pycache__/base.cpython-39.pyc           |  Bin 7025 -> 0 bytes
 .../__pycache__/dom.cpython-39.pyc            |  Bin 1760 -> 0 bytes
 .../__pycache__/etree.cpython-39.pyc          |  Bin 3522 -> 0 bytes
 .../__pycache__/etree_lxml.cpython-39.pyc     |  Bin 6659 -> 0 bytes
 .../__pycache__/genshi.cpython-39.pyc         |  Bin 1916 -> 0 bytes
 .../pip/_vendor/html5lib/treewalkers/base.py  |  252 -
 .../pip/_vendor/html5lib/treewalkers/dom.py   |   43 -
 .../pip/_vendor/html5lib/treewalkers/etree.py |  131 -
 .../html5lib/treewalkers/etree_lxml.py        |  215 -
 .../_vendor/html5lib/treewalkers/genshi.py    |   69 -
 .../pip/_vendor/idna/__init__.py              |   44 +-
 .../idna/__pycache__/__init__.cpython-39.pyc  |  Bin 285 -> 0 bytes
 .../idna/__pycache__/codec.cpython-39.pyc     |  Bin 2819 -> 0 bytes
 .../idna/__pycache__/compat.cpython-39.pyc    |  Bin 657 -> 0 bytes
 .../idna/__pycache__/core.cpython-39.pyc      |  Bin 9113 -> 0 bytes
 .../idna/__pycache__/idnadata.cpython-39.pyc  |  Bin 22166 -> 0 bytes
 .../idna/__pycache__/intranges.cpython-39.pyc |  Bin 1837 -> 0 bytes
 .../__pycache__/package_data.cpython-39.pyc   |  Bin 239 -> 0 bytes
 .../idna/__pycache__/uts46data.cpython-39.pyc |  Bin 146174 -> 0 bytes
 .../site-packages/pip/_vendor/idna/codec.py   |   32 +-
 .../site-packages/pip/_vendor/idna/compat.py  |    7 +-
 .../site-packages/pip/_vendor/idna/core.py    |  124 +-
 .../pip/_vendor/idna/idnadata.py              |  165 +-
 .../pip/_vendor/idna/intranges.py             |    9 +-
 .../pip/_vendor/idna/package_data.py          |    2 +-
 .../pip/_vendor/idna/uts46data.py             |  922 ++-
 .../pip/_vendor/msgpack/__init__.py           |    5 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 1442 -> 0 bytes
 .../__pycache__/_version.cpython-39.pyc       |  Bin 246 -> 0 bytes
 .../__pycache__/exceptions.cpython-39.pyc     |  Bin 1880 -> 0 bytes
 .../msgpack/__pycache__/ext.cpython-39.pyc    |  Bin 6308 -> 0 bytes
 .../__pycache__/fallback.cpython-39.pyc       |  Bin 26754 -> 0 bytes
 .../pip/_vendor/msgpack/_version.py           |    1 -
 .../site-packages/pip/_vendor/msgpack/ext.py  |   10 +-
 .../pip/_vendor/msgpack/fallback.py           |  291 +-
 .../pip/_vendor/packaging/__about__.py        |    3 +-
 .../pip/_vendor/packaging/__init__.py         |    1 -
 .../__pycache__/__about__.cpython-39.pyc      |  Bin 717 -> 0 bytes
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 573 -> 0 bytes
 .../__pycache__/_compat.cpython-39.pyc        |  Bin 1171 -> 0 bytes
 .../__pycache__/_structures.cpython-39.pyc    |  Bin 2925 -> 0 bytes
 .../__pycache__/_typing.cpython-39.pyc        |  Bin 1528 -> 0 bytes
 .../__pycache__/markers.cpython-39.pyc        |  Bin 9299 -> 0 bytes
 .../__pycache__/requirements.cpython-39.pyc   |  Bin 4172 -> 0 bytes
 .../__pycache__/specifiers.cpython-39.pyc     |  Bin 20954 -> 0 bytes
 .../packaging/__pycache__/tags.cpython-39.pyc |  Bin 18571 -> 0 bytes
 .../__pycache__/utils.cpython-39.pyc          |  Bin 3639 -> 0 bytes
 .../__pycache__/version.cpython-39.pyc        |  Bin 12703 -> 0 bytes
 .../pip/_vendor/packaging/_compat.py          |   38 -
 .../pip/_vendor/packaging/_structures.py      |   61 +-
 .../pip/_vendor/packaging/_typing.py          |   48 -
 .../pip/_vendor/packaging/markers.py          |  118 +-
 .../pip/_vendor/packaging/requirements.py     |   60 +-
 .../pip/_vendor/packaging/specifiers.py       |  312 +-
 .../pip/_vendor/packaging/tags.py             |  563 +-
 .../pip/_vendor/packaging/utils.py            |   76 +-
 .../pip/_vendor/packaging/version.py          |  236 +-
 .../pip/_vendor/pep517/__init__.py            |    6 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 341 -> 0 bytes
 .../pep517/__pycache__/build.cpython-39.pyc   |  Bin 3590 -> 0 bytes
 .../pep517/__pycache__/check.cpython-39.pyc   |  Bin 5125 -> 0 bytes
 .../__pycache__/colorlog.cpython-39.pyc       |  Bin 2966 -> 0 bytes
 .../pep517/__pycache__/compat.cpython-39.pyc  |  Bin 1143 -> 0 bytes
 .../__pycache__/dirtools.cpython-39.pyc       |  Bin 1375 -> 0 bytes
 .../__pycache__/envbuild.cpython-39.pyc       |  Bin 4508 -> 0 bytes
 .../pep517/__pycache__/meta.cpython-39.pyc    |  Bin 2948 -> 0 bytes
 .../__pycache__/wrappers.cpython-39.pyc       |  Bin 10508 -> 0 bytes
 .../site-packages/pip/_vendor/pep517/build.py |  127 -
 .../site-packages/pip/_vendor/pep517/check.py |  206 -
 .../pip/_vendor/pep517/colorlog.py            |  115 -
 .../pip/_vendor/pep517/compat.py              |   34 -
 .../pip/_vendor/pep517/dirtools.py            |   44 -
 .../pip/_vendor/pep517/envbuild.py            |  167 -
 .../pip/_vendor/pep517/in_process/__init__.py |   17 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 943 -> 0 bytes
 .../__pycache__/_in_process.cpython-39.pyc    |  Bin 8305 -> 0 bytes
 .../_vendor/pep517/in_process/_in_process.py  |  280 -
 .../site-packages/pip/_vendor/pep517/meta.py  |   92 -
 .../pip/_vendor/pep517/wrappers.py            |  318 -
 .../pip/_vendor/pkg_resources/__init__.py     |  857 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 100359 -> 0 bytes
 .../__pycache__/py31compat.cpython-39.pyc     |  Bin 678 -> 0 bytes
 .../pip/_vendor/pkg_resources/py31compat.py   |   23 -
 .../pip/_vendor/progress/__init__.py          |  177 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 5685 -> 0 bytes
 .../progress/__pycache__/bar.cpython-39.pyc   |  Bin 2667 -> 0 bytes
 .../__pycache__/counter.cpython-39.pyc        |  Bin 1501 -> 0 bytes
 .../__pycache__/spinner.cpython-39.pyc        |  Bin 1418 -> 0 bytes
 .../site-packages/pip/_vendor/progress/bar.py |   91 -
 .../pip/_vendor/progress/counter.py           |   41 -
 .../pip/_vendor/progress/spinner.py           |   43 -
 .../site-packages/pip/_vendor/pyparsing.py    | 7107 -----------------
 .../pip/_vendor/requests/__init__.py          |  122 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 3697 -> 0 bytes
 .../__pycache__/__version__.cpython-39.pyc    |  Bin 583 -> 0 bytes
 .../_internal_utils.cpython-39.pyc            |  Bin 1330 -> 0 bytes
 .../__pycache__/adapters.cpython-39.pyc       |  Bin 17001 -> 0 bytes
 .../requests/__pycache__/api.cpython-39.pyc   |  Bin 6787 -> 0 bytes
 .../requests/__pycache__/auth.cpython-39.pyc  |  Bin 8359 -> 0 bytes
 .../requests/__pycache__/certs.cpython-39.pyc |  Bin 661 -> 0 bytes
 .../__pycache__/compat.cpython-39.pyc         |  Bin 1640 -> 0 bytes
 .../__pycache__/cookies.cpython-39.pyc        |  Bin 18850 -> 0 bytes
 .../__pycache__/exceptions.cpython-39.pyc     |  Bin 5273 -> 0 bytes
 .../requests/__pycache__/help.cpython-39.pyc  |  Bin 2744 -> 0 bytes
 .../requests/__pycache__/hooks.cpython-39.pyc |  Bin 1018 -> 0 bytes
 .../__pycache__/models.cpython-39.pyc         |  Bin 23967 -> 0 bytes
 .../__pycache__/packages.cpython-39.pyc       |  Bin 530 -> 0 bytes
 .../__pycache__/sessions.cpython-39.pyc       |  Bin 19872 -> 0 bytes
 .../__pycache__/status_codes.cpython-39.pyc   |  Bin 4267 -> 0 bytes
 .../__pycache__/structures.cpython-39.pyc     |  Bin 4488 -> 0 bytes
 .../requests/__pycache__/utils.cpython-39.pyc |  Bin 22645 -> 0 bytes
 .../pip/_vendor/requests/__version__.py       |   20 +-
 .../pip/_vendor/requests/_internal_utils.py   |   26 +-
 .../pip/_vendor/requests/adapters.py          |  265 +-
 .../site-packages/pip/_vendor/requests/api.py |   26 +-
 .../pip/_vendor/requests/auth.py              |  156 +-
 .../pip/_vendor/requests/certs.py             |   12 +-
 .../pip/_vendor/requests/compat.py            |   89 +-
 .../pip/_vendor/requests/cookies.py           |  152 +-
 .../pip/_vendor/requests/exceptions.py        |   36 +-
 .../pip/_vendor/requests/help.py              |  106 +-
 .../pip/_vendor/requests/hooks.py             |    7 +-
 .../pip/_vendor/requests/models.py            |  364 +-
 .../pip/_vendor/requests/sessions.py          |  292 +-
 .../pip/_vendor/requests/status_codes.py      |  169 +-
 .../pip/_vendor/requests/structures.py        |   12 +-
 .../pip/_vendor/requests/utils.py             |  462 +-
 .../pip/_vendor/resolvelib/__init__.py        |    4 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 634 -> 0 bytes
 .../__pycache__/providers.cpython-39.pyc      |  Bin 6554 -> 0 bytes
 .../__pycache__/reporters.cpython-39.pyc      |  Bin 2330 -> 0 bytes
 .../__pycache__/resolvers.cpython-39.pyc      |  Bin 15225 -> 0 bytes
 .../__pycache__/structs.cpython-39.pyc        |  Bin 6948 -> 0 bytes
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 229 -> 0 bytes
 .../collections_abc.cpython-39.pyc            |  Bin 403 -> 0 bytes
 .../pip/_vendor/resolvelib/providers.py       |   25 +-
 .../pip/_vendor/resolvelib/reporters.py       |    8 +-
 .../pip/_vendor/resolvelib/resolvers.py       |  141 +-
 .../pip/_vendor/resolvelib/structs.py         |   25 +-
 env/Lib/site-packages/pip/_vendor/six.py      |   18 +-
 .../pip/_vendor/tenacity/__init__.py          |  463 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 14706 -> 0 bytes
 .../__pycache__/_asyncio.cpython-39.pyc       |  Bin 2231 -> 0 bytes
 .../__pycache__/_utils.cpython-39.pyc         |  Bin 3979 -> 0 bytes
 .../tenacity/__pycache__/after.cpython-39.pyc |  Bin 1006 -> 0 bytes
 .../__pycache__/before.cpython-39.pyc         |  Bin 902 -> 0 bytes
 .../__pycache__/before_sleep.cpython-39.pyc   |  Bin 1250 -> 0 bytes
 .../__pycache__/compat.cpython-39.pyc         |  Bin 986 -> 0 bytes
 .../tenacity/__pycache__/nap.cpython-39.pyc   |  Bin 1055 -> 0 bytes
 .../tenacity/__pycache__/retry.cpython-39.pyc |  Bin 7440 -> 0 bytes
 .../tenacity/__pycache__/stop.cpython-39.pyc  |  Bin 3816 -> 0 bytes
 .../__pycache__/tornadoweb.cpython-39.pyc     |  Bin 1370 -> 0 bytes
 .../tenacity/__pycache__/wait.cpython-39.pyc  |  Bin 7373 -> 0 bytes
 .../pip/_vendor/tenacity/_asyncio.py          |   45 +-
 .../pip/_vendor/tenacity/_utils.py            |  109 +-
 .../pip/_vendor/tenacity/after.py             |   33 +-
 .../pip/_vendor/tenacity/before.py            |   23 +-
 .../pip/_vendor/tenacity/before_sleep.py      |   42 +-
 .../pip/_vendor/tenacity/compat.py            |   23 -
 .../site-packages/pip/_vendor/tenacity/nap.py |   13 +-
 .../pip/_vendor/tenacity/retry.py             |  180 +-
 .../pip/_vendor/tenacity/stop.py              |   48 +-
 .../pip/_vendor/tenacity/tornadoweb.py        |   24 +-
 .../pip/_vendor/tenacity/wait.py              |  121 +-
 .../pip/_vendor/toml/__init__.py              |   25 -
 .../toml/__pycache__/__init__.cpython-39.pyc  |  Bin 760 -> 0 bytes
 .../toml/__pycache__/decoder.cpython-39.pyc   |  Bin 23252 -> 0 bytes
 .../toml/__pycache__/encoder.cpython-39.pyc   |  Bin 9435 -> 0 bytes
 .../toml/__pycache__/ordered.cpython-39.pyc   |  Bin 999 -> 0 bytes
 .../toml/__pycache__/tz.cpython-39.pyc        |  Bin 1301 -> 0 bytes
 .../site-packages/pip/_vendor/toml/decoder.py | 1057 ---
 .../site-packages/pip/_vendor/toml/encoder.py |  304 -
 .../site-packages/pip/_vendor/toml/ordered.py |   15 -
 env/Lib/site-packages/pip/_vendor/toml/tz.py  |   24 -
 .../pip/_vendor/urllib3/__init__.py           |   17 +
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 2217 -> 0 bytes
 .../__pycache__/_collections.cpython-39.pyc   |  Bin 10812 -> 0 bytes
 .../__pycache__/_version.cpython-39.pyc       |  Bin 241 -> 0 bytes
 .../__pycache__/connection.cpython-39.pyc     |  Bin 13397 -> 0 bytes
 .../__pycache__/connectionpool.cpython-39.pyc |  Bin 24496 -> 0 bytes
 .../__pycache__/exceptions.cpython-39.pyc     |  Bin 11674 -> 0 bytes
 .../urllib3/__pycache__/fields.cpython-39.pyc |  Bin 8189 -> 0 bytes
 .../__pycache__/filepost.cpython-39.pyc       |  Bin 2790 -> 0 bytes
 .../__pycache__/poolmanager.cpython-39.pyc    |  Bin 15192 -> 0 bytes
 .../__pycache__/request.cpython-39.pyc        |  Bin 5653 -> 0 bytes
 .../__pycache__/response.cpython-39.pyc       |  Bin 20864 -> 0 bytes
 .../pip/_vendor/urllib3/_version.py           |    2 +-
 .../pip/_vendor/urllib3/connection.py         |   61 +-
 .../pip/_vendor/urllib3/connectionpool.py     |   97 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 227 -> 0 bytes
 .../_appengine_environ.cpython-39.pyc         |  Bin 1447 -> 0 bytes
 .../__pycache__/appengine.cpython-39.pyc      |  Bin 8300 -> 0 bytes
 .../__pycache__/ntlmpool.cpython-39.pyc       |  Bin 3292 -> 0 bytes
 .../__pycache__/pyopenssl.cpython-39.pyc      |  Bin 15559 -> 0 bytes
 .../securetransport.cpython-39.pyc            |  Bin 21871 -> 0 bytes
 .../contrib/__pycache__/socks.cpython-39.pyc  |  Bin 5663 -> 0 bytes
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 244 -> 0 bytes
 .../__pycache__/bindings.cpython-39.pyc       |  Bin 10751 -> 0 bytes
 .../__pycache__/low_level.cpython-39.pyc      |  Bin 9200 -> 0 bytes
 .../contrib/_securetransport/bindings.py      |    2 +-
 .../contrib/_securetransport/low_level.py     |    1 +
 .../pip/_vendor/urllib3/contrib/appengine.py  |    4 +-
 .../pip/_vendor/urllib3/contrib/ntlmpool.py   |   13 +-
 .../pip/_vendor/urllib3/contrib/pyopenssl.py  |   23 +-
 .../urllib3/contrib/securetransport.py        |    9 +-
 .../pip/_vendor/urllib3/contrib/socks.py      |    2 +-
 .../pip/_vendor/urllib3/packages/__init__.py  |    5 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 341 -> 0 bytes
 .../packages/__pycache__/six.cpython-39.pyc   |  Bin 26545 -> 0 bytes
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 238 -> 0 bytes
 .../__pycache__/makefile.cpython-39.pyc       |  Bin 1336 -> 0 bytes
 .../pip/_vendor/urllib3/packages/six.py       |  125 +-
 .../packages/ssl_match_hostname/__init__.py   |   22 -
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 578 -> 0 bytes
 .../_implementation.cpython-39.pyc            |  Bin 3331 -> 0 bytes
 .../ssl_match_hostname/_implementation.py     |  160 -
 .../pip/_vendor/urllib3/poolmanager.py        |    3 +-
 .../pip/_vendor/urllib3/response.py           |   72 +-
 .../util/__pycache__/__init__.cpython-39.pyc  |  Bin 1137 -> 0 bytes
 .../__pycache__/connection.cpython-39.pyc     |  Bin 3491 -> 0 bytes
 .../util/__pycache__/proxy.cpython-39.pyc     |  Bin 1373 -> 0 bytes
 .../util/__pycache__/queue.cpython-39.pyc     |  Bin 1092 -> 0 bytes
 .../util/__pycache__/request.cpython-39.pyc   |  Bin 3480 -> 0 bytes
 .../util/__pycache__/response.cpython-39.pyc  |  Bin 2377 -> 0 bytes
 .../util/__pycache__/retry.cpython-39.pyc     |  Bin 15994 -> 0 bytes
 .../util/__pycache__/ssl_.cpython-39.pyc      |  Bin 11055 -> 0 bytes
 .../__pycache__/ssltransport.cpython-39.pyc   |  Bin 7543 -> 0 bytes
 .../util/__pycache__/timeout.cpython-39.pyc   |  Bin 8975 -> 0 bytes
 .../util/__pycache__/url.cpython-39.pyc       |  Bin 10651 -> 0 bytes
 .../util/__pycache__/wait.cpython-39.pyc      |  Bin 3160 -> 0 bytes
 .../pip/_vendor/urllib3/util/connection.py    |    5 +-
 .../pip/_vendor/urllib3/util/proxy.py         |    1 +
 .../pip/_vendor/urllib3/util/request.py       |    6 -
 .../pip/_vendor/urllib3/util/retry.py         |   34 +-
 .../pip/_vendor/urllib3/util/ssl_.py          |   43 +-
 .../pip/_vendor/urllib3/util/ssltransport.py  |    6 +-
 .../pip/_vendor/urllib3/util/timeout.py       |    9 +-
 .../pip/_vendor/urllib3/util/url.py           |   17 +-
 .../pip/_vendor/urllib3/util/wait.py          |    1 -
 env/Lib/site-packages/pip/_vendor/vendor.txt  |   43 +-
 .../__pycache__/__init__.cpython-39.pyc       |  Bin 9751 -> 0 bytes
 .../__pycache__/labels.cpython-39.pyc         |  Bin 3865 -> 0 bytes
 .../__pycache__/mklabels.cpython-39.pyc       |  Bin 1935 -> 0 bytes
 .../__pycache__/tests.cpython-39.pyc          |  Bin 5099 -> 0 bytes
 .../__pycache__/x_user_defined.cpython-39.pyc |  Bin 2695 -> 0 bytes
 env/Lib/site-packages/pip/py.typed            |    2 +-
 env/Scripts/Activate.ps1                      |  411 +-
 env/Scripts/activate                          |   16 +-
 env/Scripts/activate.bat                      |    3 +-
 env/Scripts/deactivate.bat                    |    1 +
 env/Scripts/pip.exe                           |  Bin 106410 -> 108400 bytes
 env/Scripts/pip3.9.exe                        |  Bin 106410 -> 0 bytes
 env/Scripts/pip3.exe                          |  Bin 106410 -> 108400 bytes
 env/Scripts/python.exe                        |  Bin 543464 -> 270616 bytes
 env/Scripts/pythonw.exe                       |  Bin 542440 -> 259352 bytes
 env/pyvenv.cfg                                |    6 +-
 project_a4_logistik/urls.py                   |    3 +-
 774 files changed, 23382 insertions(+), 50298 deletions(-)
 rename {env/Lib/site-packages/pip/_vendor/html5lib/filters => detail_item}/__init__.py (100%)
 create mode 100644 detail_item/admin.py
 create mode 100644 detail_item/apps.py
 rename env/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED => detail_item/migrations/__init__.py (100%)
 create mode 100644 detail_item/models.py
 create mode 100644 detail_item/templates/template.html
 create mode 100644 detail_item/tests.py
 create mode 100644 detail_item/urls.py
 create mode 100644 detail_item/views.py
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/METADATA
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/RECORD
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt
 delete mode 100644 env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt
 delete mode 100644 env/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/operations/install/legacy.py
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/req/req_tracker.py
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/distutils_args.py
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/parallel.py
 delete mode 100644 env/Lib/site-packages/pip/_internal/utils/pkg_resources.py
 delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/pyparsing.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/appdirs.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/compat.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/distro.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/_utils.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/constants.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/serializer.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/msgpack/_version.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/_compat.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/packaging/_typing.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/build.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/check.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/colorlog.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/compat.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/dirtools.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/envbuild.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/meta.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pep517/wrappers.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/bar.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/counter.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/progress/spinner.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/pyparsing.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/tenacity/compat.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/decoder.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/encoder.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/ordered.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/toml/tz.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc
 delete mode 100644 env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc
 delete mode 100644 env/Scripts/pip3.9.exe

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__init__.py b/detail_item/__init__.py
similarity index 100%
rename from env/Lib/site-packages/pip/_vendor/html5lib/filters/__init__.py
rename to detail_item/__init__.py
diff --git a/detail_item/admin.py b/detail_item/admin.py
new file mode 100644
index 00000000..8c38f3f3
--- /dev/null
+++ b/detail_item/admin.py
@@ -0,0 +1,3 @@
+from django.contrib import admin
+
+# Register your models here.
diff --git a/detail_item/apps.py b/detail_item/apps.py
new file mode 100644
index 00000000..29c5f55b
--- /dev/null
+++ b/detail_item/apps.py
@@ -0,0 +1,6 @@
+from django.apps import AppConfig
+
+
+class DetailItemConfig(AppConfig):
+    default_auto_field = 'django.db.models.BigAutoField'
+    name = 'detail_item'
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED b/detail_item/migrations/__init__.py
similarity index 100%
rename from env/Lib/site-packages/pip-21.1.3.dist-info/REQUESTED
rename to detail_item/migrations/__init__.py
diff --git a/detail_item/models.py b/detail_item/models.py
new file mode 100644
index 00000000..f94ad44e
--- /dev/null
+++ b/detail_item/models.py
@@ -0,0 +1,8 @@
+from django.db import models
+
+# Create your models here.
+
+class Item(models.Model):
+    id = models.IntegerField()
+    nama = models.CharField(max_length=100)
+    deskripsi = models.TextField()
\ No newline at end of file
diff --git a/detail_item/templates/template.html b/detail_item/templates/template.html
new file mode 100644
index 00000000..a2507bef
--- /dev/null
+++ b/detail_item/templates/template.html
@@ -0,0 +1,3 @@
+<div>
+{{item}}
+</div>
\ No newline at end of file
diff --git a/detail_item/tests.py b/detail_item/tests.py
new file mode 100644
index 00000000..7ce503c2
--- /dev/null
+++ b/detail_item/tests.py
@@ -0,0 +1,3 @@
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/detail_item/urls.py b/detail_item/urls.py
new file mode 100644
index 00000000..dbb9a996
--- /dev/null
+++ b/detail_item/urls.py
@@ -0,0 +1,8 @@
+from django.urls import path
+from detail_item.views import *
+
+app_name = 'purchase_requisiton'
+
+urlpatterns = [
+    path('', show_detail, name='show_detail'),
+]
\ No newline at end of file
diff --git a/detail_item/views.py b/detail_item/views.py
new file mode 100644
index 00000000..d76dfc8a
--- /dev/null
+++ b/detail_item/views.py
@@ -0,0 +1,10 @@
+from django.shortcuts import render
+from detail_item.models import Item
+
+# Create your views here.
+def show_detail(request, id):
+    item = Item.objects.get(id=id)
+    context = {
+        'item': item
+    }
+    return render(request, "template.html", context)
\ No newline at end of file
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER b/env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER
deleted file mode 100644
index a1b589e3..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/INSTALLER
+++ /dev/null
@@ -1 +0,0 @@
-pip
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt b/env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt
deleted file mode 100644
index 00addc27..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/LICENSE.txt
+++ /dev/null
@@ -1,20 +0,0 @@
-Copyright (c) 2008-2021 The pip developers (see AUTHORS.txt file)
-
-Permission is hereby granted, free of charge, to any person obtaining
-a copy of this software and associated documentation files (the
-"Software"), to deal in the Software without restriction, including
-without limitation the rights to use, copy, modify, merge, publish,
-distribute, sublicense, and/or sell copies of the Software, and to
-permit persons to whom the Software is furnished to do so, subject to
-the following conditions:
-
-The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
-LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
-OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
-WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/METADATA b/env/Lib/site-packages/pip-21.1.3.dist-info/METADATA
deleted file mode 100644
index 7625ce6d..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/METADATA
+++ /dev/null
@@ -1,91 +0,0 @@
-Metadata-Version: 2.1
-Name: pip
-Version: 21.1.3
-Summary: The PyPA recommended tool for installing Python packages.
-Home-page: https://pip.pypa.io/
-Author: The pip developers
-Author-email: distutils-sig@python.org
-License: MIT
-Project-URL: Documentation, https://pip.pypa.io
-Project-URL: Source, https://github.com/pypa/pip
-Project-URL: Changelog, https://pip.pypa.io/en/stable/news/
-Platform: UNKNOWN
-Classifier: Development Status :: 5 - Production/Stable
-Classifier: Intended Audience :: Developers
-Classifier: License :: OSI Approved :: MIT License
-Classifier: Topic :: Software Development :: Build Tools
-Classifier: Programming Language :: Python
-Classifier: Programming Language :: Python :: 3
-Classifier: Programming Language :: Python :: 3 :: Only
-Classifier: Programming Language :: Python :: 3.6
-Classifier: Programming Language :: Python :: 3.7
-Classifier: Programming Language :: Python :: 3.8
-Classifier: Programming Language :: Python :: 3.9
-Classifier: Programming Language :: Python :: Implementation :: CPython
-Classifier: Programming Language :: Python :: Implementation :: PyPy
-Requires-Python: >=3.6
-
-pip - The Python Package Installer
-==================================
-
-.. image:: https://img.shields.io/pypi/v/pip.svg
-   :target: https://pypi.org/project/pip/
-
-.. image:: https://readthedocs.org/projects/pip/badge/?version=latest
-   :target: https://pip.pypa.io/en/latest
-
-pip is the `package installer`_ for Python. You can use pip to install packages from the `Python Package Index`_ and other indexes.
-
-Please take a look at our documentation for how to install and use pip:
-
-* `Installation`_
-* `Usage`_
-
-We release updates regularly, with a new version every 3 months. Find more details in our documentation:
-
-* `Release notes`_
-* `Release process`_
-
-In pip 20.3, we've `made a big improvement to the heart of pip`_; `learn more`_. We want your input, so `sign up for our user experience research studies`_ to help us do it right.
-
-**Note**: pip 21.0, in January 2021, removed Python 2 support, per pip's `Python 2 support policy`_. Please migrate to Python 3.
-
-If you find bugs, need help, or want to talk to the developers, please use our mailing lists or chat rooms:
-
-* `Issue tracking`_
-* `Discourse channel`_
-* `User IRC`_
-
-If you want to get involved head over to GitHub to get the source code, look at our development documentation and feel free to jump on the developer mailing lists and chat rooms:
-
-* `GitHub page`_
-* `Development documentation`_
-* `Development mailing list`_
-* `Development IRC`_
-
-Code of Conduct
----------------
-
-Everyone interacting in the pip project's codebases, issue trackers, chat
-rooms, and mailing lists is expected to follow the `PSF Code of Conduct`_.
-
-.. _package installer: https://packaging.python.org/guides/tool-recommendations/
-.. _Python Package Index: https://pypi.org
-.. _Installation: https://pip.pypa.io/en/stable/installing.html
-.. _Usage: https://pip.pypa.io/en/stable/
-.. _Release notes: https://pip.pypa.io/en/stable/news.html
-.. _Release process: https://pip.pypa.io/en/latest/development/release-process/
-.. _GitHub page: https://github.com/pypa/pip
-.. _Development documentation: https://pip.pypa.io/en/latest/development
-.. _made a big improvement to the heart of pip: https://pyfound.blogspot.com/2020/11/pip-20-3-new-resolver.html
-.. _learn more: https://pip.pypa.io/en/latest/user_guide/#changes-to-the-pip-dependency-resolver-in-20-3-2020
-.. _sign up for our user experience research studies: https://pyfound.blogspot.com/2020/03/new-pip-resolver-to-roll-out-this-year.html
-.. _Python 2 support policy: https://pip.pypa.io/en/latest/development/release-process/#python-2-support
-.. _Issue tracking: https://github.com/pypa/pip/issues
-.. _Discourse channel: https://discuss.python.org/c/packaging
-.. _Development mailing list: https://mail.python.org/mailman3/lists/distutils-sig.python.org/
-.. _User IRC: https://webchat.freenode.net/?channels=%23pypa
-.. _Development IRC: https://webchat.freenode.net/?channels=%23pypa-dev
-.. _PSF Code of Conduct: https://github.com/pypa/.github/blob/main/CODE_OF_CONDUCT.md
-
-
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/RECORD b/env/Lib/site-packages/pip-21.1.3.dist-info/RECORD
deleted file mode 100644
index 128282ab..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/RECORD
+++ /dev/null
@@ -1,797 +0,0 @@
-../../Scripts/pip.exe,sha256=ky1cKir6Y6HIL0MVYE3P_6WjqlxF2IKqrUiHiJfGARY,106410
-../../Scripts/pip3.9.exe,sha256=ky1cKir6Y6HIL0MVYE3P_6WjqlxF2IKqrUiHiJfGARY,106410
-../../Scripts/pip3.exe,sha256=ky1cKir6Y6HIL0MVYE3P_6WjqlxF2IKqrUiHiJfGARY,106410
-pip-21.1.3.dist-info/INSTALLER,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
-pip-21.1.3.dist-info/LICENSE.txt,sha256=I6c2HCsVgQKLxiO52ivSSZeryqR4Gs5q1ESjeUT42uE,1090
-pip-21.1.3.dist-info/METADATA,sha256=S9OQK4VANzrp6XjVrdlA7h3FxOxK5ArkXGOMK0q8_zM,4103
-pip-21.1.3.dist-info/RECORD,,
-pip-21.1.3.dist-info/REQUESTED,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip-21.1.3.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92
-pip-21.1.3.dist-info/entry_points.txt,sha256=HtfDOwpUlr9s73jqLQ6wF9V0_0qvUXJwCBz7Vwx0Ue0,125
-pip-21.1.3.dist-info/top_level.txt,sha256=zuuue4knoyJ-UwPPXg8fezS7VCrXJQrAP7zeNuwvFQg,4
-pip/__init__.py,sha256=mLA-Prha-ozWaC8iu58VAOzOYpTR4NklaU7Jz1OeRGA,368
-pip/__main__.py,sha256=mXwWDftNLMKfwVqKFWGE_uuBZvGSIiUELhLkeysIuZc,1198
-pip/__pycache__/__init__.cpython-39.pyc,,
-pip/__pycache__/__main__.cpython-39.pyc,,
-pip/_internal/__init__.py,sha256=XvJ1JIumQnfLNFxVRdf_xrbhkTg1WMUrf2GzrH27F3A,410
-pip/_internal/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/__pycache__/build_env.cpython-39.pyc,,
-pip/_internal/__pycache__/cache.cpython-39.pyc,,
-pip/_internal/__pycache__/configuration.cpython-39.pyc,,
-pip/_internal/__pycache__/exceptions.cpython-39.pyc,,
-pip/_internal/__pycache__/main.cpython-39.pyc,,
-pip/_internal/__pycache__/pyproject.cpython-39.pyc,,
-pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc,,
-pip/_internal/__pycache__/wheel_builder.cpython-39.pyc,,
-pip/_internal/build_env.py,sha256=2hFtbEoO4vA0FxehN_e2oXZ_3E3tAvKpnVmc8sOYjv0,9746
-pip/_internal/cache.py,sha256=6VONtoReGZbBd7sqY1n6hwkdWC4iz3tmXwXwZjpjZKw,9958
-pip/_internal/cli/__init__.py,sha256=FkHBgpxxb-_gd6r1FjnNhfMOzAUYyXoXKJ6abijfcFU,132
-pip/_internal/cli/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/base_command.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/command_context.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/main.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/parser.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/req_command.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/spinners.cpython-39.pyc,,
-pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc,,
-pip/_internal/cli/autocompletion.py,sha256=r2GQSaHHim1LwPhMaO9MPeKdsSv5H8S9ElVsmByQNew,6350
-pip/_internal/cli/base_command.py,sha256=26MHnlzZSC-Wk2j2OGsBDs5cl2ladrovJyVy1_2g0Zk,7741
-pip/_internal/cli/cmdoptions.py,sha256=52JIyP5C6yT8DpT1O2ZseAY-vMvLTb8FqO0g85OFYMs,28999
-pip/_internal/cli/command_context.py,sha256=k2JF5WPsP1MNKaXWK8jZFbJhYffzkdvGaPsL53tZbDU,815
-pip/_internal/cli/main.py,sha256=G_OsY66FZRtmLrMJ4k3m77tmtsRRRQd3_-qle1lvmng,2483
-pip/_internal/cli/main_parser.py,sha256=G70Z1fXLYzeJuuotgwKwq-daCJ0jCmmHxx6aFHz6WAQ,2642
-pip/_internal/cli/parser.py,sha256=rx4w6IgD0Obi7t1k9mV0zlYhy_DuCoaDCqhkUKMOFNU,11097
-pip/_internal/cli/progress_bars.py,sha256=ck_ILji6aRTG0zxXajnPWIpQTGxTzm3nscZOxwNmTWo,8576
-pip/_internal/cli/req_command.py,sha256=jf1fe9MVmFaZJCloIvlL5UgeJtsvlVUQObjQLLT7-HQ,16965
-pip/_internal/cli/spinners.py,sha256=VLdSWCvyk3KokujLyBf_QKYcGbrePQoPB4v7jqG7xyA,5347
-pip/_internal/cli/status_codes.py,sha256=sEFHUaUJbqv8iArL3HAtcztWZmGOFX01hTesSytDEh0,116
-pip/_internal/commands/__init__.py,sha256=v-xml8oMwrQhCpmApkpcMOE97Mp8QaBxoRObnGS43_8,3659
-pip/_internal/commands/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/cache.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/check.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/completion.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/configuration.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/debug.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/download.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/freeze.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/hash.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/help.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/install.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/list.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/search.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/show.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc,,
-pip/_internal/commands/__pycache__/wheel.cpython-39.pyc,,
-pip/_internal/commands/cache.py,sha256=AELf98RWR_giU9wl0RSXf-MsTyO5G_iwO0iHoF4Fbmc,7414
-pip/_internal/commands/check.py,sha256=Dt0w7NqFp8o_45J7w32GQrKezsz2vwo_U8UmsHD9YNI,1587
-pip/_internal/commands/completion.py,sha256=UxS09s8rEnU08AAiN3gHdQIjU4XGSlv5SJ3rIJdTyhA,2951
-pip/_internal/commands/configuration.py,sha256=X1fdVdEg8MHFtArU-3bM6WBNax1E7Z7qszPEdlK1zqo,9206
-pip/_internal/commands/debug.py,sha256=yntOplw93VZoQAVBB3BXPKuqbam4mT6TErastFwFy3s,6806
-pip/_internal/commands/download.py,sha256=zv8S_DN2-k6K0VSR3yCPLSrLehoYkj3IvyO1Ho8t8V4,4993
-pip/_internal/commands/freeze.py,sha256=vPVguwBb15ubv8Es9oPSyWePBe2cq39QxjU4KizeTwk,3431
-pip/_internal/commands/hash.py,sha256=ip64AsJ6EFUEaWKDvsZmdQHks1JTEgrDjH5byl-IYyc,1713
-pip/_internal/commands/help.py,sha256=6Mnzrak_j-yE3psDCqi2GxISJqIZJ04DObKU9QhnxME,1149
-pip/_internal/commands/install.py,sha256=aFvZQfPrMrHDb6jjbmrVlyvDxMIeX3ZcZKSQvY6c0KI,27135
-pip/_internal/commands/list.py,sha256=jfqDS4xvm6WV8rHVSmvpaI811ukvD4OiPZwGGKMwwkI,11331
-pip/_internal/commands/search.py,sha256=EwcGPkDDTwFMpi2PBKhPuWX2YBMPcy7Ox1WFcWnouaw,5598
-pip/_internal/commands/show.py,sha256=sz2vbxh4l7Bj4jKlkDGTHYD6I8_duSpSUFVxUiH44xQ,6866
-pip/_internal/commands/uninstall.py,sha256=EDcx3a03l3U8tpZ2p4ffIdn45hY2YFEmq9yoeccF2ow,3216
-pip/_internal/commands/wheel.py,sha256=wKGSksuYjjhgOYa_jD6ulaKpPXaUzPiyzfRNNT4DOio,6233
-pip/_internal/configuration.py,sha256=QBLfhv-sbP-oR08NFxSYnv_mLB-SgtNOsWXAF9tDEcM,13725
-pip/_internal/distributions/__init__.py,sha256=ow1iPW_Qp-TOyOU-WghOKC8vAv1_Syk1zETZVO_vKEE,864
-pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/distributions/__pycache__/base.cpython-39.pyc,,
-pip/_internal/distributions/__pycache__/installed.cpython-39.pyc,,
-pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc,,
-pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc,,
-pip/_internal/distributions/base.py,sha256=UVndaok0jOHrLH0JqN0YzlxVEnvFQumYy37diY3ZCuE,1245
-pip/_internal/distributions/installed.py,sha256=uaTMPvY3hr_M1BCy107vJHWspKMJgrPxv30W3_zZZ0Q,667
-pip/_internal/distributions/sdist.py,sha256=co8fNR8qIhHRLBncwV92oJ7e8IOCGPgEsbEFdNPk1Yk,3900
-pip/_internal/distributions/wheel.py,sha256=n9MqNoWyMqNscfbNeeqh1bztoZUiB5x1H9h4tFfiJUw,1205
-pip/_internal/exceptions.py,sha256=2JQJSS68oggR_ZIOA-h1U2DRADURbkQn9Nf4EZWZ834,13170
-pip/_internal/index/__init__.py,sha256=vpt-JeTZefh8a-FC22ZeBSXFVbuBcXSGiILhQZJaNpQ,30
-pip/_internal/index/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/index/__pycache__/collector.cpython-39.pyc,,
-pip/_internal/index/__pycache__/package_finder.cpython-39.pyc,,
-pip/_internal/index/__pycache__/sources.cpython-39.pyc,,
-pip/_internal/index/collector.py,sha256=aEXtHK0La4nGP7mu5N5CQ3tmfjaczLwbGi8Ar4oGz5o,18192
-pip/_internal/index/package_finder.py,sha256=3J9Rzq1NAO2p_zDb4fv33GeBBBOYusV9kXtAn2j6eCU,37294
-pip/_internal/index/sources.py,sha256=SVyPitv08-Qalh2_Bk5diAJ9GAA_d-a93koouQodAG0,6557
-pip/_internal/locations/__init__.py,sha256=9EXRxCpyiMClU87-P5E66tcFxybcA_KzLrzcK2Vt7zs,4826
-pip/_internal/locations/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc,,
-pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc,,
-pip/_internal/locations/__pycache__/base.cpython-39.pyc,,
-pip/_internal/locations/_distutils.py,sha256=L5flRSr9BH0lBwPUl61cyBc1OnVD06FOENkDMRjyg38,5212
-pip/_internal/locations/_sysconfig.py,sha256=Tt8gkN7shxbqoUlzqM19myiBRzbft9CzkmcSS4YHk1s,5959
-pip/_internal/locations/base.py,sha256=QbkpgmzIbWBnUL2_3qu29sqCNewoqYbkVw8KmigRe2c,1478
-pip/_internal/main.py,sha256=BZ0vkdqgpoteTo1A1Q8ovFe8EzgKFJWOUjPmIUQfGCY,351
-pip/_internal/metadata/__init__.py,sha256=KINR8ZYO_ilc2pkV3t5KcQLzWLNc3GjZDklGWTVJ-zU,1471
-pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/metadata/__pycache__/base.cpython-39.pyc,,
-pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc,,
-pip/_internal/metadata/base.py,sha256=6BiB_b3lvNHYIVKbzrDhi0bJmSls5Q1K-iBeHWlKnIw,4750
-pip/_internal/metadata/pkg_resources.py,sha256=4FVPxYFABQ_1tbh_CRBzK4x0_SIgH1uCKx2ZLyhkouQ,4248
-pip/_internal/models/__init__.py,sha256=3DHUd_qxpPozfzouoqa9g9ts1Czr5qaHfFxbnxriepM,63
-pip/_internal/models/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/models/__pycache__/candidate.cpython-39.pyc,,
-pip/_internal/models/__pycache__/direct_url.cpython-39.pyc,,
-pip/_internal/models/__pycache__/format_control.cpython-39.pyc,,
-pip/_internal/models/__pycache__/index.cpython-39.pyc,,
-pip/_internal/models/__pycache__/link.cpython-39.pyc,,
-pip/_internal/models/__pycache__/scheme.cpython-39.pyc,,
-pip/_internal/models/__pycache__/search_scope.cpython-39.pyc,,
-pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc,,
-pip/_internal/models/__pycache__/target_python.cpython-39.pyc,,
-pip/_internal/models/__pycache__/wheel.cpython-39.pyc,,
-pip/_internal/models/candidate.py,sha256=LlyGF2SMGjeet9bLbEAzAWDP82Wcp3342Ysa7tCW_9M,1001
-pip/_internal/models/direct_url.py,sha256=VrnJNOqcPznfNarjQJavsx2tgG7GfcLa6PyZCuf_L7A,6555
-pip/_internal/models/format_control.py,sha256=l2jp47mWsJp7-LxMs05l9T-qFg9Z5PwdyP9R7Xc_VZQ,2629
-pip/_internal/models/index.py,sha256=asMraZVPI0snye404GztEpXgKerj1yAFmZl2p3eN4Bg,1092
-pip/_internal/models/link.py,sha256=5wdHbGDLbafSdYpo2Ky7F9RRo226zRy6ik3cLH_8Kwc,7472
-pip/_internal/models/scheme.py,sha256=iqceC7gKiTn2ZLgCOgGQbcmo49TRg9EnQUSsQH3U-7A,770
-pip/_internal/models/search_scope.py,sha256=4uGNEqYrz4ku6_WzowqivuMvN0fj5XQ03WB14YjcN5U,4613
-pip/_internal/models/selection_prefs.py,sha256=aNRDL97Gz3yWJW3og0yuvOkU02UL8OeNQDuDatZ8SDo,1947
-pip/_internal/models/target_python.py,sha256=SLGG3z9Pj_CiA5jmMnNDv2MN3ST3keVuanVDzTvO5pM,3962
-pip/_internal/models/wheel.py,sha256=MWjxQkBNXI6XOWiTuzMG7uONhFu8xA94OqD_9BuIsVc,3614
-pip/_internal/network/__init__.py,sha256=jf6Tt5nV_7zkARBrKojIXItgejvoegVJVKUbhAa5Ioc,50
-pip/_internal/network/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/network/__pycache__/auth.cpython-39.pyc,,
-pip/_internal/network/__pycache__/cache.cpython-39.pyc,,
-pip/_internal/network/__pycache__/download.cpython-39.pyc,,
-pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc,,
-pip/_internal/network/__pycache__/session.cpython-39.pyc,,
-pip/_internal/network/__pycache__/utils.cpython-39.pyc,,
-pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc,,
-pip/_internal/network/auth.py,sha256=d8Df0fy01P1jJlF3XDMM8ACyktR1cN9zURG-ye1ncc0,11833
-pip/_internal/network/cache.py,sha256=J_xpsLWbRrlCSUcQhA5-TuT5LWIlpVtTH4fZ1XSjyb4,2213
-pip/_internal/network/download.py,sha256=8frb2bINOf-jbmFPapKbyEO9sjXJWJG6OJaW4hQ9r3s,6243
-pip/_internal/network/lazy_wheel.py,sha256=XMfrDK1IBy44L3Gx3UZ2B8s90VRXDa96520IOPmzmOU,7924
-pip/_internal/network/session.py,sha256=VHeiorPflYPNWK2pM_q22c-H5gmRBDh9UKCJW3VAUFI,16247
-pip/_internal/network/utils.py,sha256=uqT6QkO9NHUwqTw3gHBWMQFdaYqYabB423QUZuiQD3c,4072
-pip/_internal/network/xmlrpc.py,sha256=CL1WBOTgxPwbcZ6QubZ4pXQXjb7qTTFpTUFe-ZaWkcA,1703
-pip/_internal/operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_internal/operations/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/operations/__pycache__/check.cpython-39.pyc,,
-pip/_internal/operations/__pycache__/freeze.cpython-39.pyc,,
-pip/_internal/operations/__pycache__/prepare.cpython-39.pyc,,
-pip/_internal/operations/build/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc,,
-pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc,,
-pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc,,
-pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc,,
-pip/_internal/operations/build/metadata.py,sha256=jJp05Rrp0AMsQb7izDXbNGC1LtPNwOhHQj7cRM5324c,1165
-pip/_internal/operations/build/metadata_legacy.py,sha256=ECMBhLEPEQv6PUUCpPCXW-wN9QRXdY45PNXJv7BZKTU,1917
-pip/_internal/operations/build/wheel.py,sha256=WYLMxuxqN3ahJTQk2MI9hdmZKBpFyxHeNpUdO0PybxU,1106
-pip/_internal/operations/build/wheel_legacy.py,sha256=NOJhTYMYljdbizFo_WjkaKGWG1SEZ6aByrBdCrrsZB8,3227
-pip/_internal/operations/check.py,sha256=OtMZ2ff0zk8Ghpl7eIXySZ4D8pCUfzPAYNpGTxw1qWU,5245
-pip/_internal/operations/freeze.py,sha256=D-ex0Bwy6E0EVS_gHlixlEpKDpRxFZnUmTy7nf8s7ts,9999
-pip/_internal/operations/install/__init__.py,sha256=mX7hyD2GNBO2mFGokDQ30r_GXv7Y_PLdtxcUv144e-s,51
-pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc,,
-pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc,,
-pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc,,
-pip/_internal/operations/install/editable_legacy.py,sha256=bjBObfE6sz3UmGI7y4-GCgKa2WmTgnWlFFU7b-i0sQs,1396
-pip/_internal/operations/install/legacy.py,sha256=f59fQbNLO2rvl8bNQm_CuW6dgPvXXQ7y5apulWZi01E,4177
-pip/_internal/operations/install/wheel.py,sha256=1gV2G-owlA2iwcbxYAc4BOTiPRRGB8TzpuU0wuhM2VQ,29960
-pip/_internal/operations/prepare.py,sha256=AXHNg1iGceg1lyqDqbcabmAFIfQ1k1cIfgmVY5JCWoo,24850
-pip/_internal/pyproject.py,sha256=bN_dliFVxorLITxCEzT0UmPYFoSqk_vGBtM1QwiQays,7061
-pip/_internal/req/__init__.py,sha256=lRNHBv0ZAZNbSwmXU-XUdm66gsiNmuiBDi1DFYJ4hIQ,2983
-pip/_internal/req/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/req/__pycache__/constructors.cpython-39.pyc,,
-pip/_internal/req/__pycache__/req_file.cpython-39.pyc,,
-pip/_internal/req/__pycache__/req_install.cpython-39.pyc,,
-pip/_internal/req/__pycache__/req_set.cpython-39.pyc,,
-pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc,,
-pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc,,
-pip/_internal/req/constructors.py,sha256=4sinGd7srKhI94DV6XO-qRX2M6Kr907OFmsfklKrt64,16267
-pip/_internal/req/req_file.py,sha256=nPIFl2Mi9UDGhrj-K0E3_QugF7tl3UBDty1czbIF7fk,18000
-pip/_internal/req/req_install.py,sha256=JyTkSucNku1uwqkl2Do0SS-EcqA362WoVLtpbu-rPfA,32523
-pip/_internal/req/req_set.py,sha256=AutsaiV2s-2ILwtWtTA4OJW_ZLRg4GXg6wM0Y_hZb1k,7778
-pip/_internal/req/req_tracker.py,sha256=XuPweX1lbJXT2gSkCXICS5hna6byme5PeQp4Ok8-R2o,4391
-pip/_internal/req/req_uninstall.py,sha256=gACinTIcScZGw81qLaFdTj9KGXlVuCpru7XvHGjIE-E,23468
-pip/_internal/resolution/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/resolution/__pycache__/base.cpython-39.pyc,,
-pip/_internal/resolution/base.py,sha256=T4QnfShJErpPWe4iOiO7VmXuz1bxe20LLNs33AUslYM,563
-pip/_internal/resolution/legacy/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc,,
-pip/_internal/resolution/legacy/resolver.py,sha256=OF_6Yh4hrFfJ4u0HLF4ZRBlA8lBHUfAaFnhuVKIQhPM,17934
-pip/_internal/resolution/resolvelib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc,,
-pip/_internal/resolution/resolvelib/base.py,sha256=MbakyqSotBGVJpI3kApqqP2fPPZih9DgsfkpuFd-ADM,5677
-pip/_internal/resolution/resolvelib/candidates.py,sha256=dEKSuK9B5M52c1SugB43zXnnxgNWNTa7hCCwItSX61c,19976
-pip/_internal/resolution/resolvelib/factory.py,sha256=taqeDmXk0kAY9EVqSMhEJriY02MSShbZvt9VqEAgkw4,25446
-pip/_internal/resolution/resolvelib/found_candidates.py,sha256=FzxKczhel3GhViOIEfGHUfUQ6rN3U0blMMUuu-blHfU,5410
-pip/_internal/resolution/resolvelib/provider.py,sha256=HYITnjs7hcxDGANCDdL4qg2MJ1aw1jA9cMyxNP2mLrk,7673
-pip/_internal/resolution/resolvelib/reporter.py,sha256=xgaCtXLj791A_qRfV9Y1nXGeaWVq3JE0ygIA3YNRWq0,2765
-pip/_internal/resolution/resolvelib/requirements.py,sha256=fF2RH6VCanTuF-iwu8tZY8Bh0FakDBTw7tkDJyTsy9E,6047
-pip/_internal/resolution/resolvelib/resolver.py,sha256=3hlnrZklszFUwGQFF33nLkEO8kxz4vZ3_uKp_L8YvmE,12085
-pip/_internal/self_outdated_check.py,sha256=ivoUYaGuq-Ra_DvlZvPtHhgbY97NKHYuPGzrgN2G1A8,6484
-pip/_internal/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_internal/utils/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/compat.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/datetime.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/encoding.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/glibc.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/hashes.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/logging.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/misc.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/models.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/packaging.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/parallel.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/urls.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc,,
-pip/_internal/utils/__pycache__/wheel.cpython-39.pyc,,
-pip/_internal/utils/appdirs.py,sha256=HCCFaOrZOnMLzRDpKXcMiFh_2kWZ-PzFdN8peLiwkNY,1222
-pip/_internal/utils/compat.py,sha256=I58tTZ3qqGZqeGVP_mERM8N7QPu71niLpxfO3Ij2jfQ,1912
-pip/_internal/utils/compatibility_tags.py,sha256=IcQEHCZJvdfKciACmXGCKt39Yog2_Q2XQKMHojA_2pg,5589
-pip/_internal/utils/datetime.py,sha256=biZdEJEQBGq8A-N7ooposipeGzmSHdI0WX60kll_AEs,255
-pip/_internal/utils/deprecation.py,sha256=CD9gU1zmDtC3Nk2TM14FVpAa_bxCMd03Kx5t3LoFwkg,3277
-pip/_internal/utils/direct_url_helpers.py,sha256=-chZUxdJkFRG-pA2MY7_Wii5U5o18o5K4AqBsWd92-c,3935
-pip/_internal/utils/distutils_args.py,sha256=KxWTaz07A_1ukCyw_pNah-i6sBvrVtdMsnF8jguDNYQ,1262
-pip/_internal/utils/encoding.py,sha256=T0cQTkGB7-s3wivLlHcKbKqvJoM0yLdo8ot89LlGdz0,1190
-pip/_internal/utils/entrypoints.py,sha256=m4UXkLZTnPsdSisQzNFiHM1CZcMK8N1CA98g4ORex2c,1066
-pip/_internal/utils/filesystem.py,sha256=a3rnoUB_HTdEbDaAUHSNMPIHqHds4UA-mLQ5bvgOjSQ,6045
-pip/_internal/utils/filetypes.py,sha256=weviVbapHWVQ_8-K-PTQ_TnYL66kZi4SrVBTmRYZXLc,761
-pip/_internal/utils/glibc.py,sha256=GM1Y2hWkOf_tumySGFg-iNbc7oilBQQrjczb_705CF8,3170
-pip/_internal/utils/hashes.py,sha256=o1qQEkqe2AqsRm_JhLoM4hkxmVtewH0ZZpQ6EBObHuU,5167
-pip/_internal/utils/inject_securetransport.py,sha256=tGl9Bgyt2IHKtB3b0B-6r3W2yYF3Og-PBe0647S3lZs,810
-pip/_internal/utils/logging.py,sha256=Bkp3QSjur3ekkunAInsGJ6ls7KF8ANTtBgGhjY0vltg,12133
-pip/_internal/utils/misc.py,sha256=F7LDb6PQIwniYwLczhU2pSAyHZ9bnTVT1yI_OduYh3w,23315
-pip/_internal/utils/models.py,sha256=qCgYyUw2mIH1pombsJ3YQsMtONZgyJ4BGwO5MJnSC4c,1329
-pip/_internal/utils/packaging.py,sha256=I1938AB7FprcVJJd6C0vSiMuCVajmrxZF55vX5j0bMo,2900
-pip/_internal/utils/parallel.py,sha256=RZF4JddPEWVbkkPCknfvpqaLfm3Pmqd_ABoCHmV4lXs,3224
-pip/_internal/utils/pkg_resources.py,sha256=jwH5JViPe-JlXLvLC0-ASfTTCRYvm0u9CwQGcWjxStI,1106
-pip/_internal/utils/setuptools_build.py,sha256=xk9sRBjUyNTHs_TvEWebVWs1GfLPN208MzpSXr9Ok_A,5047
-pip/_internal/utils/subprocess.py,sha256=uxaP3IzPiBYhG0MbdfPK_uchZAh27uZ3wO3q5hRfEyo,10036
-pip/_internal/utils/temp_dir.py,sha256=9gs3N9GQeVXRVWjJIalSpH1uj8yQXPTzarb5n1_HMVo,7950
-pip/_internal/utils/unpacking.py,sha256=PioYYwfTCn_VeYer80onhrO9Y1ggetqOPSOroG38bRQ,9032
-pip/_internal/utils/urls.py,sha256=XzjQsHGd2YDmJhoCogspPTqh6Kl5tGENRHPcwjS0JC4,1256
-pip/_internal/utils/virtualenv.py,sha256=iRTK-sD6bWpHqXcZ0ECfdpFLWatMOHFUVCIRa0L6Gu0,3564
-pip/_internal/utils/wheel.py,sha256=DOIVZaXN7bMOAeMEqzIOZHGl4OFO-KGrEqBUB848DPo,6290
-pip/_internal/vcs/__init__.py,sha256=CjyxHCgdt19l21j0tJGiQ_6Yk8m-KWmQThmYvljd1eo,571
-pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc,,
-pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc,,
-pip/_internal/vcs/__pycache__/git.cpython-39.pyc,,
-pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc,,
-pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc,,
-pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc,,
-pip/_internal/vcs/bazaar.py,sha256=Ay_vN-87vYSEzBqXT3RVwl40vlk56j3jy_AfQbMj4uo,2962
-pip/_internal/vcs/git.py,sha256=URUz1kSqhDhqJsr9ulaFTewP8Zjwf7oVPP7skdj9SMQ,15431
-pip/_internal/vcs/mercurial.py,sha256=2X3eIyeAWQWI2TxoPT-xuVsD6fxr7YSyHw4MR9EWz4M,5043
-pip/_internal/vcs/subversion.py,sha256=lPfCu841JAMRG_jTX_TbRZrBpKdId5eQ8t7_xI7w3L0,11876
-pip/_internal/vcs/versioncontrol.py,sha256=N60TSMbTr79ADzR61BCrk8YogUQcBBnNaLgJPTfXsfc,23086
-pip/_internal/wheel_builder.py,sha256=hW63ZmABr65rOiSRBHXu1jBUdEZw5LZiw0LaQBbz0lI,11740
-pip/_vendor/__init__.py,sha256=gCrQwPBY2OZBeedvKOLdRZ3W1LIRM60fG6d4mgW_-9Y,4760
-pip/_vendor/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/__pycache__/appdirs.cpython-39.pyc,,
-pip/_vendor/__pycache__/distro.cpython-39.pyc,,
-pip/_vendor/__pycache__/pyparsing.cpython-39.pyc,,
-pip/_vendor/__pycache__/six.cpython-39.pyc,,
-pip/_vendor/appdirs.py,sha256=M6IYRJtdZgmSPCXCSMBRB0VT3P8MdFbWCDbSLrB2Ebg,25907
-pip/_vendor/cachecontrol/__init__.py,sha256=pJtAaUxOsMPnytI1A3juAJkXYDr8krdSnsg4Yg3OBEg,302
-pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc,,
-pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc,,
-pip/_vendor/cachecontrol/_cmd.py,sha256=URGE0KrA87QekCG3SGPatlSPT571dZTDjNa-ZXX3pDc,1295
-pip/_vendor/cachecontrol/adapter.py,sha256=sSwaSYd93IIfCFU4tOMgSo6b2LCt_gBSaQUj8ktJFOA,4882
-pip/_vendor/cachecontrol/cache.py,sha256=1fc4wJP8HYt1ycnJXeEw5pCpeBL2Cqxx6g9Fb0AYDWQ,805
-pip/_vendor/cachecontrol/caches/__init__.py,sha256=-gHNKYvaeD0kOk5M74eOrsSgIKUtC6i6GfbmugGweEo,86
-pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc,,
-pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc,,
-pip/_vendor/cachecontrol/caches/file_cache.py,sha256=nYVKsJtXh6gJXvdn1iWyrhxvkwpQrK-eKoMRzuiwkKk,4153
-pip/_vendor/cachecontrol/caches/redis_cache.py,sha256=HxelMpNCo-dYr2fiJDwM3hhhRmxUYtB5tXm1GpAAT4Y,856
-pip/_vendor/cachecontrol/compat.py,sha256=kHNvMRdt6s_Xwqq_9qJmr9ou3wYMOMUMxPPcwNxT8Mc,695
-pip/_vendor/cachecontrol/controller.py,sha256=CWEX3pedIM9s60suf4zZPtm_JvVgnvogMGK_OiBG5F8,14149
-pip/_vendor/cachecontrol/filewrapper.py,sha256=vACKO8Llzu_ZWyjV1Fxn1MA4TGU60N5N3GSrAFdAY2Q,2533
-pip/_vendor/cachecontrol/heuristics.py,sha256=BFGHJ3yQcxvZizfo90LLZ04T_Z5XSCXvFotrp7Us0sc,4070
-pip/_vendor/cachecontrol/serialize.py,sha256=vIa4jvq4x_KSOLdEIedoknX2aXYHQujLDFV4-F21Dno,7091
-pip/_vendor/cachecontrol/wrapper.py,sha256=5LX0uJwkNQUtYSEw3aGmGu9WY8wGipd81mJ8lG0d0M4,690
-pip/_vendor/certifi/__init__.py,sha256=SsmdmFHjHCY4VLtqwpp9P_jsOcAuHj-5c5WqoEz-oFg,62
-pip/_vendor/certifi/__main__.py,sha256=1k3Cr95vCxxGRGDljrW3wMdpZdL3Nhf0u1n-k2qdsCY,255
-pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc,,
-pip/_vendor/certifi/__pycache__/core.cpython-39.pyc,,
-pip/_vendor/certifi/cacert.pem,sha256=u3fxPT--yemLvyislQRrRBlsfY9Vq3cgBh6ZmRqCkZc,263774
-pip/_vendor/certifi/core.py,sha256=gOFd0zHYlx4krrLEn982esOtmz3djiG0BFSDhgjlvcI,2840
-pip/_vendor/chardet/__init__.py,sha256=mWZaWmvZkhwfBEAT9O1Y6nRTfKzhT7FHhQTTAujbqUA,3271
-pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc,,
-pip/_vendor/chardet/__pycache__/version.cpython-39.pyc,,
-pip/_vendor/chardet/big5freq.py,sha256=D_zK5GyzoVsRes0HkLJziltFQX0bKCLOrFe9_xDvO_8,31254
-pip/_vendor/chardet/big5prober.py,sha256=kBxHbdetBpPe7xrlb-e990iot64g_eGSLd32lB7_h3M,1757
-pip/_vendor/chardet/chardistribution.py,sha256=3woWS62KrGooKyqz4zQSnjFbJpa6V7g02daAibTwcl8,9411
-pip/_vendor/chardet/charsetgroupprober.py,sha256=GZLReHP6FRRn43hvSOoGCxYamErKzyp6RgOQxVeC3kg,3839
-pip/_vendor/chardet/charsetprober.py,sha256=KSmwJErjypyj0bRZmC5F5eM7c8YQgLYIjZXintZNstg,5110
-pip/_vendor/chardet/cli/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
-pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc,,
-pip/_vendor/chardet/cli/chardetect.py,sha256=XK5zqjUG2a4-y6eLHZ8ThYcp6WWUrdlmELxNypcc2SE,2747
-pip/_vendor/chardet/codingstatemachine.py,sha256=VYp_6cyyki5sHgXDSZnXW4q1oelHc3cu9AyQTX7uug8,3590
-pip/_vendor/chardet/compat.py,sha256=40zr6wICZwknxyuLGGcIOPyve8DTebBCbbvttvnmp5Q,1200
-pip/_vendor/chardet/cp949prober.py,sha256=TZ434QX8zzBsnUvL_8wm4AQVTZ2ZkqEEQL_lNw9f9ow,1855
-pip/_vendor/chardet/enums.py,sha256=Aimwdb9as1dJKZaFNUH2OhWIVBVd6ZkJJ_WK5sNY8cU,1661
-pip/_vendor/chardet/escprober.py,sha256=kkyqVg1Yw3DIOAMJ2bdlyQgUFQhuHAW8dUGskToNWSc,3950
-pip/_vendor/chardet/escsm.py,sha256=RuXlgNvTIDarndvllNCk5WZBIpdCxQ0kcd9EAuxUh84,10510
-pip/_vendor/chardet/eucjpprober.py,sha256=iD8Jdp0ISRjgjiVN7f0e8xGeQJ5GM2oeZ1dA8nbSeUw,3749
-pip/_vendor/chardet/euckrfreq.py,sha256=-7GdmvgWez4-eO4SuXpa7tBiDi5vRXQ8WvdFAzVaSfo,13546
-pip/_vendor/chardet/euckrprober.py,sha256=MqFMTQXxW4HbzIpZ9lKDHB3GN8SP4yiHenTmf8g_PxY,1748
-pip/_vendor/chardet/euctwfreq.py,sha256=No1WyduFOgB5VITUA7PLyC5oJRNzRyMbBxaKI1l16MA,31621
-pip/_vendor/chardet/euctwprober.py,sha256=13p6EP4yRaxqnP4iHtxHOJ6R2zxHq1_m8hTRjzVZ95c,1747
-pip/_vendor/chardet/gb2312freq.py,sha256=JX8lsweKLmnCwmk8UHEQsLgkr_rP_kEbvivC4qPOrlc,20715
-pip/_vendor/chardet/gb2312prober.py,sha256=gGvIWi9WhDjE-xQXHvNIyrnLvEbMAYgyUSZ65HUfylw,1754
-pip/_vendor/chardet/hebrewprober.py,sha256=c3SZ-K7hvyzGY6JRAZxJgwJ_sUS9k0WYkvMY00YBYFo,13838
-pip/_vendor/chardet/jisfreq.py,sha256=vpmJv2Bu0J8gnMVRPHMFefTRvo_ha1mryLig8CBwgOg,25777
-pip/_vendor/chardet/jpcntx.py,sha256=PYlNqRUQT8LM3cT5FmHGP0iiscFlTWED92MALvBungo,19643
-pip/_vendor/chardet/langbulgarianmodel.py,sha256=rk9CJpuxO0bObboJcv6gNgWuosYZmd8qEEds5y7DS_Y,105697
-pip/_vendor/chardet/langgreekmodel.py,sha256=S-uNQ1ihC75yhBvSux24gLFZv3QyctMwC6OxLJdX-bw,99571
-pip/_vendor/chardet/langhebrewmodel.py,sha256=DzPP6TPGG_-PV7tqspu_d8duueqm7uN-5eQ0aHUw1Gg,98776
-pip/_vendor/chardet/langhungarianmodel.py,sha256=RtJH7DZdsmaHqyK46Kkmnk5wQHiJwJPPJSqqIlpeZRc,102498
-pip/_vendor/chardet/langrussianmodel.py,sha256=THqJOhSxiTQcHboDNSc5yofc2koXXQFHFyjtyuntUfM,131180
-pip/_vendor/chardet/langthaimodel.py,sha256=R1wXHnUMtejpw0JnH_JO8XdYasME6wjVqp1zP7TKLgg,103312
-pip/_vendor/chardet/langturkishmodel.py,sha256=rfwanTptTwSycE4-P-QasPmzd-XVYgevytzjlEzBBu8,95946
-pip/_vendor/chardet/latin1prober.py,sha256=S2IoORhFk39FEFOlSFWtgVybRiP6h7BlLldHVclNkU8,5370
-pip/_vendor/chardet/mbcharsetprober.py,sha256=AR95eFH9vuqSfvLQZN-L5ijea25NOBCoXqw8s5O9xLQ,3413
-pip/_vendor/chardet/mbcsgroupprober.py,sha256=h6TRnnYq2OxG1WdD5JOyxcdVpn7dG0q-vB8nWr5mbh4,2012
-pip/_vendor/chardet/mbcssm.py,sha256=SY32wVIF3HzcjY3BaEspy9metbNSKxIIB0RKPn7tjpI,25481
-pip/_vendor/chardet/metadata/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc,,
-pip/_vendor/chardet/metadata/languages.py,sha256=41tLq3eLSrBEbEVVQpVGFq9K7o1ln9b1HpY1l0hCUQo,19474
-pip/_vendor/chardet/sbcharsetprober.py,sha256=nmyMyuxzG87DN6K3Rk2MUzJLMLR69MrWpdnHzOwVUwQ,6136
-pip/_vendor/chardet/sbcsgroupprober.py,sha256=hqefQuXmiFyDBArOjujH6hd6WFXlOD1kWCsxDhjx5Vc,4309
-pip/_vendor/chardet/sjisprober.py,sha256=IIt-lZj0WJqK4rmUZzKZP4GJlE8KUEtFYVuY96ek5MQ,3774
-pip/_vendor/chardet/universaldetector.py,sha256=DpZTXCX0nUHXxkQ9sr4GZxGB_hveZ6hWt3uM94cgWKs,12503
-pip/_vendor/chardet/utf8prober.py,sha256=IdD8v3zWOsB8OLiyPi-y_fqwipRFxV9Nc1eKBLSuIEw,2766
-pip/_vendor/chardet/version.py,sha256=A4CILFAd8MRVG1HoXPp45iK9RLlWyV73a1EtwE8Tvn8,242
-pip/_vendor/colorama/__init__.py,sha256=pCdErryzLSzDW5P-rRPBlPLqbBtIRNJB6cMgoeJns5k,239
-pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc,,
-pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc,,
-pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc,,
-pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc,,
-pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc,,
-pip/_vendor/colorama/ansi.py,sha256=Top4EeEuaQdBWdteKMEcGOTeKeF19Q-Wo_6_Cj5kOzQ,2522
-pip/_vendor/colorama/ansitowin32.py,sha256=yV7CEmCb19MjnJKODZEEvMH_fnbJhwnpzo4sxZuGXmA,10517
-pip/_vendor/colorama/initialise.py,sha256=PprovDNxMTrvoNHFcL2NZjpH2XzDc8BLxLxiErfUl4k,1915
-pip/_vendor/colorama/win32.py,sha256=bJ8Il9jwaBN5BJ8bmN6FoYZ1QYuMKv2j8fGrXh7TJjw,5404
-pip/_vendor/colorama/winterm.py,sha256=2y_2b7Zsv34feAsP67mLOVc-Bgq51mdYGo571VprlrM,6438
-pip/_vendor/distlib/__init__.py,sha256=3veAk2rPznOB2gsK6tjbbh0TQMmGE5P82eE9wXq6NIk,581
-pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/database.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/index.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/util.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/version.cpython-39.pyc,,
-pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc,,
-pip/_vendor/distlib/_backport/__init__.py,sha256=bqS_dTOH6uW9iGgd0uzfpPjo6vZ4xpPZ7kyfZJ2vNaw,274
-pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc,,
-pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc,,
-pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc,,
-pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc,,
-pip/_vendor/distlib/_backport/misc.py,sha256=KWecINdbFNOxSOP1fGF680CJnaC6S4fBRgEtaYTw0ig,971
-pip/_vendor/distlib/_backport/shutil.py,sha256=IX_G2NPqwecJibkIDje04bqu0xpHkfSQ2GaGdEVqM5Y,25707
-pip/_vendor/distlib/_backport/sysconfig.cfg,sha256=swZKxq9RY5e9r3PXCrlvQPMsvOdiWZBTHLEbqS8LJLU,2617
-pip/_vendor/distlib/_backport/sysconfig.py,sha256=BQHFlb6pubCl_dvT1NjtzIthylofjKisox239stDg0U,26854
-pip/_vendor/distlib/_backport/tarfile.py,sha256=Ihp7rXRcjbIKw8COm9wSePV9ARGXbSF9gGXAMn2Q-KU,92628
-pip/_vendor/distlib/compat.py,sha256=ADA56xiAxar3mU6qemlBhNbsrFPosXRhO44RzsbJPqk,41408
-pip/_vendor/distlib/database.py,sha256=Kl0YvPQKc4OcpVi7k5cFziydM1xOK8iqdxLGXgbZHV4,51059
-pip/_vendor/distlib/index.py,sha256=SXKzpQCERctxYDMp_OLee2f0J0e19ZhGdCIoMlUfUQM,21066
-pip/_vendor/distlib/locators.py,sha256=c9E4cDEacJ_uKbuE5BqAVocoWp6rsuBGTkiNDQq3zV4,52100
-pip/_vendor/distlib/manifest.py,sha256=nQEhYmgoreaBZzyFzwYsXxJARu3fo4EkunU163U16iE,14811
-pip/_vendor/distlib/markers.py,sha256=6Ac3cCfFBERexiESWIOXmg-apIP8l2esafNSX3KMy-8,4387
-pip/_vendor/distlib/metadata.py,sha256=z2KPy3h3tcDnb9Xs7nAqQ5Oz0bqjWAUFmKWcFKRoodg,38962
-pip/_vendor/distlib/resources.py,sha256=2FGv0ZHF14KXjLIlL0R991lyQQGcewOS4mJ-5n-JVnc,10766
-pip/_vendor/distlib/scripts.py,sha256=_MAj3sMuv56kuM8FsiIWXqbT0gmumPGaOR_atOzn4a4,17180
-pip/_vendor/distlib/t32.exe,sha256=NS3xBCVAld35JVFNmb-1QRyVtThukMrwZVeXn4LhaEQ,96768
-pip/_vendor/distlib/t64.exe,sha256=oAqHes78rUWVM0OtVqIhUvequl_PKhAhXYQWnUf7zR0,105984
-pip/_vendor/distlib/util.py,sha256=f2jZCPrcLCt6LcnC0gUy-Fur60tXD8reA7k4rDpHMDw,59845
-pip/_vendor/distlib/version.py,sha256=_n7F6juvQGAcn769E_SHa7fOcf5ERlEVymJ_EjPRwGw,23391
-pip/_vendor/distlib/w32.exe,sha256=lJtnZdeUxTZWya_EW5DZos_K5rswRECGspIl8ZJCIXs,90112
-pip/_vendor/distlib/w64.exe,sha256=0aRzoN2BO9NWW4ENy4_4vHkHR4qZTFZNVSAJJYlODTI,99840
-pip/_vendor/distlib/wheel.py,sha256=v6DnwTqhNHwrEVFr8_YeiTW6G4ftP_evsywNgrmdb2o,41144
-pip/_vendor/distro.py,sha256=xxMIh2a3KmippeWEHzynTdHT3_jZM0o-pos0dAWJROM,43628
-pip/_vendor/html5lib/__init__.py,sha256=BYzcKCqeEii52xDrqBFruhnmtmkiuHXFyFh-cglQ8mk,1160
-pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc,,
-pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc,,
-pip/_vendor/html5lib/_ihatexml.py,sha256=ifOwF7pXqmyThIXc3boWc96s4MDezqRrRVp7FwDYUFs,16728
-pip/_vendor/html5lib/_inputstream.py,sha256=jErNASMlkgs7MpOM9Ve_VdLDJyFFweAjLuhVutZz33U,32353
-pip/_vendor/html5lib/_tokenizer.py,sha256=04mgA2sNTniutl2fxFv-ei5bns4iRaPxVXXHh_HrV_4,77040
-pip/_vendor/html5lib/_trie/__init__.py,sha256=nqfgO910329BEVJ5T4psVwQtjd2iJyEXQ2-X8c1YxwU,109
-pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc,,
-pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc,,
-pip/_vendor/html5lib/_trie/_base.py,sha256=CaybYyMro8uERQYjby2tTeSUatnWDfWroUN9N7ety5w,1013
-pip/_vendor/html5lib/_trie/py.py,sha256=wXmQLrZRf4MyWNyg0m3h81m9InhLR7GJ002mIIZh-8o,1775
-pip/_vendor/html5lib/_utils.py,sha256=Dx9AKntksRjFT1veBj7I362pf5OgIaT0zglwq43RnfU,4931
-pip/_vendor/html5lib/constants.py,sha256=Ll-yzLU_jcjyAI_h57zkqZ7aQWE5t5xA4y_jQgoUUhw,83464
-pip/_vendor/html5lib/filters/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc,,
-pip/_vendor/html5lib/filters/alphabeticalattributes.py,sha256=lViZc2JMCclXi_5gduvmdzrRxtO5Xo9ONnbHBVCsykU,919
-pip/_vendor/html5lib/filters/base.py,sha256=z-IU9ZAYjpsVsqmVt7kuWC63jR11hDMr6CVrvuao8W0,286
-pip/_vendor/html5lib/filters/inject_meta_charset.py,sha256=egDXUEHXmAG9504xz0K6ALDgYkvUrC2q15YUVeNlVQg,2945
-pip/_vendor/html5lib/filters/lint.py,sha256=jk6q56xY0ojiYfvpdP-OZSm9eTqcAdRqhCoPItemPYA,3643
-pip/_vendor/html5lib/filters/optionaltags.py,sha256=8lWT75J0aBOHmPgfmqTHSfPpPMp01T84NKu0CRedxcE,10588
-pip/_vendor/html5lib/filters/sanitizer.py,sha256=m6oGmkBhkGAnn2nV6D4hE78SCZ6WEnK9rKdZB3uXBIc,26897
-pip/_vendor/html5lib/filters/whitespace.py,sha256=8eWqZxd4UC4zlFGW6iyY6f-2uuT8pOCSALc3IZt7_t4,1214
-pip/_vendor/html5lib/html5parser.py,sha256=anr-aXre_ImfrkQ35c_rftKXxC80vJCREKe06Tq15HA,117186
-pip/_vendor/html5lib/serializer.py,sha256=_PpvcZF07cwE7xr9uKkZqh5f4UEaI8ltCU2xPJzaTpk,15759
-pip/_vendor/html5lib/treeadapters/__init__.py,sha256=A0rY5gXIe4bJOiSGRO_j_tFhngRBO8QZPzPtPw5dFzo,679
-pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc,,
-pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc,,
-pip/_vendor/html5lib/treeadapters/genshi.py,sha256=CH27pAsDKmu4ZGkAUrwty7u0KauGLCZRLPMzaO3M5vo,1715
-pip/_vendor/html5lib/treeadapters/sax.py,sha256=BKS8woQTnKiqeffHsxChUqL4q2ZR_wb5fc9MJ3zQC8s,1776
-pip/_vendor/html5lib/treebuilders/__init__.py,sha256=AysSJyvPfikCMMsTVvaxwkgDieELD5dfR8FJIAuq7hY,3592
-pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc,,
-pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc,,
-pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc,,
-pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc,,
-pip/_vendor/html5lib/treebuilders/base.py,sha256=z-o51vt9r_l2IDG5IioTOKGzZne4Fy3_Fc-7ztrOh4I,14565
-pip/_vendor/html5lib/treebuilders/dom.py,sha256=22whb0C71zXIsai5mamg6qzBEiigcBIvaDy4Asw3at0,8925
-pip/_vendor/html5lib/treebuilders/etree.py,sha256=w5ZFpKk6bAxnrwD2_BrF5EVC7vzz0L3LMi9Sxrbc_8w,12836
-pip/_vendor/html5lib/treebuilders/etree_lxml.py,sha256=9gqDjs-IxsPhBYa5cpvv2FZ1KZlG83Giusy2lFmvIkE,14766
-pip/_vendor/html5lib/treewalkers/__init__.py,sha256=OBPtc1TU5mGyy18QDMxKEyYEz0wxFUUNj5v0-XgmYhY,5719
-pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc,,
-pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc,,
-pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc,,
-pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc,,
-pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc,,
-pip/_vendor/html5lib/treewalkers/base.py,sha256=ouiOsuSzvI0KgzdWP8PlxIaSNs9falhbiinAEc_UIJY,7476
-pip/_vendor/html5lib/treewalkers/dom.py,sha256=EHyFR8D8lYNnyDU9lx_IKigVJRyecUGua0mOi7HBukc,1413
-pip/_vendor/html5lib/treewalkers/etree.py,sha256=xo1L5m9VtkfpFJK0pFmkLVajhqYYVisVZn3k9kYpPkI,4551
-pip/_vendor/html5lib/treewalkers/etree_lxml.py,sha256=_b0LAVWLcVu9WaU_-w3D8f0IRSpCbjf667V-3NRdhTw,6357
-pip/_vendor/html5lib/treewalkers/genshi.py,sha256=4D2PECZ5n3ZN3qu3jMl9yY7B81jnQApBQSVlfaIuYbA,2309
-pip/_vendor/idna/__init__.py,sha256=9Nt7xpyet3DmOrPUGooDdAwmHZZu1qUAy2EaJ93kGiQ,58
-pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/codec.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/core.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc,,
-pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc,,
-pip/_vendor/idna/codec.py,sha256=4RVMhqFquJgyGBKyl40ARqcgDzkDDXZUvyl1EOCRLFE,3027
-pip/_vendor/idna/compat.py,sha256=g-7Ph45nzILe_7xvxdbTebrHZq4mQWxIOH1rjMc6xrs,232
-pip/_vendor/idna/core.py,sha256=VdFGQyiit1eMKUQ2x0mNXoGThrXlRyp070mPDyLX9Yg,11849
-pip/_vendor/idna/idnadata.py,sha256=cl4x9RLdw1ZMtEEbvKwAsX-Id3AdIjO5U3HaoKM6VGs,42350
-pip/_vendor/idna/intranges.py,sha256=TY1lpxZIQWEP6tNqjZkFA5hgoMWOj1OBmnUG8ihT87E,1749
-pip/_vendor/idna/package_data.py,sha256=kxptFveZ37zbPSmKU7KMEA8Pi7h3-sM1-p2agm2PpCI,21
-pip/_vendor/idna/uts46data.py,sha256=4CZEB6ZQgmSNIATBn2V_xdW9PEgVOXAOYRzCeQGsK_E,196224
-pip/_vendor/msgpack/__init__.py,sha256=2gJwcsTIaAtCM0GMi2rU-_Y6kILeeQuqRkrQ22jSANc,1118
-pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc,,
-pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc,,
-pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc,,
-pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc,,
-pip/_vendor/msgpack/_version.py,sha256=dFR03oACnj4lsKd1RnwD7BPMiVI_FMygdOL1TOBEw_U,20
-pip/_vendor/msgpack/exceptions.py,sha256=dCTWei8dpkrMsQDcjQk74ATl9HsIBH0ybt8zOPNqMYc,1081
-pip/_vendor/msgpack/ext.py,sha256=4l356Y4sVEcvCla2dh_cL57vh4GMhZfa3kuWHFHYz6A,6088
-pip/_vendor/msgpack/fallback.py,sha256=Rpv1Ldey8f8ueRnQznD4ARKBn9dxM2PywVNkXI8IEeE,38026
-pip/_vendor/packaging/__about__.py,sha256=j4B7IMMSqpUnYzcYd5H5WZlILXevD7Zm_n9lj_TROTw,726
-pip/_vendor/packaging/__init__.py,sha256=6enbp5XgRfjBjsI9-bn00HjHf5TH21PDMOKkJW8xw-w,562
-pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc,,
-pip/_vendor/packaging/__pycache__/version.cpython-39.pyc,,
-pip/_vendor/packaging/_compat.py,sha256=MXdsGpSE_W-ZrHoC87andI4LV2FAwU7HLL-eHe_CjhU,1128
-pip/_vendor/packaging/_structures.py,sha256=ozkCX8Q8f2qE1Eic3YiQ4buDVfgz2iYevY9e7R2y3iY,2022
-pip/_vendor/packaging/_typing.py,sha256=VgA0AAvsc97KB5nF89zoudOyCMEsV7FlaXzZbYqEkzA,1824
-pip/_vendor/packaging/markers.py,sha256=8DOn1c7oZ_DySBlLom_9o49GzobVGYN8-kpK_nsj8oQ,9472
-pip/_vendor/packaging/requirements.py,sha256=MHqf_FKihHC0VkOB62ZUdUyG8okEL97D4Xy_jK1yFS0,5110
-pip/_vendor/packaging/specifiers.py,sha256=RaxQ-JKyCqI5QBm6gDvboZ2K6jjLVd-pxq0kvYf28kc,32208
-pip/_vendor/packaging/tags.py,sha256=BMEL_3W3E8nXK_AXAWqmlYccsvoznFKkTBkTPR48DB8,29561
-pip/_vendor/packaging/utils.py,sha256=5vUxwCVYSmaNJFgd7KaCBpxHXQN89KIvRLvCsDzao0k,4385
-pip/_vendor/packaging/version.py,sha256=t7FpsZKmDncMn6EG28dEu_5NBZUa9_HVoiG-fsDo3oc,15974
-pip/_vendor/pep517/__init__.py,sha256=mju9elFHLEUJ23rU5Zpdj8nROdY0Vj3bp4ZgvBTs6bg,130
-pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/build.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/check.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc,,
-pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc,,
-pip/_vendor/pep517/build.py,sha256=Z49CmRFafX7NjoBModiibwQYa_EYz3E0F31b7D5WVvs,3456
-pip/_vendor/pep517/check.py,sha256=8LJLtfZ99zAcV4vKJ1a-odMxg2sEImD7RMNg_Ere-1Y,6082
-pip/_vendor/pep517/colorlog.py,sha256=Tk9AuYm_cLF3BKTBoSTJt9bRryn0aFojIQOwbfVUTxQ,4098
-pip/_vendor/pep517/compat.py,sha256=M-5s4VNp8rjyT76ZZ_ibnPD44DYVzSQlyCEHayjtDPw,780
-pip/_vendor/pep517/dirtools.py,sha256=2mkAkAL0mRz_elYFjRKuekTJVipH1zTn4tbf1EDev84,1129
-pip/_vendor/pep517/envbuild.py,sha256=szKUFlO50X1ahQfXwz4hD9V2VE_bz9MLVPIeidsFo4w,6041
-pip/_vendor/pep517/in_process/__init__.py,sha256=MyWoAi8JHdcBv7yXuWpUSVADbx6LSB9rZh7kTIgdA8Y,563
-pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc,,
-pip/_vendor/pep517/in_process/_in_process.py,sha256=XrKOTURJdia5R7i3i_OQmS89LASFXE3HQXfX63qZBIE,8438
-pip/_vendor/pep517/meta.py,sha256=8mnM5lDnT4zXQpBTliJbRGfesH7iioHwozbDxALPS9Y,2463
-pip/_vendor/pep517/wrappers.py,sha256=QYZfN1nWoq4Z2krY-UX14JLAxkdNwujYjRGf7qFc914,11044
-pip/_vendor/pkg_resources/__init__.py,sha256=XpGBfvS9fafA6bm5rx7vnxdxs7yqyoc_NnpzKApkJ64,108277
-pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc,,
-pip/_vendor/pkg_resources/py31compat.py,sha256=CRk8fkiPRDLsbi5pZcKsHI__Pbmh_94L8mr9Qy9Ab2U,562
-pip/_vendor/progress/__init__.py,sha256=fcbQQXo5np2CoQyhSH5XprkicwLZNLePR3uIahznSO0,4857
-pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/progress/__pycache__/bar.cpython-39.pyc,,
-pip/_vendor/progress/__pycache__/counter.cpython-39.pyc,,
-pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc,,
-pip/_vendor/progress/bar.py,sha256=QuDuVNcmXgpxtNtxO0Fq72xKigxABaVmxYGBw4J3Z_E,2854
-pip/_vendor/progress/counter.py,sha256=MznyBrvPWrOlGe4MZAlGUb9q3aODe6_aNYeAE_VNoYA,1372
-pip/_vendor/progress/spinner.py,sha256=k8JbDW94T0-WXuXfxZIFhdoNPYp3jfnpXqBnfRv5fGs,1380
-pip/_vendor/pyparsing.py,sha256=J1b4z3S_KwyJW7hKGnoN-hXW9pgMIzIP6QThyY5yJq4,273394
-pip/_vendor/requests/__init__.py,sha256=ib7nRjDadbCMOeX2sMQLcbXzy982HoKRY2LD_gWqwPM,4458
-pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/api.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/auth.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/certs.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/help.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/models.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/packages.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/structures.cpython-39.pyc,,
-pip/_vendor/requests/__pycache__/utils.cpython-39.pyc,,
-pip/_vendor/requests/__version__.py,sha256=k4J8c1yFRFzwGWwlN7miaDOclFtbcIs1GlnmT17YbXQ,441
-pip/_vendor/requests/_internal_utils.py,sha256=Zx3PnEUccyfsB-ie11nZVAW8qClJy0gx1qNME7rgT18,1096
-pip/_vendor/requests/adapters.py,sha256=e-bmKEApNVqFdylxuMJJfiaHdlmS_zhWhIMEzlHvGuc,21548
-pip/_vendor/requests/api.py,sha256=PlHM-HT3PQ5lyufoeGmV-nJxRi7UnUyGVh7OV7B9XV4,6496
-pip/_vendor/requests/auth.py,sha256=OMoJIVKyRLy9THr91y8rxysZuclwPB-K1Xg1zBomUhQ,10207
-pip/_vendor/requests/certs.py,sha256=nXRVq9DtGmv_1AYbwjTu9UrgAcdJv05ZvkNeaoLOZxY,465
-pip/_vendor/requests/compat.py,sha256=LQWuCR4qXk6w7-qQopXyz0WNHUdAD40k0mKnaAEf1-g,2045
-pip/_vendor/requests/cookies.py,sha256=Y-bKX6TvW3FnYlE6Au0SXtVVWcaNdFvuAwQxw-G0iTI,18430
-pip/_vendor/requests/exceptions.py,sha256=d9fJJw8YFBB9VzG9qhvxLuOx6be3c_Dwbck-dVUEAcs,3173
-pip/_vendor/requests/help.py,sha256=SJPVcoXeo7KfK4AxJN5eFVQCjr0im87tU2n7ubLsksU,3578
-pip/_vendor/requests/hooks.py,sha256=QReGyy0bRcr5rkwCuObNakbYsc7EkiKeBwG4qHekr2Q,757
-pip/_vendor/requests/models.py,sha256=UkkaVuU1tc-BKYB41dds35saisoTpaYJ2YBCFZEEfhM,34373
-pip/_vendor/requests/packages.py,sha256=njJmVifY4aSctuW3PP5EFRCxjEwMRDO6J_feG2dKWsI,695
-pip/_vendor/requests/sessions.py,sha256=BsnR-zYILgoFzJ6yq4T8ht_i0PwwPGVAxWxWaV5dcHg,30137
-pip/_vendor/requests/status_codes.py,sha256=gT79Pbs_cQjBgp-fvrUgg1dn2DQO32bDj4TInjnMPSc,4188
-pip/_vendor/requests/structures.py,sha256=msAtr9mq1JxHd-JRyiILfdFlpbJwvvFuP3rfUQT_QxE,3005
-pip/_vendor/requests/utils.py,sha256=_K9AgkN6efPe-a-zgZurXzds5PBC0CzDkyjAE2oCQFQ,30529
-pip/_vendor/resolvelib/__init__.py,sha256=QWAqNErjxqEMKl-AUccXz10aCKVmO-WmWvxUl3QOlFY,537
-pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc,,
-pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc,,
-pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc,,
-pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc,,
-pip/_vendor/resolvelib/compat/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc,,
-pip/_vendor/resolvelib/compat/collections_abc.py,sha256=uy8xUZ-NDEw916tugUXm8HgwCGiMO0f-RcdnpkfXfOs,156
-pip/_vendor/resolvelib/providers.py,sha256=bfzFDZd7UqkkAS7lUM_HeYbA-HzjKfDlle_pn_79vio,5638
-pip/_vendor/resolvelib/reporters.py,sha256=hQvvXuuEBOyEWO8KDfLsWKVjX55UFMAUwO0YZMNpzAw,1364
-pip/_vendor/resolvelib/resolvers.py,sha256=P6aq-7pY5E7zROb0zUUWqFIHEA9Lm0MWsx_bYXzUg3A,17292
-pip/_vendor/resolvelib/structs.py,sha256=Z6m4CkKJlWH4ZIKelEsKNeZqKTvyux4hqBNzY4kZzLo,4495
-pip/_vendor/six.py,sha256=U4Z_yv534W5CNyjY9i8V1OXY2SjAny8y2L5vDLhhThM,34159
-pip/_vendor/tenacity/__init__.py,sha256=MVs5n8anwg_rEiX2_QItExciIdgLDwSnukiFDyjChJw,16790
-pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc,,
-pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc,,
-pip/_vendor/tenacity/_asyncio.py,sha256=6C4Sfv9IOUYf1-0vuIoE6OGbmJrJywH0-YslrxmbxKw,2833
-pip/_vendor/tenacity/_utils.py,sha256=W1nujHum1f9i4RQpOSjqsQo9_mQtaUtNznXAmQHsL28,4555
-pip/_vendor/tenacity/after.py,sha256=KNIi2WT83r4eqA3QaXMK1zXQzkbLgVHj5uRanY6HabM,1307
-pip/_vendor/tenacity/before.py,sha256=B9pAXn6_J1UKzwTL9nFtRpOhNg8s5vGSi4bqnx4-laA,1154
-pip/_vendor/tenacity/before_sleep.py,sha256=lZEMHNaFRmdCcws3Moh4EOZ9zeo4MRxskdiUudvNuvY,1784
-pip/_vendor/tenacity/compat.py,sha256=dHonJkJlHwD2cmqLrYHYU0Tdzm2bn1-76QZSt6OCemw,739
-pip/_vendor/tenacity/nap.py,sha256=7VVudOTmuv_-C_XJlvjGcgHbV6_A2HlzymaXu8vj1d8,1280
-pip/_vendor/tenacity/retry.py,sha256=xskLGa15EsNhPPOmIUcKS7CqjaRAtWxGFNPNRjjz9UU,5463
-pip/_vendor/tenacity/stop.py,sha256=4cjSe_YPSawz6iI-QBDN0xFfE_zlKvjhFwx21ZlyD2E,2435
-pip/_vendor/tenacity/tornadoweb.py,sha256=q3XZW2A9Rky1BhUQbNHF61hM1EXQ57dA7wxPnlSOx3s,1729
-pip/_vendor/tenacity/wait.py,sha256=FAoIfIUSNf5OWJYT7nhjFC0uOVijHMBd56AJRyLN230,6017
-pip/_vendor/toml/__init__.py,sha256=kYgYzehhUx1cctsuprmjEKwnSdmQeC53cTxi7nxQrko,747
-pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc,,
-pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc,,
-pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc,,
-pip/_vendor/toml/__pycache__/tz.cpython-39.pyc,,
-pip/_vendor/toml/decoder.py,sha256=deDPQqpj92SG6pAtwLbgKHrIsly7hAZG-U6g2y7hyGc,38954
-pip/_vendor/toml/encoder.py,sha256=tBe93_GB21K52TlSbMiYuGeIGXH70F2WzAg-lIfVoko,9964
-pip/_vendor/toml/ordered.py,sha256=UWt5Eka90IWVBYdvLgY5PXnkBcVYpHjnw9T67rM85T8,378
-pip/_vendor/toml/tz.py,sha256=-5vg8wkg_atnVi2TnEveexIVE7T_FxBVr_-2WVfO1oA,701
-pip/_vendor/urllib3/__init__.py,sha256=j3yzHIbmW7CS-IKQJ9-PPQf_YKO8EOAey_rMW0UR7us,2763
-pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc,,
-pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc,,
-pip/_vendor/urllib3/_collections.py,sha256=Rp1mVyBgc_UlAcp6M3at1skJBXR5J43NawRTvW2g_XY,10811
-pip/_vendor/urllib3/_version.py,sha256=2Bjk_cB49921PTvereWp8ZR3NhLNoCMAyHSGP-OesLk,63
-pip/_vendor/urllib3/connection.py,sha256=q-vf_TM3MyRbZcFn3-VCKZBSf0oEhGjv7BFeZm_7kw4,18748
-pip/_vendor/urllib3/connectionpool.py,sha256=IKoeuJZY9YAYm0GK4q-MXAhyXW0M_FnvabYaNsDIR-E,37133
-pip/_vendor/urllib3/contrib/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/_appengine_environ.py,sha256=bDbyOEhW2CKLJcQqAKAyrEHN-aklsyHFKq6vF8ZFsmk,957
-pip/_vendor/urllib3/contrib/_securetransport/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc,,
-pip/_vendor/urllib3/contrib/_securetransport/bindings.py,sha256=eRy1Mj-wpg7sR6-OSvnSV4jUbjMT464dLN_CWxbIRVw,17649
-pip/_vendor/urllib3/contrib/_securetransport/low_level.py,sha256=lgIdsSycqfB0Xm5BiJzXGeIKT7ybCQMFPJAgkcwPa1s,13908
-pip/_vendor/urllib3/contrib/appengine.py,sha256=lm86XjaOI7ajbonsN0JLA0ckkgSFWhgxWKLW_Ymt4sI,11034
-pip/_vendor/urllib3/contrib/ntlmpool.py,sha256=6I95h1_71fzxmoMSNtY0gB8lnyCoVtP_DpqFGj14fdU,4160
-pip/_vendor/urllib3/contrib/pyopenssl.py,sha256=kqm9SX4h_6h76QwGDBiNQ7i-ktKZunZuxzTVjjtHDto,16795
-pip/_vendor/urllib3/contrib/securetransport.py,sha256=MEEHa3YqG8ifDPYG0gO12C1tZu2I-HqGF4lC53cHFPg,34303
-pip/_vendor/urllib3/contrib/socks.py,sha256=DcRjM2l0rQMIyhYrN6r-tnVkY6ZTDxHJlM8_usAkGCA,7097
-pip/_vendor/urllib3/exceptions.py,sha256=0Mnno3KHTNfXRfY7638NufOPkUb6mXOm-Lqj-4x2w8A,8217
-pip/_vendor/urllib3/fields.py,sha256=kvLDCg_JmH1lLjUUEY_FLS8UhY7hBvDPuVETbY8mdrM,8579
-pip/_vendor/urllib3/filepost.py,sha256=5b_qqgRHVlL7uLtdAYBzBh-GHmU5AfJVt_2N0XS3PeY,2440
-pip/_vendor/urllib3/packages/__init__.py,sha256=h4BLhD4tLaBx1adaDtKXfupsgqY0wWLXb_f1_yVlV6A,108
-pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc,,
-pip/_vendor/urllib3/packages/backports/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
-pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc,,
-pip/_vendor/urllib3/packages/backports/makefile.py,sha256=nbzt3i0agPVP07jqqgjhaYjMmuAi_W5E0EywZivVO8E,1417
-pip/_vendor/urllib3/packages/six.py,sha256=adx4z-eM_D0Vvu0IIqVzFACQ_ux9l64y7DkSEfbxCDs,32536
-pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py,sha256=zppezdEQdpGsYerI6mV6MfUYy495JV4mcOWC_GgbljU,757
-pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc,,
-pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py,sha256=6dZ-q074g7XhsJ27MFCgkct8iVNZB3sMZvKhf-KUVy0,5679
-pip/_vendor/urllib3/poolmanager.py,sha256=whzlX6UTEgODMOCy0ZDMUONRBCz5wyIM8Z9opXAY-Lk,19763
-pip/_vendor/urllib3/request.py,sha256=ZFSIqX0C6WizixecChZ3_okyu7BEv0lZu1VT0s6h4SM,5985
-pip/_vendor/urllib3/response.py,sha256=hGhGBh7TkEkh_IQg5C1W_xuPNrgIKv5BUXPyE-q0LuE,28203
-pip/_vendor/urllib3/util/__init__.py,sha256=JEmSmmqqLyaw8P51gUImZh8Gwg9i1zSe-DoqAitn2nc,1155
-pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc,,
-pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc,,
-pip/_vendor/urllib3/util/connection.py,sha256=_I-ZoF58xXLLjo-Q5IGaJrMxy2IW_exI8K9O9pq7op0,4922
-pip/_vendor/urllib3/util/proxy.py,sha256=FGipAEnvZteyldXNjce4DEB7YzwU-a5lep8y5S0qHQg,1604
-pip/_vendor/urllib3/util/queue.py,sha256=nRgX8_eX-_VkvxoX096QWoz8Ps0QHUAExILCY_7PncM,498
-pip/_vendor/urllib3/util/request.py,sha256=NnzaEKQ1Pauw5MFMV6HmgEMHITf0Aua9fQuzi2uZzGc,4123
-pip/_vendor/urllib3/util/response.py,sha256=GJpg3Egi9qaJXRwBh5wv-MNuRWan5BIu40oReoxWP28,3510
-pip/_vendor/urllib3/util/retry.py,sha256=s3ZNKXO6_t23ZQMg8zlu20PMSqraT495-S_mEY_19ak,21396
-pip/_vendor/urllib3/util/ssl_.py,sha256=dKcH-sqiR_ESWqKP1PJ6SUAUSvqC-fkMQGrTokV4NMY,16281
-pip/_vendor/urllib3/util/ssltransport.py,sha256=vOOCPRn-dODUZ2qtMCfStb0JmjgrgJaKLqJ9qvKucFs,6932
-pip/_vendor/urllib3/util/timeout.py,sha256=QSbBUNOB9yh6AnDn61SrLQ0hg5oz0I9-uXEG91AJuIg,10003
-pip/_vendor/urllib3/util/url.py,sha256=KP_yaHA0TFFAsQSImc_FOHO-Wq3PNHf_bKObKcrgdU4,13981
-pip/_vendor/urllib3/util/wait.py,sha256=3MUKRSAUJDB2tgco7qRUskW0zXGAWYvRRE4Q1_6xlLs,5404
-pip/_vendor/vendor.txt,sha256=yaN2qLLkKuoRmFLCxGJ1LZtZiuV7T7NoisZqwWNRhIU,364
-pip/_vendor/webencodings/__init__.py,sha256=qOBJIuPy_4ByYH6W_bNgJF-qYQ2DoU-dKsDu5yRWCXg,10579
-pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc,,
-pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc,,
-pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc,,
-pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc,,
-pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc,,
-pip/_vendor/webencodings/labels.py,sha256=4AO_KxTddqGtrL9ns7kAPjb0CcN6xsCIxbK37HY9r3E,8979
-pip/_vendor/webencodings/mklabels.py,sha256=GYIeywnpaLnP0GSic8LFWgd0UVvO_l1Nc6YoF-87R_4,1305
-pip/_vendor/webencodings/tests.py,sha256=OtGLyjhNY1fvkW1GvLJ_FV9ZoqC9Anyjr7q3kxTbzNs,6563
-pip/_vendor/webencodings/x_user_defined.py,sha256=yOqWSdmpytGfUgh_Z6JYgDNhoc-BAHyyeeT15Fr42tM,4307
-pip/py.typed,sha256=l9g-Fc1zgtIZ70tLJDcx6qKeqDutTVVSceIqUod-awg,286
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL b/env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL
deleted file mode 100644
index 385faab0..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/WHEEL
+++ /dev/null
@@ -1,5 +0,0 @@
-Wheel-Version: 1.0
-Generator: bdist_wheel (0.36.2)
-Root-Is-Purelib: true
-Tag: py3-none-any
-
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt b/env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt
deleted file mode 100644
index d48bd8a8..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/entry_points.txt
+++ /dev/null
@@ -1,5 +0,0 @@
-[console_scripts]
-pip = pip._internal.cli.main:main
-pip3 = pip._internal.cli.main:main
-pip3.8 = pip._internal.cli.main:main
-
diff --git a/env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt b/env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt
deleted file mode 100644
index a1b589e3..00000000
--- a/env/Lib/site-packages/pip-21.1.3.dist-info/top_level.txt
+++ /dev/null
@@ -1 +0,0 @@
-pip
diff --git a/env/Lib/site-packages/pip/__init__.py b/env/Lib/site-packages/pip/__init__.py
index 75815d8b..6633ef7e 100644
--- a/env/Lib/site-packages/pip/__init__.py
+++ b/env/Lib/site-packages/pip/__init__.py
@@ -1,10 +1,9 @@
 from typing import List, Optional
 
-__version__ = "21.1.3"
+__version__ = "23.2.1"
 
 
-def main(args=None):
-    # type: (Optional[List[str]]) -> int
+def main(args: Optional[List[str]] = None) -> int:
     """This is an internal API only meant for use by pip's own console scripts.
 
     For additional details, see https://github.com/pypa/pip/issues/7498.
diff --git a/env/Lib/site-packages/pip/__main__.py b/env/Lib/site-packages/pip/__main__.py
index fe34a7b7..59913261 100644
--- a/env/Lib/site-packages/pip/__main__.py
+++ b/env/Lib/site-packages/pip/__main__.py
@@ -1,6 +1,5 @@
 import os
 import sys
-import warnings
 
 # Remove '' and current working directory from the first entry
 # of sys.path, if present to avoid using current directory
@@ -20,12 +19,6 @@ if __package__ == "":
     sys.path.insert(0, path)
 
 if __name__ == "__main__":
-    # Work around the error reported in #9540, pending a proper fix.
-    # Note: It is essential the warning filter is set *before* importing
-    #       pip, as the deprecation happens at import time, not runtime.
-    warnings.filterwarnings(
-        "ignore", category=DeprecationWarning, module=".*packaging\\.version"
-    )
     from pip._internal.cli.main import main as _main
 
     sys.exit(_main())
diff --git a/env/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index dc3d1815e1a9ac6e62163d03e139a6282a04e7a4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 618
zcmYe~<>g{vU|^UdaWJ)jk%8ech=Yuo85kHG7#J9el^7TpQW#Pga~N_NqZo6UqL>&N
zQkbHcQ`k~iQdnCUqgYaygBdj0UxIXNGTmbF$t*6p#o=F2l9`{Em{Y}OWT<DTXY7~E
z2vPvWObiSRAnXjXK?Gz2V+s?<hFV5Oh8o5ihGxcK22JLw=^+`J#R{3l3W<3NnRz9t
zMR|!i3XTDu3i)|Cl?u73iFqXoY57G8rNyZVNtFr(nFZ>_3i;)E3d#9-#rZj@3dPAq
znFS@qdR$xz3JMBt`9%teDJhu{rzxbQmLz886zeDyr=}`ol#~<{Tj}ekXO?7?Cg~;T
z=js<!79{EyWESXW78jSM7VDdvSX$_T4Jrb8Mw9UtM|^ovVnIP_ktWkE`GU*>y?B@_
z^-4=JbBgs+^Gb>;3-UAbN{WkE7#J8p0hCyj4&kh1C}L+|VE9$wY!wq)oLW>IlbVx~
zSrp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p9O4?JU=|Y);1iQ*
zqMMVSo>^RynH`gwR~F-wnG{o;S(2(-keHmEn4Vf31M)<Cd}dx|NqoFsLFFx$+{Da0
zHc;S$9L2!K!&Jlxavh_eChIM>lFEY2y!0Ya1QmhO!7c9i__EZZ;>`TK_;|2Fu)C26
c4h9B>TO2mI`6;D2sdk{iDFzuVz{J7~04z76v;Y7A

diff --git a/env/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc b/env/Lib/site-packages/pip/__pycache__/__main__.cpython-39.pyc
deleted file mode 100644
index bd7a243e21c993216c2db568cdbfd2a812a53f8a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 615
zcmYe~<>g{vU|^UdaWHiq3j@Pr5C<8vGB7YWFfcF_&tPC+NMT4}%wdRv(2P-xU_Mh6
zQz~N?a|(kbLkd$W!vdCt3~5Yd3`JHT(FLq23=0_<8B*C&n6jCQQc@YRm=~}^Nsfh#
z3mK!B!Rk0u7*d%RGBGlwa-}e5GZjrqWy<1CVM*mlVNGG{Wo87~$)3ZT%NNDZ$dJmo
zKp>UB8EkS2V=#jz$4ii#{cbVb;)svWP0Y-TkH5v1nVy$llv*XCr&W-coSm4SnU@};
zSC(2-oSC1e$#jb&Ik6-)J-?{(7F%w9N@-52CgUv@kX}u}TTJ=Ix0s77i*Iq1Cl=*p
z=A{?kVkt;0$+*Rqo?4Pzo^p%1Aiv-icYHj=<ka~1TkI*BMR|$2sUR1mW#)i{*fR5q
zQ;SMKA|RRg_*;BwnK>n?MQ}rfTv7{)Qj-%)GV}AoAvWC-E66O+i_gp}NiE7t%+X8E
z$<zb6s)(I|f#DV_*mt*BQY$h`Rx%VxFfc%fUj@!qF`>n&Ma40xIVqV%G5&d}E=8GT
zsS3IZp?;oWu0g?`A&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9
zF{ycFF+Q0|F~ylBsk%@f7RMB17U;tQSFfP*7KaTa*z6cV$wP{Pfq{dOgOP(xjFE?h
UgH?o)kBNhYg^}$)8#50R09GKi`~Uy|

diff --git a/env/Lib/site-packages/pip/_internal/__init__.py b/env/Lib/site-packages/pip/_internal/__init__.py
index 41071cd8..6afb5c62 100644
--- a/env/Lib/site-packages/pip/_internal/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/__init__.py
@@ -1,10 +1,14 @@
 from typing import List, Optional
 
 import pip._internal.utils.inject_securetransport  # noqa
+from pip._internal.utils import _log
 
+# init_logging() must be called before any call to logging.getLogger()
+# which happens at import of most modules.
+_log.init_logging()
 
-def main(args=None):
-    # type: (Optional[List[str]]) -> int
+
+def main(args: (Optional[List[str]]) = None) -> int:
     """This is preserved for old console scripts that may still be referencing
     it.
 
diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 7fe14dae3c07d62767e554113e942c5938779003..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 667
zcmYe~<>g{vU|^UdaWHijBLl-@5C<7EGcYhXFfcF_t1&Pzq%fo~<}l<kMlt3xMKLjg
z_)Iy>Q7kE}Da<J>EsRmDDNMl(nrtsYCTKF<V)4l=F1f|wUr>^npO={9m&^!~fMO;F
z1_lsz2AM7bGMzDn31oULBO^l%V+}(yV=#jzbJe_%jLc$%%wmOtqSWHlqO#N!g|z%4
zh5Vcph2;Fa;{2Rch2rF*%z~0)g_4ZK5{2BvN`>N*%$yvBq*R5X)U?#1)V$=(ymT%F
z1qFr75<M<3!!5r^Au%N-6XG(3l+=>M%$#B!h2qpyg^ZGtf?_Lu{q)R|jM5~%<osOy
zg35wK{esK_{mkOx($r#oa}!GoJ+MJVAU|m`-r|TaFG?&ZNG;N2x+PzbS)do6nOBlp
zl$V&JS6Y&pQ>>SoS5j12ke``XQe4Esz`y_spTwec2xlcj5jz6|!>=l5tC-N@)S}{;
z)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ5Z53DvzUMY
zpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi=QkSE|y(~pnO%*!l^kJl@x
zyv356n3=~0iVcwS7}$B3ia0^;Wc1TyyTw*gS&*5RUIdD<B2c2ZrG?FtnR!{M$tCf{
zsmY~9sU<~;dBp|!MJ2bG3o;A9hJk&FL~t-LFx=v>$<0qG%}KQb1!XbFaseg|W&qe8
Bw@m;5

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/build_env.cpython-39.pyc
deleted file mode 100644
index 033a15b6b579e37bf15c82ae533c009683c074b1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/cache.cpython-39.pyc
deleted file mode 100644
index c8bfcdf1b6e6d5cd821d106a50134e3e6c8983c9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/configuration.cpython-39.pyc
deleted file mode 100644
index 5aff75cd21c04afcc029cd0a05d2dd4a94f157d0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/exceptions.cpython-39.pyc
deleted file mode 100644
index e6a9ab952836dbe62cd94fcd7a1cf5e0175297b3..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/main.cpython-39.pyc
deleted file mode 100644
index 343a299dd20ad3517a6b1dad93f79a0ecf8cf061..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 604
zcmYe~<>g{vU|^UdaWFNWk%8ech=Yuo85kHG7#J9e<ro+kQW#Pga~N_NqZo6UqL>&N
zQdm=%Q&?IUqnJ~ef*CZ~UV?OLGTmbF$t*6p#o=F2l9`{EnB$ks2$FzeCI$uu5OxNc
zDgrW<F@*_aYAqupLk(jMLo;JAgC=v;ypW8{Vuj3Ng@U5g;?$zD)D(rZ{33<?oD_xR
z{Ji4)oK%J4<f6=il46CDjKmU!+{8+S;*!jq9EGG*g`(87)S}e9<jlNuE(HYzh0GE?
zE-=F_zepi5B_$K$GKG}XlEloMVjYFz)KrCxl9GaAD}DX+%#w`KB)#PPT>XN|f<*m-
z%mV$);^NZOVtsQHOA9@)K}8@xX)@m8h%YZnEGS4V(qy_NUyxa#7oV9|l3J9Pn4?!(
zl9^Mimzq~nR9TRpnO9O=#KOS901BVPqI3vnB|{NA0|UdaGH0up(Bjmh;+WK&l+2<S
z|GZR}qRg^X1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd
z{PfJ?lFaOw)V#77pUk9~;>?m%-GapA?8Nlc;uw%8;7-%eP0Y;GE2zB10%Cw%RSY5+
z*m;<WI6-b?^wVUy#a2>TkeQcW1d6R9P(lF9fgOxQa4;}1+~Tmw%}*)KNwouoN-;=-
G05br{kDr(T

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/pyproject.cpython-39.pyc
deleted file mode 100644
index d4627db45e6348451a0219f7131b6b479df88347..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/self_outdated_check.cpython-39.pyc
deleted file mode 100644
index 936888cbd4eb0274946e937dde5ccbe6f7016557..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/__pycache__/wheel_builder.cpython-39.pyc
deleted file mode 100644
index 9a6a77a02ea6035e17a88e86924b1df096153934..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8305
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
L0*5k(HHQEI>K2~u

diff --git a/env/Lib/site-packages/pip/_internal/build_env.py b/env/Lib/site-packages/pip/_internal/build_env.py
index cc15250f..4f704a35 100644
--- a/env/Lib/site-packages/pip/_internal/build_env.py
+++ b/env/Lib/site-packages/pip/_internal/build_env.py
@@ -1,24 +1,24 @@
 """Build Environment used for isolation during sdist building
 """
 
-import contextlib
 import logging
 import os
 import pathlib
+import site
 import sys
 import textwrap
-import zipfile
 from collections import OrderedDict
-from sysconfig import get_paths
 from types import TracebackType
-from typing import TYPE_CHECKING, Iterable, Iterator, List, Optional, Set, Tuple, Type
+from typing import TYPE_CHECKING, Iterable, List, Optional, Set, Tuple, Type, Union
 
 from pip._vendor.certifi import where
-from pip._vendor.pkg_resources import Requirement, VersionConflict, WorkingSet
+from pip._vendor.packaging.requirements import Requirement
+from pip._vendor.packaging.version import Version
 
 from pip import __file__ as pip_location
 from pip._internal.cli.spinners import open_spinner
-from pip._internal.locations import get_platlib, get_prefixed_libs, get_purelib
+from pip._internal.locations import get_platlib, get_purelib, get_scheme
+from pip._internal.metadata import get_default_environment, get_environment
 from pip._internal.utils.subprocess import call_subprocess
 from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds
 
@@ -28,62 +28,68 @@ if TYPE_CHECKING:
 logger = logging.getLogger(__name__)
 
 
-class _Prefix:
+def _dedup(a: str, b: str) -> Union[Tuple[str], Tuple[str, str]]:
+    return (a, b) if a != b else (a,)
+
 
-    def __init__(self, path):
-        # type: (str) -> None
+class _Prefix:
+    def __init__(self, path: str) -> None:
         self.path = path
         self.setup = False
-        self.bin_dir = get_paths(
-            'nt' if os.name == 'nt' else 'posix_prefix',
-            vars={'base': path, 'platbase': path}
-        )['scripts']
-        self.lib_dirs = get_prefixed_libs(path)
+        scheme = get_scheme("", prefix=path)
+        self.bin_dir = scheme.scripts
+        self.lib_dirs = _dedup(scheme.purelib, scheme.platlib)
 
 
-@contextlib.contextmanager
-def _create_standalone_pip() -> Iterator[str]:
-    """Create a "standalone pip" zip file.
+def get_runnable_pip() -> str:
+    """Get a file to pass to a Python executable, to run the currently-running pip.
 
-    The zip file's content is identical to the currently-running pip.
-    It will be used to install requirements into the build environment.
+    This is used to run a pip subprocess, for installing requirements into the build
+    environment.
     """
     source = pathlib.Path(pip_location).resolve().parent
 
-    # Return the current instance if `source` is not a directory. We can't build
-    # a zip from this, and it likely means the instance is already standalone.
     if not source.is_dir():
-        yield str(source)
-        return
+        # This would happen if someone is using pip from inside a zip file. In that
+        # case, we can use that directly.
+        return str(source)
 
-    with TempDirectory(kind="standalone-pip") as tmp_dir:
-        pip_zip = os.path.join(tmp_dir.path, "__env_pip__.zip")
-        kwargs = {}
-        if sys.version_info >= (3, 8):
-            kwargs["strict_timestamps"] = False
-        with zipfile.ZipFile(pip_zip, "w", **kwargs) as zf:
-            for child in source.rglob("*"):
-                zf.write(child, child.relative_to(source.parent).as_posix())
-        yield os.path.join(pip_zip, "pip")
+    return os.fsdecode(source / "__pip-runner__.py")
 
 
-class BuildEnvironment:
-    """Creates and manages an isolated environment to install build deps
+def _get_system_sitepackages() -> Set[str]:
+    """Get system site packages
+
+    Usually from site.getsitepackages,
+    but fallback on `get_purelib()/get_platlib()` if unavailable
+    (e.g. in a virtualenv created by virtualenv<20)
+
+    Returns normalized set of strings.
     """
+    if hasattr(site, "getsitepackages"):
+        system_sites = site.getsitepackages()
+    else:
+        # virtualenv < 20 overwrites site.py without getsitepackages
+        # fallback on get_purelib/get_platlib.
+        # this is known to miss things, but shouldn't in the cases
+        # where getsitepackages() has been removed (inside a virtualenv)
+        system_sites = [get_purelib(), get_platlib()]
+    return {os.path.normcase(path) for path in system_sites}
 
-    def __init__(self):
-        # type: () -> None
-        temp_dir = TempDirectory(
-            kind=tempdir_kinds.BUILD_ENV, globally_managed=True
-        )
+
+class BuildEnvironment:
+    """Creates and manages an isolated environment to install build deps"""
+
+    def __init__(self) -> None:
+        temp_dir = TempDirectory(kind=tempdir_kinds.BUILD_ENV, globally_managed=True)
 
         self._prefixes = OrderedDict(
             (name, _Prefix(os.path.join(temp_dir.path, name)))
-            for name in ('normal', 'overlay')
+            for name in ("normal", "overlay")
         )
 
-        self._bin_dirs = []  # type: List[str]
-        self._lib_dirs = []  # type: List[str]
+        self._bin_dirs: List[str] = []
+        self._lib_dirs: List[str] = []
         for prefix in reversed(list(self._prefixes.values())):
             self._bin_dirs.append(prefix.bin_dir)
             self._lib_dirs.extend(prefix.lib_dirs)
@@ -91,15 +97,17 @@ class BuildEnvironment:
         # Customize site to:
         # - ensure .pth files are honored
         # - prevent access to system site packages
-        system_sites = {
-            os.path.normcase(site) for site in (get_purelib(), get_platlib())
-        }
-        self._site_dir = os.path.join(temp_dir.path, 'site')
+        system_sites = _get_system_sitepackages()
+
+        self._site_dir = os.path.join(temp_dir.path, "site")
         if not os.path.exists(self._site_dir):
             os.mkdir(self._site_dir)
-        with open(os.path.join(self._site_dir, 'sitecustomize.py'), 'w') as fp:
-            fp.write(textwrap.dedent(
-                '''
+        with open(
+            os.path.join(self._site_dir, "sitecustomize.py"), "w", encoding="utf-8"
+        ) as fp:
+            fp.write(
+                textwrap.dedent(
+                    """
                 import os, site, sys
 
                 # First, drop system-sites related paths.
@@ -122,90 +130,97 @@ class BuildEnvironment:
                 for path in {lib_dirs!r}:
                     assert not path in sys.path
                     site.addsitedir(path)
-                '''
-            ).format(system_sites=system_sites, lib_dirs=self._lib_dirs))
+                """
+                ).format(system_sites=system_sites, lib_dirs=self._lib_dirs)
+            )
 
-    def __enter__(self):
-        # type: () -> None
+    def __enter__(self) -> None:
         self._save_env = {
             name: os.environ.get(name, None)
-            for name in ('PATH', 'PYTHONNOUSERSITE', 'PYTHONPATH')
+            for name in ("PATH", "PYTHONNOUSERSITE", "PYTHONPATH")
         }
 
         path = self._bin_dirs[:]
-        old_path = self._save_env['PATH']
+        old_path = self._save_env["PATH"]
         if old_path:
             path.extend(old_path.split(os.pathsep))
 
         pythonpath = [self._site_dir]
 
-        os.environ.update({
-            'PATH': os.pathsep.join(path),
-            'PYTHONNOUSERSITE': '1',
-            'PYTHONPATH': os.pathsep.join(pythonpath),
-        })
+        os.environ.update(
+            {
+                "PATH": os.pathsep.join(path),
+                "PYTHONNOUSERSITE": "1",
+                "PYTHONPATH": os.pathsep.join(pythonpath),
+            }
+        )
 
     def __exit__(
         self,
-        exc_type,  # type: Optional[Type[BaseException]]
-        exc_val,  # type: Optional[BaseException]
-        exc_tb  # type: Optional[TracebackType]
-    ):
-        # type: (...) -> None
+        exc_type: Optional[Type[BaseException]],
+        exc_val: Optional[BaseException],
+        exc_tb: Optional[TracebackType],
+    ) -> None:
         for varname, old_value in self._save_env.items():
             if old_value is None:
                 os.environ.pop(varname, None)
             else:
                 os.environ[varname] = old_value
 
-    def check_requirements(self, reqs):
-        # type: (Iterable[str]) -> Tuple[Set[Tuple[str, str]], Set[str]]
+    def check_requirements(
+        self, reqs: Iterable[str]
+    ) -> Tuple[Set[Tuple[str, str]], Set[str]]:
         """Return 2 sets:
-            - conflicting requirements: set of (installed, wanted) reqs tuples
-            - missing requirements: set of reqs
+        - conflicting requirements: set of (installed, wanted) reqs tuples
+        - missing requirements: set of reqs
         """
         missing = set()
         conflicting = set()
         if reqs:
-            ws = WorkingSet(self._lib_dirs)
-            for req in reqs:
-                try:
-                    if ws.find(Requirement.parse(req)) is None:
-                        missing.add(req)
-                except VersionConflict as e:
-                    conflicting.add((str(e.args[0].as_requirement()),
-                                     str(e.args[1])))
+            env = (
+                get_environment(self._lib_dirs)
+                if hasattr(self, "_lib_dirs")
+                else get_default_environment()
+            )
+            for req_str in reqs:
+                req = Requirement(req_str)
+                # We're explicitly evaluating with an empty extra value, since build
+                # environments are not provided any mechanism to select specific extras.
+                if req.marker is not None and not req.marker.evaluate({"extra": ""}):
+                    continue
+                dist = env.get_distribution(req.name)
+                if not dist:
+                    missing.add(req_str)
+                    continue
+                if isinstance(dist.version, Version):
+                    installed_req_str = f"{req.name}=={dist.version}"
+                else:
+                    installed_req_str = f"{req.name}==={dist.version}"
+                if not req.specifier.contains(dist.version, prereleases=True):
+                    conflicting.add((installed_req_str, req_str))
+                # FIXME: Consider direct URL?
         return conflicting, missing
 
     def install_requirements(
         self,
-        finder,  # type: PackageFinder
-        requirements,  # type: Iterable[str]
-        prefix_as_string,  # type: str
-        message  # type: str
-    ):
-        # type: (...) -> None
+        finder: "PackageFinder",
+        requirements: Iterable[str],
+        prefix_as_string: str,
+        *,
+        kind: str,
+    ) -> None:
         prefix = self._prefixes[prefix_as_string]
         assert not prefix.setup
         prefix.setup = True
         if not requirements:
             return
-        with contextlib.ExitStack() as ctx:
-            # TODO: Remove this block when dropping 3.6 support. Python 3.6
-            # lacks importlib.resources and pep517 has issues loading files in
-            # a zip, so we fallback to the "old" method by adding the current
-            # pip directory to the child process's sys.path.
-            if sys.version_info < (3, 7):
-                pip_runnable = os.path.dirname(pip_location)
-            else:
-                pip_runnable = ctx.enter_context(_create_standalone_pip())
-            self._install_requirements(
-                pip_runnable,
-                finder,
-                requirements,
-                prefix,
-                message,
-            )
+        self._install_requirements(
+            get_runnable_pip(),
+            finder,
+            requirements,
+            prefix,
+            kind=kind,
+        )
 
     @staticmethod
     def _install_requirements(
@@ -213,74 +228,84 @@ class BuildEnvironment:
         finder: "PackageFinder",
         requirements: Iterable[str],
         prefix: _Prefix,
-        message: str,
+        *,
+        kind: str,
     ) -> None:
-        args = [
-            sys.executable, pip_runnable, 'install',
-            '--ignore-installed', '--no-user', '--prefix', prefix.path,
-            '--no-warn-script-location',
-        ]  # type: List[str]
+        args: List[str] = [
+            sys.executable,
+            pip_runnable,
+            "install",
+            "--ignore-installed",
+            "--no-user",
+            "--prefix",
+            prefix.path,
+            "--no-warn-script-location",
+        ]
         if logger.getEffectiveLevel() <= logging.DEBUG:
-            args.append('-v')
-        for format_control in ('no_binary', 'only_binary'):
+            args.append("-v")
+        for format_control in ("no_binary", "only_binary"):
             formats = getattr(finder.format_control, format_control)
-            args.extend(('--' + format_control.replace('_', '-'),
-                         ','.join(sorted(formats or {':none:'}))))
+            args.extend(
+                (
+                    "--" + format_control.replace("_", "-"),
+                    ",".join(sorted(formats or {":none:"})),
+                )
+            )
 
         index_urls = finder.index_urls
         if index_urls:
-            args.extend(['-i', index_urls[0]])
+            args.extend(["-i", index_urls[0]])
             for extra_index in index_urls[1:]:
-                args.extend(['--extra-index-url', extra_index])
+                args.extend(["--extra-index-url", extra_index])
         else:
-            args.append('--no-index')
+            args.append("--no-index")
         for link in finder.find_links:
-            args.extend(['--find-links', link])
+            args.extend(["--find-links", link])
 
         for host in finder.trusted_hosts:
-            args.extend(['--trusted-host', host])
+            args.extend(["--trusted-host", host])
         if finder.allow_all_prereleases:
-            args.append('--pre')
+            args.append("--pre")
         if finder.prefer_binary:
-            args.append('--prefer-binary')
-        args.append('--')
+            args.append("--prefer-binary")
+        args.append("--")
         args.extend(requirements)
         extra_environ = {"_PIP_STANDALONE_CERT": where()}
-        with open_spinner(message) as spinner:
-            call_subprocess(args, spinner=spinner, extra_environ=extra_environ)
+        with open_spinner(f"Installing {kind}") as spinner:
+            call_subprocess(
+                args,
+                command_desc=f"pip subprocess to install {kind}",
+                spinner=spinner,
+                extra_environ=extra_environ,
+            )
 
 
 class NoOpBuildEnvironment(BuildEnvironment):
-    """A no-op drop-in replacement for BuildEnvironment
-    """
+    """A no-op drop-in replacement for BuildEnvironment"""
 
-    def __init__(self):
-        # type: () -> None
+    def __init__(self) -> None:
         pass
 
-    def __enter__(self):
-        # type: () -> None
+    def __enter__(self) -> None:
         pass
 
     def __exit__(
         self,
-        exc_type,  # type: Optional[Type[BaseException]]
-        exc_val,  # type: Optional[BaseException]
-        exc_tb  # type: Optional[TracebackType]
-    ):
-        # type: (...) -> None
+        exc_type: Optional[Type[BaseException]],
+        exc_val: Optional[BaseException],
+        exc_tb: Optional[TracebackType],
+    ) -> None:
         pass
 
-    def cleanup(self):
-        # type: () -> None
+    def cleanup(self) -> None:
         pass
 
     def install_requirements(
         self,
-        finder,  # type: PackageFinder
-        requirements,  # type: Iterable[str]
-        prefix_as_string,  # type: str
-        message  # type: str
-    ):
-        # type: (...) -> None
+        finder: "PackageFinder",
+        requirements: Iterable[str],
+        prefix_as_string: str,
+        *,
+        kind: str,
+    ) -> None:
         raise NotImplementedError()
diff --git a/env/Lib/site-packages/pip/_internal/cache.py b/env/Lib/site-packages/pip/_internal/cache.py
index 7ef51b92..8d3a664c 100644
--- a/env/Lib/site-packages/pip/_internal/cache.py
+++ b/env/Lib/site-packages/pip/_internal/cache.py
@@ -5,13 +5,14 @@ import hashlib
 import json
 import logging
 import os
-from typing import Any, Dict, List, Optional, Set
+from pathlib import Path
+from typing import Any, Dict, List, Optional
 
 from pip._vendor.packaging.tags import Tag, interpreter_name, interpreter_version
 from pip._vendor.packaging.utils import canonicalize_name
 
 from pip._internal.exceptions import InvalidWheelFilename
-from pip._internal.models.format_control import FormatControl
+from pip._internal.models.direct_url import DirectUrl
 from pip._internal.models.link import Link
 from pip._internal.models.wheel import Wheel
 from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds
@@ -19,9 +20,10 @@ from pip._internal.utils.urls import path_to_url
 
 logger = logging.getLogger(__name__)
 
+ORIGIN_JSON_NAME = "origin.json"
 
-def _hash_dict(d):
-    # type: (Dict[str, str]) -> str
+
+def _hash_dict(d: Dict[str, str]) -> str:
     """Return a stable sha224 of a dictionary."""
     s = json.dumps(d, sort_keys=True, separators=(",", ":"), ensure_ascii=True)
     return hashlib.sha224(s.encode("ascii")).hexdigest()
@@ -30,29 +32,16 @@ def _hash_dict(d):
 class Cache:
     """An abstract class - provides cache directories for data from links
 
-
-        :param cache_dir: The root of the cache.
-        :param format_control: An object of FormatControl class to limit
-            binaries being read from the cache.
-        :param allowed_formats: which formats of files the cache should store.
-            ('binary' and 'source' are the only allowed values)
+    :param cache_dir: The root of the cache.
     """
 
-    def __init__(self, cache_dir, format_control, allowed_formats):
-        # type: (str, FormatControl, Set[str]) -> None
+    def __init__(self, cache_dir: str) -> None:
         super().__init__()
         assert not cache_dir or os.path.isabs(cache_dir)
         self.cache_dir = cache_dir or None
-        self.format_control = format_control
-        self.allowed_formats = allowed_formats
-
-        _valid_formats = {"source", "binary"}
-        assert self.allowed_formats.union(_valid_formats) == _valid_formats
 
-    def _get_cache_path_parts(self, link):
-        # type: (Link) -> List[str]
-        """Get parts of part that must be os.path.joined with cache_dir
-        """
+    def _get_cache_path_parts(self, link: Link) -> List[str]:
+        """Get parts of part that must be os.path.joined with cache_dir"""
 
         # We want to generate an url to use as our cache key, we don't want to
         # just re-use the URL because it might have other items in the fragment
@@ -84,22 +73,11 @@ class Cache:
 
         return parts
 
-    def _get_candidates(self, link, canonical_package_name):
-        # type: (Link, str) -> List[Any]
-        can_not_cache = (
-            not self.cache_dir or
-            not canonical_package_name or
-            not link
-        )
+    def _get_candidates(self, link: Link, canonical_package_name: str) -> List[Any]:
+        can_not_cache = not self.cache_dir or not canonical_package_name or not link
         if can_not_cache:
             return []
 
-        formats = self.format_control.get_allowed_formats(
-            canonical_package_name
-        )
-        if not self.allowed_formats.intersection(formats):
-            return []
-
         candidates = []
         path = self.get_path_for_link(link)
         if os.path.isdir(path):
@@ -107,19 +85,16 @@ class Cache:
                 candidates.append((candidate, path))
         return candidates
 
-    def get_path_for_link(self, link):
-        # type: (Link) -> str
-        """Return a directory to store cached items in for link.
-        """
+    def get_path_for_link(self, link: Link) -> str:
+        """Return a directory to store cached items in for link."""
         raise NotImplementedError()
 
     def get(
         self,
-        link,            # type: Link
-        package_name,    # type: Optional[str]
-        supported_tags,  # type: List[Tag]
-    ):
-        # type: (...) -> Link
+        link: Link,
+        package_name: Optional[str],
+        supported_tags: List[Tag],
+    ) -> Link:
         """Returns a link to a cached item if it exists, otherwise returns the
         passed link.
         """
@@ -127,15 +102,12 @@ class Cache:
 
 
 class SimpleWheelCache(Cache):
-    """A cache of wheels for future installs.
-    """
+    """A cache of wheels for future installs."""
 
-    def __init__(self, cache_dir, format_control):
-        # type: (str, FormatControl) -> None
-        super().__init__(cache_dir, format_control, {"binary"})
+    def __init__(self, cache_dir: str) -> None:
+        super().__init__(cache_dir)
 
-    def get_path_for_link(self, link):
-        # type: (Link) -> str
+    def get_path_for_link(self, link: Link) -> str:
         """Return a directory to store cached wheels for link
 
         Because there are M wheels for any one sdist, we provide a directory
@@ -157,20 +129,17 @@ class SimpleWheelCache(Cache):
 
     def get(
         self,
-        link,            # type: Link
-        package_name,    # type: Optional[str]
-        supported_tags,  # type: List[Tag]
-    ):
-        # type: (...) -> Link
+        link: Link,
+        package_name: Optional[str],
+        supported_tags: List[Tag],
+    ) -> Link:
         candidates = []
 
         if not package_name:
             return link
 
         canonical_package_name = canonicalize_name(package_name)
-        for wheel_name, wheel_dir in self._get_candidates(
-            link, canonical_package_name
-        ):
+        for wheel_name, wheel_dir in self._get_candidates(link, canonical_package_name):
             try:
                 wheel = Wheel(wheel_name)
             except InvalidWheelFilename:
@@ -179,7 +148,9 @@ class SimpleWheelCache(Cache):
                 logger.debug(
                     "Ignoring cached wheel %s for %s as it "
                     "does not match the expected distribution name %s.",
-                    wheel_name, link, package_name,
+                    wheel_name,
+                    link,
+                    package_name,
                 )
                 continue
             if not wheel.supported(supported_tags):
@@ -201,27 +172,39 @@ class SimpleWheelCache(Cache):
 
 
 class EphemWheelCache(SimpleWheelCache):
-    """A SimpleWheelCache that creates it's own temporary cache directory
-    """
+    """A SimpleWheelCache that creates it's own temporary cache directory"""
 
-    def __init__(self, format_control):
-        # type: (FormatControl) -> None
+    def __init__(self) -> None:
         self._temp_dir = TempDirectory(
             kind=tempdir_kinds.EPHEM_WHEEL_CACHE,
             globally_managed=True,
         )
 
-        super().__init__(self._temp_dir.path, format_control)
+        super().__init__(self._temp_dir.path)
 
 
 class CacheEntry:
     def __init__(
         self,
-        link,  # type: Link
-        persistent,  # type: bool
+        link: Link,
+        persistent: bool,
     ):
         self.link = link
         self.persistent = persistent
+        self.origin: Optional[DirectUrl] = None
+        origin_direct_url_path = Path(self.link.file_path).parent / ORIGIN_JSON_NAME
+        if origin_direct_url_path.exists():
+            try:
+                self.origin = DirectUrl.from_json(
+                    origin_direct_url_path.read_text(encoding="utf-8")
+                )
+            except Exception as e:
+                logger.warning(
+                    "Ignoring invalid cache entry origin file %s for %s (%s)",
+                    origin_direct_url_path,
+                    link.filename,
+                    e,
+                )
 
 
 class WheelCache(Cache):
@@ -231,27 +214,23 @@ class WheelCache(Cache):
     when a certain link is not found in the simple wheel cache first.
     """
 
-    def __init__(self, cache_dir, format_control):
-        # type: (str, FormatControl) -> None
-        super().__init__(cache_dir, format_control, {'binary'})
-        self._wheel_cache = SimpleWheelCache(cache_dir, format_control)
-        self._ephem_cache = EphemWheelCache(format_control)
+    def __init__(self, cache_dir: str) -> None:
+        super().__init__(cache_dir)
+        self._wheel_cache = SimpleWheelCache(cache_dir)
+        self._ephem_cache = EphemWheelCache()
 
-    def get_path_for_link(self, link):
-        # type: (Link) -> str
+    def get_path_for_link(self, link: Link) -> str:
         return self._wheel_cache.get_path_for_link(link)
 
-    def get_ephem_path_for_link(self, link):
-        # type: (Link) -> str
+    def get_ephem_path_for_link(self, link: Link) -> str:
         return self._ephem_cache.get_path_for_link(link)
 
     def get(
         self,
-        link,            # type: Link
-        package_name,    # type: Optional[str]
-        supported_tags,  # type: List[Tag]
-    ):
-        # type: (...) -> Link
+        link: Link,
+        package_name: Optional[str],
+        supported_tags: List[Tag],
+    ) -> Link:
         cache_entry = self.get_cache_entry(link, package_name, supported_tags)
         if cache_entry is None:
             return link
@@ -259,11 +238,10 @@ class WheelCache(Cache):
 
     def get_cache_entry(
         self,
-        link,            # type: Link
-        package_name,    # type: Optional[str]
-        supported_tags,  # type: List[Tag]
-    ):
-        # type: (...) -> Optional[CacheEntry]
+        link: Link,
+        package_name: Optional[str],
+        supported_tags: List[Tag],
+    ) -> Optional[CacheEntry]:
         """Returns a CacheEntry with a link to a cached item if it exists or
         None. The cache entry indicates if the item was found in the persistent
         or ephemeral cache.
@@ -285,3 +263,30 @@ class WheelCache(Cache):
             return CacheEntry(retval, persistent=False)
 
         return None
+
+    @staticmethod
+    def record_download_origin(cache_dir: str, download_info: DirectUrl) -> None:
+        origin_path = Path(cache_dir) / ORIGIN_JSON_NAME
+        if origin_path.exists():
+            try:
+                origin = DirectUrl.from_json(origin_path.read_text(encoding="utf-8"))
+            except Exception as e:
+                logger.warning(
+                    "Could not read origin file %s in cache entry (%s). "
+                    "Will attempt to overwrite it.",
+                    origin_path,
+                    e,
+                )
+            else:
+                # TODO: use DirectUrl.equivalent when
+                # https://github.com/pypa/pip/pull/10564 is merged.
+                if origin.url != download_info.url:
+                    logger.warning(
+                        "Origin URL %s in cache entry %s does not match download URL "
+                        "%s. This is likely a pip bug or a cache corruption issue. "
+                        "Will overwrite it with the new value.",
+                        origin.url,
+                        cache_dir,
+                        download_info.url,
+                    )
+        origin_path.write_text(download_info.to_json(), encoding="utf-8")
diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index ff82adfae63eee653bc79382e24e4c238b6a410f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 300
zcmYe~<>g{vU|^UdaWJ)ofq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}X0gG-YN
z5|gtN(^D0a^Ycm)GxIX@(iIYOauo8@6bdp6)Qc68^K)|(^HLOYGV@XuGV@AOi_#L4
zQx%F*a}rBZQxuZ(Q&PG7G#PKP$H%ASC&$OHWGG@{V1N+6>YS}&LW@(2iepl9QZkET
z{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-
z^3yYmOER-#QuE4Ud@_?_iZe@6b)l{<jw#42(2oZ@D=#reKRG8;KR!M)FS8^*Uaz3?
U7Kcr4eoARhsvRf<K7)b;0O!eA`2YX_

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/autocompletion.cpython-39.pyc
deleted file mode 100644
index 5bd91fd9253b4308b87b47d6255bec2e41e9d916..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/base_command.cpython-39.pyc
deleted file mode 100644
index b3f214f29cbc78efc695aa019cc97ce97a990923..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5821
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
UYziC@7ASWKF!C_5F>x^i05Y{rN&o-=

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/cmdoptions.cpython-39.pyc
deleted file mode 100644
index 12076cc0043e7bf61c200f413071848f1f2d3d10..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/command_context.cpython-39.pyc
deleted file mode 100644
index c6722b70ee195e4921c901fcde9d50fd6b8d0848..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1249
zcmYe~<>g{vU|^UdaWGY%nStRkh=Yt-7#J8F7#J9eofsGxQW#Pga~N_NqZo6UqL>&#
ze5M@cT$U)7T-GSoT(&4SMut?j6y_9`6xLp*D0X*-6t)!h7KRk|W~L~P6pmm9P0p7f
z(>0lHak^GymIRk1CTHK`OU}<LNv$Z!P0UM7Pc719zQyMZ5%GnH+~V*oNi9k&$uGLa
z9#UD58kSgeizz-NM3eCrXL5d7Vo_#dUP&^@U}Ve;<rEt*FfgPtL@}l?L@~89q%o#2
zrZBZ|L@}qbfSlUG(99Ucn!=jG*1{0Q*3Q7f5XBzMpvitq*f~EpH!&{-=9bI~&%9(t
zsG%SV#Aae(U;tTEEW^OSP{Pp6uz+zP10zEUV+}(*Qwei3Lk&YbOA13UgC>)on<ncm
z*5cBF)S_D)@$s2?nI-Y@w*=xd^Wt+8GxOr1p-==e@)j?O*h<D*EXAogX)76TamL3d
z=Oh*v$H%W^_|@uc6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu5bEa{<{A|28R8hM;OXb$
z@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfOSzMBt9g~_@7UPqd6jPj8lB!#fn4F!M
zo?0AJkXfJ~pP5&ZT9lWVqo16Ush<o96_|7N3Mz}Z85kHiK#7D66f8_!jBJcmGFU=S
z59Vu(U<By~MPP9V0|P@1Ll#33mls15BRCits?2H_vKaftKnX64fsrAcA%%g3frX)&
znUNt+z>uNX#DIYj3?m`3Of?Mg40#+WVA_BI9Q@3FA#R#XMLY})3`M*kf)7Lp!3kjo
z28LTa$PocjPz+Mfz|6(O#>m9T!KlVmrGU*}$l8)Y@dpYA5C*Y9$-@~GI$}`26@&c-
z^3wvQ8pef;!3>&=ewxe(x834R1%)^)h&7pt_(84{fToc6f};Gg%#_rkB2?!Wi83%S
zNP%nu<yr<NE~Y9)Y_3H$oCA~?^AdAY<Ku5}#mDF7r<CS^*gWy^g{6r(5E*b37lC|I
zBmxRDkWIIEp-C}0H76%N9?3BRASIvxE#hQgU|<Ki2o%8_j67^ij9lDcQ9n)2TU<~N
z<zyy-Q$5&%TWlqj1(|v2MIcWUv4V^OC95KkF<_lY7J>Z_vgj6v4aDJgpiEf|(jdSn
I!o<T20NRlz)Bpeg

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/main.cpython-39.pyc
deleted file mode 100644
index 2a1ea13d959aefde891da5e34e74833dcebedcdb..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1349
zcmYe~<>g{vU|^UdaWHi=Cj-M{5C<7EGcYhXFfcF_cQ7z8q%cG=q%fv1<uFDuf@!8G
zCNRw$#SErdqF7QGQ<!sDbJ?QUa@nKU8A0k<ayW81qd38A)*P-}?kH|Bn=OYYmp6(R
z%x2Hw%jJ*a2eUbH1abwV1Q{7pnHC783NK`g5=r4s;Y{IbVT=+@VG3r@<f&2!D9X%D
zEUHvUEGWpyOinDx%+FIu%_}LYEXdEyE79Y63G#)XCetkzpUmQtTO9rcASH=8nvA!2
z5=%?+lk;;6a#BlDH5qU579<uGr^YAe=jJBnrD!tV;!7?{O)Nnc;Rwhqa4jmzFVbYZ
z#hsE`P?QR>GMN!%4HUC6Fff2Z(-{<APZ$^&Y8X-&N*Rj8N*J<0;l<F(B*{?AP{Oo;
zc_9NMLkUYW10zF~KnZINLo;IxQ!QgHQ#eDO9}7bXTV)d?LoG8SLzP(xLl*l2jufUE
z=GhE$nHDlKGC)L1IJ3AQyan7Tj38DxLnK2ALoIV1a~>CjHefJds1hpSS-@Mulf{?9
zypV~JA)F!4h=rkqCyT%G1S3N&3nN37M2Wxx!4#Gn7Kl996qY&`uqiBcEFe=#glZU5
zSZkQd7*g1JnQB>USQiM_FfC*ZX3%8!dkG4JDt6bPApamMg<A|&s-Ee2`9+y|=?bZ!
zFjG)1Rw&O%%~L2&Ehzzs=Hw?Q=A>3}>FQ<{=jSArq=EvS1I`w?#avuje2XQqD7~zR
zgMoqJmRM$9aY<rMPJDS{QC?<VdVEfPdU|S65eowYLlG;8U<WB<D=tY%Eh@UjT3(b{
zl6s3NzxWn=PG(+eacaRWmeh*Ol3Q#Lt8Z}@r<OpOY(CEMjy^uOSi$iNQUNmh7Hdjs
zQfYb-C{Ay&<R)h3X|jP`RD6pgIX5LfFEKY2!b&VkFTTZ`T9JH<G4&QZG!d<2C{ko#
zVE9$#Y!wq)oLW>IlbVx~Srp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2
z?CR?p9O4?JU=|Y);1iQ*qMMVSo>^RynH`gwR~F-wnG{o;S(2(-keHmEn4Vf3Q;=Dp
zAD@|5l3J9Pn4_PZlc^7KtX@H7krV?1gDxm3DuB`_69*$7GY1nJ6BDBVBOjv>BOjvz
z3lpOdqX3f<qW}|FwI-vVrr0g^`1q9k<oNg^5m1=2gMvCUFTF?*6wEvzA-0mr0+0w3
zNCZ?s+)^mWEYO3yLN7TdQx7SRW#;FBW9pVHrZSLY<H7l_2po~O#L(10GG#F&A|y~H
zQ!A2F!P&aF2o(QO!l=@vC7C(JkOah;o?7AqPBXVS;=z#@A73N^az7}Pz;T5{D1m&*
gVUwGmQks)$2TI+=Ahj$^9E=bsz{JA{g-l#>0Binn#sB~S

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/main_parser.cpython-39.pyc
deleted file mode 100644
index 87424e9188b059ff2b0dd1d8a7285af6a210861d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2130
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
KfQf^dLjeFfwo<YH

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/parser.cpython-39.pyc
deleted file mode 100644
index b3ce798f74719f2627fecd76d78d5c0fff11d182..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/progress_bars.cpython-39.pyc
deleted file mode 100644
index 876b8062f01fc20a4763f35b0baedb985488f221..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7466
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
J6#i!81OU2v%cTGS

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/req_command.cpython-39.pyc
deleted file mode 100644
index 98a9806baf04bcc2b17af91728798359eb791a1b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/spinners.cpython-39.pyc
deleted file mode 100644
index c1157315338cbb7d296cd9a545cf70586998bfa0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/cli/__pycache__/status_codes.cpython-39.pyc
deleted file mode 100644
index 603750ba7833106e3d2b6e9315c72062ecacba23..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 379
zcmYe~<>g{vU|^UdaWJ)nfq~&Mh=Yt785kHG7#J9eWf&M3QW&BbQW&EcQ<$QdQkbKd
zQ&^%{Qdpx{Q`mwTG}&K*^t}XWc*(@T!0?h8M6iGeaRvqkKTWn<?7^YV&aT11w^&_+
zg8YMS@rL?&`}v3a#Y4CvVV*%Dp^iSTeqr%`{vq*h{-J&@w<H3BT*Ey5Lxba;LOp$4
z;$1w0py~zu{NsHcL!3QagCS~HG8FMLFhGc3P0m&^p~b01#WATlDVaqv{&}e`MVV!(
z3c3oRex6~jLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbV
zsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$1^V%sc_pbud5Jmt$vK(&#U+U)rN!~d`6;Qz
bdIgoYIBatBQ%ZAE?LeVY3<_x$Mi>MD!%Ss~

diff --git a/env/Lib/site-packages/pip/_internal/cli/autocompletion.py b/env/Lib/site-packages/pip/_internal/cli/autocompletion.py
index 3b1d2ac9..226fe84d 100644
--- a/env/Lib/site-packages/pip/_internal/cli/autocompletion.py
+++ b/env/Lib/site-packages/pip/_internal/cli/autocompletion.py
@@ -9,11 +9,10 @@ from typing import Any, Iterable, List, Optional
 
 from pip._internal.cli.main_parser import create_main_parser
 from pip._internal.commands import commands_dict, create_command
-from pip._internal.utils.misc import get_installed_distributions
+from pip._internal.metadata import get_default_environment
 
 
-def autocomplete():
-    # type: () -> None
+def autocomplete() -> None:
     """Entry Point for completion of main and subcommand options."""
     # Don't complete if user hasn't sourced bash_completion file.
     if "PIP_AUTO_COMPLETE" not in os.environ:
@@ -30,7 +29,7 @@ def autocomplete():
     options = []
 
     # subcommand
-    subcommand_name = None  # type: Optional[str]
+    subcommand_name: Optional[str] = None
     for word in cwords:
         if word in subcommands:
             subcommand_name = word
@@ -46,11 +45,13 @@ def autocomplete():
             "uninstall",
         ]
         if should_list_installed:
+            env = get_default_environment()
             lc = current.lower()
             installed = [
-                dist.key
-                for dist in get_installed_distributions(local_only=True)
-                if dist.key.startswith(lc) and dist.key not in cwords[1:]
+                dist.canonical_name
+                for dist in env.iter_installed_distributions(local_only=True)
+                if dist.canonical_name.startswith(lc)
+                and dist.canonical_name not in cwords[1:]
             ]
             # if there are no dists installed, fall back to option completion
             if installed:
@@ -58,6 +59,14 @@ def autocomplete():
                     print(dist)
                 sys.exit(1)
 
+        should_list_installables = (
+            not current.startswith("-") and subcommand_name == "install"
+        )
+        if should_list_installables:
+            for path in auto_complete_paths(current, "path"):
+                print(path)
+            sys.exit(1)
+
         subcommand = create_command(subcommand_name)
 
         for opt in subcommand.parser.option_list_all:
@@ -107,8 +116,9 @@ def autocomplete():
     sys.exit(1)
 
 
-def get_path_completion_type(cwords, cword, opts):
-    # type: (List[str], int, Iterable[Any]) -> Optional[str]
+def get_path_completion_type(
+    cwords: List[str], cword: int, opts: Iterable[Any]
+) -> Optional[str]:
     """Get the type of path completion (``file``, ``dir``, ``path`` or None)
 
     :param cwords: same as the environmental variable ``COMP_WORDS``
@@ -130,14 +140,13 @@ def get_path_completion_type(cwords, cword, opts):
     return None
 
 
-def auto_complete_paths(current, completion_type):
-    # type: (str, str) -> Iterable[str]
+def auto_complete_paths(current: str, completion_type: str) -> Iterable[str]:
     """If ``completion_type`` is ``file`` or ``path``, list all regular files
     and directories starting with ``current``; otherwise only list directories
     starting with ``current``.
 
     :param current: The word to be completed
-    :param completion_type: path completion type(`file`, `path` or `dir`)i
+    :param completion_type: path completion type(``file``, ``path`` or ``dir``)
     :return: A generator of regular files and/or directories
     """
     directory, filename = os.path.split(current)
diff --git a/env/Lib/site-packages/pip/_internal/cli/base_command.py b/env/Lib/site-packages/pip/_internal/cli/base_command.py
index b59420dd..6a3b8e6c 100644
--- a/env/Lib/site-packages/pip/_internal/cli/base_command.py
+++ b/env/Lib/site-packages/pip/_internal/cli/base_command.py
@@ -1,5 +1,6 @@
 """Base Command class, and related routines"""
 
+import functools
 import logging
 import logging.config
 import optparse
@@ -7,7 +8,9 @@ import os
 import sys
 import traceback
 from optparse import Values
-from typing import Any, List, Optional, Tuple
+from typing import Any, Callable, List, Optional, Tuple
+
+from pip._vendor.rich import traceback as rich_traceback
 
 from pip._internal.cli import cmdoptions
 from pip._internal.cli.command_context import CommandContextMixIn
@@ -21,12 +24,12 @@ from pip._internal.cli.status_codes import (
 from pip._internal.exceptions import (
     BadCommand,
     CommandError,
+    DiagnosticPipError,
     InstallationError,
     NetworkConnectionError,
     PreviousBuildDirError,
     UninstallationError,
 )
-from pip._internal.utils.deprecation import deprecated
 from pip._internal.utils.filesystem import check_path_owner
 from pip._internal.utils.logging import BrokenStdoutLoggingError, setup_logging
 from pip._internal.utils.misc import get_prog, normalize_path
@@ -40,11 +43,10 @@ logger = logging.getLogger(__name__)
 
 
 class Command(CommandContextMixIn):
-    usage = None  # type: str
-    ignore_require_venv = False  # type: bool
+    usage: str = ""
+    ignore_require_venv: bool = False
 
-    def __init__(self, name, summary, isolated=False):
-        # type: (str, str, bool) -> None
+    def __init__(self, name: str, summary: str, isolated: bool = False) -> None:
         super().__init__()
 
         self.name = name
@@ -59,7 +61,7 @@ class Command(CommandContextMixIn):
             isolated=isolated,
         )
 
-        self.tempdir_registry = None  # type: Optional[TempDirRegistry]
+        self.tempdir_registry: Optional[TempDirRegistry] = None
 
         # Commands should add options to this option group
         optgroup_name = f"{self.name.capitalize()} Options"
@@ -74,12 +76,10 @@ class Command(CommandContextMixIn):
 
         self.add_options()
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         pass
 
-    def handle_pip_version_check(self, options):
-        # type: (Values) -> None
+    def handle_pip_version_check(self, options: Values) -> None:
         """
         This is a no-op so that commands by default do not do the pip version
         check.
@@ -88,25 +88,21 @@ class Command(CommandContextMixIn):
         # are present.
         assert not hasattr(options, "no_index")
 
-    def run(self, options, args):
-        # type: (Values, List[Any]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         raise NotImplementedError
 
-    def parse_args(self, args):
-        # type: (List[str]) -> Tuple[Any, Any]
+    def parse_args(self, args: List[str]) -> Tuple[Values, List[str]]:
         # factored out for testability
         return self.parser.parse_args(args)
 
-    def main(self, args):
-        # type: (List[str]) -> int
+    def main(self, args: List[str]) -> int:
         try:
             with self.main_context():
                 return self._main(args)
         finally:
             logging.shutdown()
 
-    def _main(self, args):
-        # type: (List[str]) -> int
+    def _main(self, args: List[str]) -> int:
         # We must initialize this before the tempdir manager, otherwise the
         # configuration would not be accessible by the time we clean up the
         # tempdir manager.
@@ -126,6 +122,26 @@ class Command(CommandContextMixIn):
             user_log_file=options.log,
         )
 
+        always_enabled_features = set(options.features_enabled) & set(
+            cmdoptions.ALWAYS_ENABLED_FEATURES
+        )
+        if always_enabled_features:
+            logger.warning(
+                "The following features are always enabled: %s. ",
+                ", ".join(sorted(always_enabled_features)),
+            )
+
+        # Make sure that the --python argument isn't specified after the
+        # subcommand. We can tell, because if --python was specified,
+        # we should only reach this point if we're running in the created
+        # subprocess, which has the _PIP_RUNNING_IN_SUBPROCESS environment
+        # variable set.
+        if options.python and "_PIP_RUNNING_IN_SUBPROCESS" not in os.environ:
+            logger.critical(
+                "The --python option must be placed before the pip subcommand name"
+            )
+            sys.exit(ERROR)
+
         # TODO: Try to get these passing down from the command?
         #       without resorting to os.environ to hold these.
         #       This also affects isolated builds and it should.
@@ -155,67 +171,66 @@ class Command(CommandContextMixIn):
                 )
                 options.cache_dir = None
 
-        if getattr(options, "build_dir", None):
-            deprecated(
-                reason=(
-                    "The -b/--build/--build-dir/--build-directory "
-                    "option is deprecated and has no effect anymore."
-                ),
-                replacement=(
-                    "use the TMPDIR/TEMP/TMP environment variable, "
-                    "possibly combined with --no-clean"
-                ),
-                gone_in="21.3",
-                issue=8333,
-            )
-
-        if "2020-resolver" in options.features_enabled:
-            logger.warning(
-                "--use-feature=2020-resolver no longer has any effect, "
-                "since it is now the default dependency resolver in pip. "
-                "This will become an error in pip 21.0."
-            )
+        def intercepts_unhandled_exc(
+            run_func: Callable[..., int]
+        ) -> Callable[..., int]:
+            @functools.wraps(run_func)
+            def exc_logging_wrapper(*args: Any) -> int:
+                try:
+                    status = run_func(*args)
+                    assert isinstance(status, int)
+                    return status
+                except DiagnosticPipError as exc:
+                    logger.error("[present-rich] %s", exc)
+                    logger.debug("Exception information:", exc_info=True)
+
+                    return ERROR
+                except PreviousBuildDirError as exc:
+                    logger.critical(str(exc))
+                    logger.debug("Exception information:", exc_info=True)
+
+                    return PREVIOUS_BUILD_DIR_ERROR
+                except (
+                    InstallationError,
+                    UninstallationError,
+                    BadCommand,
+                    NetworkConnectionError,
+                ) as exc:
+                    logger.critical(str(exc))
+                    logger.debug("Exception information:", exc_info=True)
+
+                    return ERROR
+                except CommandError as exc:
+                    logger.critical("%s", exc)
+                    logger.debug("Exception information:", exc_info=True)
+
+                    return ERROR
+                except BrokenStdoutLoggingError:
+                    # Bypass our logger and write any remaining messages to
+                    # stderr because stdout no longer works.
+                    print("ERROR: Pipe to stdout was broken", file=sys.stderr)
+                    if level_number <= logging.DEBUG:
+                        traceback.print_exc(file=sys.stderr)
+
+                    return ERROR
+                except KeyboardInterrupt:
+                    logger.critical("Operation cancelled by user")
+                    logger.debug("Exception information:", exc_info=True)
+
+                    return ERROR
+                except BaseException:
+                    logger.critical("Exception:", exc_info=True)
+
+                    return UNKNOWN_ERROR
+
+            return exc_logging_wrapper
 
         try:
-            status = self.run(options, args)
-            assert isinstance(status, int)
-            return status
-        except PreviousBuildDirError as exc:
-            logger.critical(str(exc))
-            logger.debug("Exception information:", exc_info=True)
-
-            return PREVIOUS_BUILD_DIR_ERROR
-        except (
-            InstallationError,
-            UninstallationError,
-            BadCommand,
-            NetworkConnectionError,
-        ) as exc:
-            logger.critical(str(exc))
-            logger.debug("Exception information:", exc_info=True)
-
-            return ERROR
-        except CommandError as exc:
-            logger.critical("%s", exc)
-            logger.debug("Exception information:", exc_info=True)
-
-            return ERROR
-        except BrokenStdoutLoggingError:
-            # Bypass our logger and write any remaining messages to stderr
-            # because stdout no longer works.
-            print("ERROR: Pipe to stdout was broken", file=sys.stderr)
-            if level_number <= logging.DEBUG:
-                traceback.print_exc(file=sys.stderr)
-
-            return ERROR
-        except KeyboardInterrupt:
-            logger.critical("Operation cancelled by user")
-            logger.debug("Exception information:", exc_info=True)
-
-            return ERROR
-        except BaseException:
-            logger.critical("Exception:", exc_info=True)
-
-            return UNKNOWN_ERROR
+            if not options.debug_mode:
+                run = intercepts_unhandled_exc(self.run)
+            else:
+                run = self.run
+                rich_traceback.install(show_locals=True)
+            return run(options, args)
         finally:
             self.handle_pip_version_check(options)
diff --git a/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py b/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py
index f71c0b02..02ba6082 100644
--- a/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py
+++ b/env/Lib/site-packages/pip/_internal/cli/cmdoptions.py
@@ -10,9 +10,10 @@ pass on state. To be consistent, all options will follow this design.
 # The following comment should be removed at some point in the future.
 # mypy: strict-optional=False
 
+import importlib.util
+import logging
 import os
 import textwrap
-import warnings
 from functools import partial
 from optparse import SUPPRESS_HELP, Option, OptionGroup, OptionParser, Values
 from textwrap import dedent
@@ -21,7 +22,6 @@ from typing import Any, Callable, Dict, Optional, Tuple
 from pip._vendor.packaging.utils import canonicalize_name
 
 from pip._internal.cli.parser import ConfigOptionParser
-from pip._internal.cli.progress_bars import BAR_TYPES
 from pip._internal.exceptions import CommandError
 from pip._internal.locations import USER_CACHE_DIR, get_src_prefix
 from pip._internal.models.format_control import FormatControl
@@ -30,9 +30,10 @@ from pip._internal.models.target_python import TargetPython
 from pip._internal.utils.hashes import STRONG_HASHES
 from pip._internal.utils.misc import strtobool
 
+logger = logging.getLogger(__name__)
 
-def raise_option_error(parser, option, msg):
-    # type: (OptionParser, Option, str) -> None
+
+def raise_option_error(parser: OptionParser, option: Option, msg: str) -> None:
     """
     Raise an option parsing error using parser.error().
 
@@ -46,8 +47,7 @@ def raise_option_error(parser, option, msg):
     parser.error(msg)
 
 
-def make_option_group(group, parser):
-    # type: (Dict[str, Any], ConfigOptionParser) -> OptionGroup
+def make_option_group(group: Dict[str, Any], parser: ConfigOptionParser) -> OptionGroup:
     """
     Return an OptionGroup object
     group  -- assumed to be dict with 'name' and 'options' keys
@@ -59,34 +59,7 @@ def make_option_group(group, parser):
     return option_group
 
 
-def check_install_build_global(options, check_options=None):
-    # type: (Values, Optional[Values]) -> None
-    """Disable wheels if per-setup.py call options are set.
-
-    :param options: The OptionParser options to update.
-    :param check_options: The options to check, if not supplied defaults to
-        options.
-    """
-    if check_options is None:
-        check_options = options
-
-    def getname(n):
-        # type: (str) -> Optional[Any]
-        return getattr(check_options, n, None)
-
-    names = ["build_options", "global_options", "install_options"]
-    if any(map(getname, names)):
-        control = options.format_control
-        control.disallow_binaries()
-        warnings.warn(
-            "Disabling all use of wheels due to the use of --build-option "
-            "/ --global-option / --install-option.",
-            stacklevel=2,
-        )
-
-
-def check_dist_restriction(options, check_target=False):
-    # type: (Values, bool) -> None
+def check_dist_restriction(options: Values, check_target: bool = False) -> None:
     """Function for determining if custom platform options are allowed.
 
     :param options: The OptionParser options.
@@ -126,13 +99,11 @@ def check_dist_restriction(options, check_target=False):
             )
 
 
-def _path_option_check(option, opt, value):
-    # type: (Option, str, str) -> str
+def _path_option_check(option: Option, opt: str, value: str) -> str:
     return os.path.expanduser(value)
 
 
-def _package_name_option_check(option, opt, value):
-    # type: (Option, str, str) -> str
+def _package_name_option_check(option: Option, opt: str, value: str) -> str:
     return canonicalize_name(value)
 
 
@@ -147,16 +118,28 @@ class PipOption(Option):
 # options #
 ###########
 
-help_ = partial(
+help_: Callable[..., Option] = partial(
     Option,
     "-h",
     "--help",
     dest="help",
     action="help",
     help="Show help.",
-)  # type: Callable[..., Option]
+)
+
+debug_mode: Callable[..., Option] = partial(
+    Option,
+    "--debug",
+    dest="debug_mode",
+    action="store_true",
+    default=False,
+    help=(
+        "Let unhandled exceptions propagate outside the main subroutine, "
+        "instead of logging them to stderr."
+    ),
+)
 
-isolated_mode = partial(
+isolated_mode: Callable[..., Option] = partial(
     Option,
     "--isolated",
     dest="isolated_mode",
@@ -166,20 +149,37 @@ isolated_mode = partial(
         "Run pip in an isolated mode, ignoring environment variables and user "
         "configuration."
     ),
-)  # type: Callable[..., Option]
+)
 
-require_virtualenv = partial(
+require_virtualenv: Callable[..., Option] = partial(
     Option,
-    # Run only if inside a virtualenv, bail if not.
     "--require-virtualenv",
     "--require-venv",
     dest="require_venv",
     action="store_true",
     default=False,
-    help=SUPPRESS_HELP,
-)  # type: Callable[..., Option]
+    help=(
+        "Allow pip to only run in a virtual environment; "
+        "exit with an error otherwise."
+    ),
+)
+
+override_externally_managed: Callable[..., Option] = partial(
+    Option,
+    "--break-system-packages",
+    dest="override_externally_managed",
+    action="store_true",
+    help="Allow pip to modify an EXTERNALLY-MANAGED Python installation",
+)
 
-verbose = partial(
+python: Callable[..., Option] = partial(
+    Option,
+    "--python",
+    dest="python",
+    help="Run pip with the specified Python interpreter.",
+)
+
+verbose: Callable[..., Option] = partial(
     Option,
     "-v",
     "--verbose",
@@ -187,27 +187,27 @@ verbose = partial(
     action="count",
     default=0,
     help="Give more output. Option is additive, and can be used up to 3 times.",
-)  # type: Callable[..., Option]
+)
 
-no_color = partial(
+no_color: Callable[..., Option] = partial(
     Option,
     "--no-color",
     dest="no_color",
     action="store_true",
     default=False,
     help="Suppress colored output.",
-)  # type: Callable[..., Option]
+)
 
-version = partial(
+version: Callable[..., Option] = partial(
     Option,
     "-V",
     "--version",
     dest="version",
     action="store_true",
     help="Show version and exit.",
-)  # type: Callable[..., Option]
+)
 
-quiet = partial(
+quiet: Callable[..., Option] = partial(
     Option,
     "-q",
     "--quiet",
@@ -219,23 +219,19 @@ quiet = partial(
         " times (corresponding to WARNING, ERROR, and CRITICAL logging"
         " levels)."
     ),
-)  # type: Callable[..., Option]
+)
 
-progress_bar = partial(
+progress_bar: Callable[..., Option] = partial(
     Option,
     "--progress-bar",
     dest="progress_bar",
     type="choice",
-    choices=list(BAR_TYPES.keys()),
+    choices=["on", "off"],
     default="on",
-    help=(
-        "Specify type of progress to be displayed ["
-        + "|".join(BAR_TYPES.keys())
-        + "] (default: %default)"
-    ),
-)  # type: Callable[..., Option]
+    help="Specify whether the progress bar should be used [on, off] (default: on)",
+)
 
-log = partial(
+log: Callable[..., Option] = partial(
     PipOption,
     "--log",
     "--log-file",
@@ -244,9 +240,9 @@ log = partial(
     metavar="path",
     type="path",
     help="Path to a verbose appending log.",
-)  # type: Callable[..., Option]
+)
 
-no_input = partial(
+no_input: Callable[..., Option] = partial(
     Option,
     # Don't ask for input
     "--no-input",
@@ -254,18 +250,31 @@ no_input = partial(
     action="store_true",
     default=False,
     help="Disable prompting for input.",
-)  # type: Callable[..., Option]
+)
+
+keyring_provider: Callable[..., Option] = partial(
+    Option,
+    "--keyring-provider",
+    dest="keyring_provider",
+    choices=["auto", "disabled", "import", "subprocess"],
+    default="auto",
+    help=(
+        "Enable the credential lookup via the keyring library if user input is allowed."
+        " Specify which mechanism to use [disabled, import, subprocess]."
+        " (default: disabled)"
+    ),
+)
 
-proxy = partial(
+proxy: Callable[..., Option] = partial(
     Option,
     "--proxy",
     dest="proxy",
     type="str",
     default="",
-    help="Specify a proxy in the form [user:passwd@]proxy.server:port.",
-)  # type: Callable[..., Option]
+    help="Specify a proxy in the form scheme://[user:passwd@]proxy.server:port.",
+)
 
-retries = partial(
+retries: Callable[..., Option] = partial(
     Option,
     "--retries",
     dest="retries",
@@ -273,9 +282,9 @@ retries = partial(
     default=5,
     help="Maximum number of retries each connection should attempt "
     "(default %default times).",
-)  # type: Callable[..., Option]
+)
 
-timeout = partial(
+timeout: Callable[..., Option] = partial(
     Option,
     "--timeout",
     "--default-timeout",
@@ -284,11 +293,10 @@ timeout = partial(
     type="float",
     default=15,
     help="Set the socket timeout (default %default seconds).",
-)  # type: Callable[..., Option]
+)
 
 
-def exists_action():
-    # type: () -> Option
+def exists_action() -> Option:
     return Option(
         # Option when path already exist
         "--exists-action",
@@ -303,7 +311,7 @@ def exists_action():
     )
 
 
-cert = partial(
+cert: Callable[..., Option] = partial(
     PipOption,
     "--cert",
     dest="cert",
@@ -315,9 +323,9 @@ cert = partial(
         "See 'SSL Certificate Verification' in pip documentation "
         "for more information."
     ),
-)  # type: Callable[..., Option]
+)
 
-client_cert = partial(
+client_cert: Callable[..., Option] = partial(
     PipOption,
     "--client-cert",
     dest="client_cert",
@@ -326,9 +334,9 @@ client_cert = partial(
     metavar="path",
     help="Path to SSL client certificate, a single file containing the "
     "private key and the certificate in PEM format.",
-)  # type: Callable[..., Option]
+)
 
-index_url = partial(
+index_url: Callable[..., Option] = partial(
     Option,
     "-i",
     "--index-url",
@@ -340,11 +348,10 @@ index_url = partial(
     "This should point to a repository compliant with PEP 503 "
     "(the simple repository API) or a local directory laid out "
     "in the same format.",
-)  # type: Callable[..., Option]
+)
 
 
-def extra_index_url():
-    # type: () -> Option
+def extra_index_url() -> Option:
     return Option(
         "--extra-index-url",
         dest="extra_index_urls",
@@ -357,18 +364,17 @@ def extra_index_url():
     )
 
 
-no_index = partial(
+no_index: Callable[..., Option] = partial(
     Option,
     "--no-index",
     dest="no_index",
     action="store_true",
     default=False,
     help="Ignore package index (only looking at --find-links URLs instead).",
-)  # type: Callable[..., Option]
+)
 
 
-def find_links():
-    # type: () -> Option
+def find_links() -> Option:
     return Option(
         "-f",
         "--find-links",
@@ -378,14 +384,13 @@ def find_links():
         metavar="url",
         help="If a URL or path to an html file, then parse for links to "
         "archives such as sdist (.tar.gz) or wheel (.whl) files. "
-        "If a local path or file:// URL that's a directory,  "
+        "If a local path or file:// URL that's a directory, "
         "then look for archives in the directory listing. "
         "Links to VCS project URLs are not supported.",
     )
 
 
-def trusted_host():
-    # type: () -> Option
+def trusted_host() -> Option:
     return Option(
         "--trusted-host",
         dest="trusted_hosts",
@@ -397,8 +402,7 @@ def trusted_host():
     )
 
 
-def constraints():
-    # type: () -> Option
+def constraints() -> Option:
     return Option(
         "-c",
         "--constraint",
@@ -411,8 +415,7 @@ def constraints():
     )
 
 
-def requirements():
-    # type: () -> Option
+def requirements() -> Option:
     return Option(
         "-r",
         "--requirement",
@@ -425,8 +428,7 @@ def requirements():
     )
 
 
-def editable():
-    # type: () -> Option
+def editable() -> Option:
     return Option(
         "-e",
         "--editable",
@@ -441,13 +443,12 @@ def editable():
     )
 
 
-def _handle_src(option, opt_str, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_src(option: Option, opt_str: str, value: str, parser: OptionParser) -> None:
     value = os.path.abspath(value)
     setattr(parser.values, option.dest, value)
 
 
-src = partial(
+src: Callable[..., Option] = partial(
     PipOption,
     "--src",
     "--source",
@@ -462,17 +463,17 @@ src = partial(
     help="Directory to check out editable projects into. "
     'The default in a virtualenv is "<venv path>/src". '
     'The default for global installs is "<current dir>/src".',
-)  # type: Callable[..., Option]
+)
 
 
-def _get_format_control(values, option):
-    # type: (Values, Option) -> Any
+def _get_format_control(values: Values, option: Option) -> Any:
     """Get a format_control object."""
     return getattr(values, option.dest)
 
 
-def _handle_no_binary(option, opt_str, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_no_binary(
+    option: Option, opt_str: str, value: str, parser: OptionParser
+) -> None:
     existing = _get_format_control(parser.values, option)
     FormatControl.handle_mutual_excludes(
         value,
@@ -481,8 +482,9 @@ def _handle_no_binary(option, opt_str, value, parser):
     )
 
 
-def _handle_only_binary(option, opt_str, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_only_binary(
+    option: Option, opt_str: str, value: str, parser: OptionParser
+) -> None:
     existing = _get_format_control(parser.values, option)
     FormatControl.handle_mutual_excludes(
         value,
@@ -491,8 +493,7 @@ def _handle_only_binary(option, opt_str, value, parser):
     )
 
 
-def no_binary():
-    # type: () -> Option
+def no_binary() -> Option:
     format_control = FormatControl(set(), set())
     return Option(
         "--no-binary",
@@ -510,8 +511,7 @@ def no_binary():
     )
 
 
-def only_binary():
-    # type: () -> Option
+def only_binary() -> Option:
     format_control = FormatControl(set(), set())
     return Option(
         "--only-binary",
@@ -529,7 +529,7 @@ def only_binary():
     )
 
 
-platforms = partial(
+platforms: Callable[..., Option] = partial(
     Option,
     "--platform",
     dest="platforms",
@@ -541,12 +541,11 @@ platforms = partial(
         "platform of the running system. Use this option multiple times to "
         "specify multiple platforms supported by the target interpreter."
     ),
-)  # type: Callable[..., Option]
+)
 
 
 # This was made a separate function for unit-testing purposes.
-def _convert_python_version(value):
-    # type: (str) -> Tuple[Tuple[int, ...], Optional[str]]
+def _convert_python_version(value: str) -> Tuple[Tuple[int, ...], Optional[str]]:
     """
     Convert a version string like "3", "37", or "3.7.3" into a tuple of ints.
 
@@ -575,8 +574,9 @@ def _convert_python_version(value):
     return (version_info, None)
 
 
-def _handle_python_version(option, opt_str, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_python_version(
+    option: Option, opt_str: str, value: str, parser: OptionParser
+) -> None:
     """
     Handle a provided --python-version value.
     """
@@ -591,7 +591,7 @@ def _handle_python_version(option, opt_str, value, parser):
     parser.values.python_version = version_info
 
 
-python_version = partial(
+python_version: Callable[..., Option] = partial(
     Option,
     "--python-version",
     dest="python_version",
@@ -609,10 +609,10 @@ python_version = partial(
     version can also be given as a string without dots (e.g. "37" for 3.7.0).
     """
     ),
-)  # type: Callable[..., Option]
+)
 
 
-implementation = partial(
+implementation: Callable[..., Option] = partial(
     Option,
     "--implementation",
     dest="implementation",
@@ -625,10 +625,10 @@ implementation = partial(
         "interpreter implementation is used.  Use 'py' to force "
         "implementation-agnostic wheels."
     ),
-)  # type: Callable[..., Option]
+)
 
 
-abis = partial(
+abis: Callable[..., Option] = partial(
     Option,
     "--abi",
     dest="abis",
@@ -643,19 +643,17 @@ abis = partial(
         "--implementation, --platform, and --python-version when using this "
         "option."
     ),
-)  # type: Callable[..., Option]
+)
 
 
-def add_target_python_options(cmd_opts):
-    # type: (OptionGroup) -> None
+def add_target_python_options(cmd_opts: OptionGroup) -> None:
     cmd_opts.add_option(platforms())
     cmd_opts.add_option(python_version())
     cmd_opts.add_option(implementation())
     cmd_opts.add_option(abis())
 
 
-def make_target_python(options):
-    # type: (Values) -> TargetPython
+def make_target_python(options: Values) -> TargetPython:
     target_python = TargetPython(
         platforms=options.platforms,
         py_version_info=options.python_version,
@@ -666,8 +664,7 @@ def make_target_python(options):
     return target_python
 
 
-def prefer_binary():
-    # type: () -> Option
+def prefer_binary() -> Option:
     return Option(
         "--prefer-binary",
         dest="prefer_binary",
@@ -677,7 +674,7 @@ def prefer_binary():
     )
 
 
-cache_dir = partial(
+cache_dir: Callable[..., Option] = partial(
     PipOption,
     "--cache-dir",
     dest="cache_dir",
@@ -685,11 +682,12 @@ cache_dir = partial(
     metavar="dir",
     type="path",
     help="Store the cache data in <dir>.",
-)  # type: Callable[..., Option]
+)
 
 
-def _handle_no_cache_dir(option, opt, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_no_cache_dir(
+    option: Option, opt: str, value: str, parser: OptionParser
+) -> None:
     """
     Process a value provided for the --no-cache-dir option.
 
@@ -716,16 +714,16 @@ def _handle_no_cache_dir(option, opt, value, parser):
     parser.values.cache_dir = False
 
 
-no_cache = partial(
+no_cache: Callable[..., Option] = partial(
     Option,
     "--no-cache-dir",
     dest="cache_dir",
     action="callback",
     callback=_handle_no_cache_dir,
     help="Disable the cache.",
-)  # type: Callable[..., Option]
+)
 
-no_deps = partial(
+no_deps: Callable[..., Option] = partial(
     Option,
     "--no-deps",
     "--no-dependencies",
@@ -733,29 +731,17 @@ no_deps = partial(
     action="store_true",
     default=False,
     help="Don't install package dependencies.",
-)  # type: Callable[..., Option]
-
-build_dir = partial(
-    PipOption,
-    "-b",
-    "--build",
-    "--build-dir",
-    "--build-directory",
-    dest="build_dir",
-    type="path",
-    metavar="dir",
-    help=SUPPRESS_HELP,
-)  # type: Callable[..., Option]
+)
 
-ignore_requires_python = partial(
+ignore_requires_python: Callable[..., Option] = partial(
     Option,
     "--ignore-requires-python",
     dest="ignore_requires_python",
     action="store_true",
     help="Ignore the Requires-Python information.",
-)  # type: Callable[..., Option]
+)
 
-no_build_isolation = partial(
+no_build_isolation: Callable[..., Option] = partial(
     Option,
     "--no-build-isolation",
     dest="build_isolation",
@@ -764,11 +750,21 @@ no_build_isolation = partial(
     help="Disable isolation when building a modern source distribution. "
     "Build dependencies specified by PEP 518 must be already installed "
     "if this option is used.",
-)  # type: Callable[..., Option]
+)
+
+check_build_deps: Callable[..., Option] = partial(
+    Option,
+    "--check-build-dependencies",
+    dest="check_build_deps",
+    action="store_true",
+    default=False,
+    help="Check the build dependencies when PEP517 is used.",
+)
 
 
-def _handle_no_use_pep517(option, opt, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_no_use_pep517(
+    option: Option, opt: str, value: str, parser: OptionParser
+) -> None:
     """
     Process a value provided for the --no-use-pep517 option.
 
@@ -787,11 +783,21 @@ def _handle_no_use_pep517(option, opt, value, parser):
         """
         raise_option_error(parser, option=option, msg=msg)
 
+    # If user doesn't wish to use pep517, we check if setuptools and wheel are installed
+    # and raise error if it is not.
+    packages = ("setuptools", "wheel")
+    if not all(importlib.util.find_spec(package) for package in packages):
+        msg = (
+            f"It is not possible to use --no-use-pep517 "
+            f"without {' and '.join(packages)} installed."
+        )
+        raise_option_error(parser, option=option, msg=msg)
+
     # Otherwise, --no-use-pep517 was passed via the command-line.
     parser.values.use_pep517 = False
 
 
-use_pep517 = partial(
+use_pep517: Any = partial(
     Option,
     "--use-pep517",
     dest="use_pep517",
@@ -799,9 +805,9 @@ use_pep517 = partial(
     default=None,
     help="Use PEP 517 for building source distributions "
     "(use --no-use-pep517 to force legacy behaviour).",
-)  # type: Any
+)
 
-no_use_pep517 = partial(
+no_use_pep517: Any = partial(
     Option,
     "--no-use-pep517",
     dest="use_pep517",
@@ -809,31 +815,52 @@ no_use_pep517 = partial(
     callback=_handle_no_use_pep517,
     default=None,
     help=SUPPRESS_HELP,
-)  # type: Any
-
-install_options = partial(
+)
+
+
+def _handle_config_settings(
+    option: Option, opt_str: str, value: str, parser: OptionParser
+) -> None:
+    key, sep, val = value.partition("=")
+    if sep != "=":
+        parser.error(f"Arguments to {opt_str} must be of the form KEY=VAL")  # noqa
+    dest = getattr(parser.values, option.dest)
+    if dest is None:
+        dest = {}
+        setattr(parser.values, option.dest, dest)
+    if key in dest:
+        if isinstance(dest[key], list):
+            dest[key].append(val)
+        else:
+            dest[key] = [dest[key], val]
+    else:
+        dest[key] = val
+
+
+config_settings: Callable[..., Option] = partial(
     Option,
-    "--install-option",
-    dest="install_options",
-    action="append",
-    metavar="options",
-    help="Extra arguments to be supplied to the setup.py install "
-    'command (use like --install-option="--install-scripts=/usr/local/'
-    'bin"). Use multiple --install-option options to pass multiple '
-    "options to setup.py install. If you are using an option with a "
-    "directory path, be sure to use absolute path.",
-)  # type: Callable[..., Option]
-
-build_options = partial(
+    "-C",
+    "--config-settings",
+    dest="config_settings",
+    type=str,
+    action="callback",
+    callback=_handle_config_settings,
+    metavar="settings",
+    help="Configuration settings to be passed to the PEP 517 build backend. "
+    "Settings take the form KEY=VALUE. Use multiple --config-settings options "
+    "to pass multiple keys to the backend.",
+)
+
+build_options: Callable[..., Option] = partial(
     Option,
     "--build-option",
     dest="build_options",
     metavar="options",
     action="append",
     help="Extra arguments to be supplied to 'setup.py bdist_wheel'.",
-)  # type: Callable[..., Option]
+)
 
-global_options = partial(
+global_options: Callable[..., Option] = partial(
     Option,
     "--global-option",
     dest="global_options",
@@ -841,26 +868,26 @@ global_options = partial(
     metavar="options",
     help="Extra global options to be supplied to the setup.py "
     "call before the install or bdist_wheel command.",
-)  # type: Callable[..., Option]
+)
 
-no_clean = partial(
+no_clean: Callable[..., Option] = partial(
     Option,
     "--no-clean",
     action="store_true",
     default=False,
     help="Don't clean up build directories.",
-)  # type: Callable[..., Option]
+)
 
-pre = partial(
+pre: Callable[..., Option] = partial(
     Option,
     "--pre",
     action="store_true",
     default=False,
     help="Include pre-release and development versions. By default, "
     "pip only finds stable versions.",
-)  # type: Callable[..., Option]
+)
 
-disable_pip_version_check = partial(
+disable_pip_version_check: Callable[..., Option] = partial(
     Option,
     "--disable-pip-version-check",
     dest="disable_pip_version_check",
@@ -868,11 +895,21 @@ disable_pip_version_check = partial(
     default=False,
     help="Don't periodically check PyPI to determine whether a new version "
     "of pip is available for download. Implied with --no-index.",
-)  # type: Callable[..., Option]
+)
+
+root_user_action: Callable[..., Option] = partial(
+    Option,
+    "--root-user-action",
+    dest="root_user_action",
+    default="warn",
+    choices=["warn", "ignore"],
+    help="Action if pip is run as a root user. By default, a warning message is shown.",
+)
 
 
-def _handle_merge_hash(option, opt_str, value, parser):
-    # type: (Option, str, str, OptionParser) -> None
+def _handle_merge_hash(
+    option: Option, opt_str: str, value: str, parser: OptionParser
+) -> None:
     """Given a value spelled "algo:digest", append the digest to a list
     pointed to in a dict by the algo name."""
     if not parser.values.hashes:
@@ -894,7 +931,7 @@ def _handle_merge_hash(option, opt_str, value, parser):
     parser.values.hashes.setdefault(algo, []).append(digest)
 
 
-hash = partial(
+hash: Callable[..., Option] = partial(
     Option,
     "--hash",
     # Hash values eventually end up in InstallRequirement.hashes due to
@@ -905,10 +942,10 @@ hash = partial(
     type="string",
     help="Verify that the package's archive matches this "
     "hash before installing. Example: --hash=sha256:abcdef...",
-)  # type: Callable[..., Option]
+)
 
 
-require_hashes = partial(
+require_hashes: Callable[..., Option] = partial(
     Option,
     "--require-hashes",
     dest="require_hashes",
@@ -917,10 +954,10 @@ require_hashes = partial(
     help="Require a hash to check each requirement against, for "
     "repeatable installs. This option is implied when any package in a "
     "requirements file has a --hash option.",
-)  # type: Callable[..., Option]
+)
 
 
-list_path = partial(
+list_path: Callable[..., Option] = partial(
     PipOption,
     "--path",
     dest="path",
@@ -928,16 +965,15 @@ list_path = partial(
     action="append",
     help="Restrict to the specified installation path for listing "
     "packages (can be used multiple times).",
-)  # type: Callable[..., Option]
+)
 
 
-def check_list_path_option(options):
-    # type: (Values) -> None
+def check_list_path_option(options: Values) -> None:
     if options.path and (options.user or options.local):
         raise CommandError("Cannot combine '--path' with '--user' or '--local'")
 
 
-list_exclude = partial(
+list_exclude: Callable[..., Option] = partial(
     PipOption,
     "--exclude",
     dest="excludes",
@@ -945,57 +981,71 @@ list_exclude = partial(
     metavar="package",
     type="package_name",
     help="Exclude specified package from the output",
-)  # type: Callable[..., Option]
+)
 
 
-no_python_version_warning = partial(
+no_python_version_warning: Callable[..., Option] = partial(
     Option,
     "--no-python-version-warning",
     dest="no_python_version_warning",
     action="store_true",
     default=False,
     help="Silence deprecation warnings for upcoming unsupported Pythons.",
-)  # type: Callable[..., Option]
+)
 
 
-use_new_feature = partial(
+# Features that are now always on. A warning is printed if they are used.
+ALWAYS_ENABLED_FEATURES = [
+    "no-binary-enable-wheel-cache",  # always on since 23.1
+]
+
+use_new_feature: Callable[..., Option] = partial(
     Option,
     "--use-feature",
     dest="features_enabled",
     metavar="feature",
     action="append",
     default=[],
-    choices=["2020-resolver", "fast-deps", "in-tree-build"],
+    choices=[
+        "fast-deps",
+        "truststore",
+    ]
+    + ALWAYS_ENABLED_FEATURES,
     help="Enable new functionality, that may be backward incompatible.",
-)  # type: Callable[..., Option]
+)
 
-use_deprecated_feature = partial(
+use_deprecated_feature: Callable[..., Option] = partial(
     Option,
     "--use-deprecated",
     dest="deprecated_features_enabled",
     metavar="feature",
     action="append",
     default=[],
-    choices=["legacy-resolver"],
+    choices=[
+        "legacy-resolver",
+    ],
     help=("Enable deprecated functionality, that will be removed in the future."),
-)  # type: Callable[..., Option]
+)
 
 
 ##########
 # groups #
 ##########
 
-general_group = {
+general_group: Dict[str, Any] = {
     "name": "General Options",
     "options": [
         help_,
+        debug_mode,
         isolated_mode,
         require_virtualenv,
+        python,
         verbose,
         version,
         quiet,
         log,
         no_input,
+        keyring_provider,
         proxy,
         retries,
         timeout,
@@ -1011,9 +1061,9 @@ general_group = {
         use_new_feature,
         use_deprecated_feature,
     ],
-}  # type: Dict[str, Any]
+}
 
-index_group = {
+index_group: Dict[str, Any] = {
     "name": "Package Index Options",
     "options": [
         index_url,
@@ -1021,4 +1071,4 @@ index_group = {
         no_index,
         find_links,
     ],
-}  # type: Dict[str, Any]
+}
diff --git a/env/Lib/site-packages/pip/_internal/cli/command_context.py b/env/Lib/site-packages/pip/_internal/cli/command_context.py
index 375a2e36..139995ac 100644
--- a/env/Lib/site-packages/pip/_internal/cli/command_context.py
+++ b/env/Lib/site-packages/pip/_internal/cli/command_context.py
@@ -1,19 +1,17 @@
 from contextlib import ExitStack, contextmanager
-from typing import ContextManager, Iterator, TypeVar
+from typing import ContextManager, Generator, TypeVar
 
 _T = TypeVar("_T", covariant=True)
 
 
 class CommandContextMixIn:
-    def __init__(self):
-        # type: () -> None
+    def __init__(self) -> None:
         super().__init__()
         self._in_main_context = False
         self._main_context = ExitStack()
 
     @contextmanager
-    def main_context(self):
-        # type: () -> Iterator[None]
+    def main_context(self) -> Generator[None, None, None]:
         assert not self._in_main_context
 
         self._in_main_context = True
@@ -23,8 +21,7 @@ class CommandContextMixIn:
         finally:
             self._in_main_context = False
 
-    def enter_context(self, context_provider):
-        # type: (ContextManager[_T]) -> _T
+    def enter_context(self, context_provider: ContextManager[_T]) -> _T:
         assert self._in_main_context
 
         return self._main_context.enter_context(context_provider)
diff --git a/env/Lib/site-packages/pip/_internal/cli/main.py b/env/Lib/site-packages/pip/_internal/cli/main.py
index 7ae074b5..7e061f5b 100644
--- a/env/Lib/site-packages/pip/_internal/cli/main.py
+++ b/env/Lib/site-packages/pip/_internal/cli/main.py
@@ -4,6 +4,7 @@ import locale
 import logging
 import os
 import sys
+import warnings
 from typing import List, Optional
 
 from pip._internal.cli.autocompletion import autocomplete
@@ -42,11 +43,18 @@ logger = logging.getLogger(__name__)
 # main, this should not be an issue in practice.
 
 
-def main(args=None):
-    # type: (Optional[List[str]]) -> int
+def main(args: Optional[List[str]] = None) -> int:
     if args is None:
         args = sys.argv[1:]
 
+    # Suppress the pkg_resources deprecation warning
+    # Note - we use a module of .*pkg_resources to cover
+    # the normal case (pip._vendor.pkg_resources) and the
+    # devendored case (a bare pkg_resources)
+    warnings.filterwarnings(
+        action="ignore", category=DeprecationWarning, module=".*pkg_resources"
+    )
+
     # Configure our deprecation warnings to be sent through loggers
     deprecation.install_warning_logger()
 
diff --git a/env/Lib/site-packages/pip/_internal/cli/main_parser.py b/env/Lib/site-packages/pip/_internal/cli/main_parser.py
index d0f58fe4..5ade356b 100644
--- a/env/Lib/site-packages/pip/_internal/cli/main_parser.py
+++ b/env/Lib/site-packages/pip/_internal/cli/main_parser.py
@@ -2,9 +2,11 @@
 """
 
 import os
+import subprocess
 import sys
-from typing import List, Tuple
+from typing import List, Optional, Tuple
 
+from pip._internal.build_env import get_runnable_pip
 from pip._internal.cli import cmdoptions
 from pip._internal.cli.parser import ConfigOptionParser, UpdatingDefaultsHelpFormatter
 from pip._internal.commands import commands_dict, get_similar_commands
@@ -14,8 +16,7 @@ from pip._internal.utils.misc import get_pip_version, get_prog
 __all__ = ["create_main_parser", "parse_command"]
 
 
-def create_main_parser():
-    # type: () -> ConfigOptionParser
+def create_main_parser() -> ConfigOptionParser:
     """Creates and returns the main parser for pip's CLI"""
 
     parser = ConfigOptionParser(
@@ -46,8 +47,26 @@ def create_main_parser():
     return parser
 
 
-def parse_command(args):
-    # type: (List[str]) -> Tuple[str, List[str]]
+def identify_python_interpreter(python: str) -> Optional[str]:
+    # If the named file exists, use it.
+    # If it's a directory, assume it's a virtual environment and
+    # look for the environment's Python executable.
+    if os.path.exists(python):
+        if os.path.isdir(python):
+            # bin/python for Unix, Scripts/python.exe for Windows
+            # Try both in case of odd cases like cygwin.
+            for exe in ("bin/python", "Scripts/python.exe"):
+                py = os.path.join(python, exe)
+                if os.path.exists(py):
+                    return py
+        else:
+            return python
+
+    # Could not find the interpreter specified
+    return None
+
+
+def parse_command(args: List[str]) -> Tuple[str, List[str]]:
     parser = create_main_parser()
 
     # Note: parser calls disable_interspersed_args(), so the result of this
@@ -59,6 +78,32 @@ def parse_command(args):
     #  args_else: ['install', '--user', 'INITools']
     general_options, args_else = parser.parse_args(args)
 
+    # --python
+    if general_options.python and "_PIP_RUNNING_IN_SUBPROCESS" not in os.environ:
+        # Re-invoke pip using the specified Python interpreter
+        interpreter = identify_python_interpreter(general_options.python)
+        if interpreter is None:
+            raise CommandError(
+                f"Could not locate Python interpreter {general_options.python}"
+            )
+
+        pip_cmd = [
+            interpreter,
+            get_runnable_pip(),
+        ]
+        pip_cmd.extend(args)
+
+        # Set a flag so the child doesn't re-invoke itself, causing
+        # an infinite loop.
+        os.environ["_PIP_RUNNING_IN_SUBPROCESS"] = "1"
+        returncode = 0
+        try:
+            proc = subprocess.run(pip_cmd)
+            returncode = proc.returncode
+        except (subprocess.SubprocessError, OSError) as exc:
+            raise CommandError(f"Failed to run pip under {interpreter}: {exc}")
+        sys.exit(returncode)
+
     # --version
     if general_options.version:
         sys.stdout.write(parser.version)
diff --git a/env/Lib/site-packages/pip/_internal/cli/parser.py b/env/Lib/site-packages/pip/_internal/cli/parser.py
index 16523c5a..c762cf27 100644
--- a/env/Lib/site-packages/pip/_internal/cli/parser.py
+++ b/env/Lib/site-packages/pip/_internal/cli/parser.py
@@ -6,7 +6,7 @@ import shutil
 import sys
 import textwrap
 from contextlib import suppress
-from typing import Any, Dict, Iterator, List, Tuple
+from typing import Any, Dict, Generator, List, Tuple
 
 from pip._internal.cli.status_codes import UNKNOWN_ERROR
 from pip._internal.configuration import Configuration, ConfigurationError
@@ -18,20 +18,19 @@ logger = logging.getLogger(__name__)
 class PrettyHelpFormatter(optparse.IndentedHelpFormatter):
     """A prettier/less verbose help formatter for optparse."""
 
-    def __init__(self, *args, **kwargs):
-        # type: (*Any, **Any) -> None
+    def __init__(self, *args: Any, **kwargs: Any) -> None:
         # help position must be aligned with __init__.parseopts.description
         kwargs["max_help_position"] = 30
         kwargs["indent_increment"] = 1
         kwargs["width"] = shutil.get_terminal_size()[0] - 2
         super().__init__(*args, **kwargs)
 
-    def format_option_strings(self, option):
-        # type: (optparse.Option) -> str
+    def format_option_strings(self, option: optparse.Option) -> str:
         return self._format_option_strings(option)
 
-    def _format_option_strings(self, option, mvarfmt=" <{}>", optsep=", "):
-        # type: (optparse.Option, str, str) -> str
+    def _format_option_strings(
+        self, option: optparse.Option, mvarfmt: str = " <{}>", optsep: str = ", "
+    ) -> str:
         """
         Return a comma-separated list of option strings and metavars.
 
@@ -55,14 +54,12 @@ class PrettyHelpFormatter(optparse.IndentedHelpFormatter):
 
         return "".join(opts)
 
-    def format_heading(self, heading):
-        # type: (str) -> str
+    def format_heading(self, heading: str) -> str:
         if heading == "Options":
             return ""
         return heading + ":\n"
 
-    def format_usage(self, usage):
-        # type: (str) -> str
+    def format_usage(self, usage: str) -> str:
         """
         Ensure there is only one newline between usage and the first heading
         if there is no description.
@@ -70,8 +67,7 @@ class PrettyHelpFormatter(optparse.IndentedHelpFormatter):
         msg = "\nUsage: {}\n".format(self.indent_lines(textwrap.dedent(usage), "  "))
         return msg
 
-    def format_description(self, description):
-        # type: (str) -> str
+    def format_description(self, description: str) -> str:
         # leave full control over description to us
         if description:
             if hasattr(self.parser, "main"):
@@ -89,16 +85,14 @@ class PrettyHelpFormatter(optparse.IndentedHelpFormatter):
         else:
             return ""
 
-    def format_epilog(self, epilog):
-        # type: (str) -> str
+    def format_epilog(self, epilog: str) -> str:
         # leave full control over epilog to us
         if epilog:
             return epilog
         else:
             return ""
 
-    def indent_lines(self, text, indent):
-        # type: (str, str) -> str
+    def indent_lines(self, text: str, indent: str) -> str:
         new_lines = [indent + line for line in text.split("\n")]
         return "\n".join(new_lines)
 
@@ -112,8 +106,7 @@ class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter):
     Also redact auth from url type options
     """
 
-    def expand_default(self, option):
-        # type: (optparse.Option) -> str
+    def expand_default(self, option: optparse.Option) -> str:
         default_values = None
         if self.parser is not None:
             assert isinstance(self.parser, ConfigOptionParser)
@@ -137,8 +130,9 @@ class UpdatingDefaultsHelpFormatter(PrettyHelpFormatter):
 
 
 class CustomOptionParser(optparse.OptionParser):
-    def insert_option_group(self, idx, *args, **kwargs):
-        # type: (int, Any, Any) -> optparse.OptionGroup
+    def insert_option_group(
+        self, idx: int, *args: Any, **kwargs: Any
+    ) -> optparse.OptionGroup:
         """Insert an OptionGroup at a given position."""
         group = self.add_option_group(*args, **kwargs)
 
@@ -148,8 +142,7 @@ class CustomOptionParser(optparse.OptionParser):
         return group
 
     @property
-    def option_list_all(self):
-        # type: () -> List[optparse.Option]
+    def option_list_all(self) -> List[optparse.Option]:
         """Get a list of all options, including those in option groups."""
         res = self.option_list[:]
         for i in self.option_groups:
@@ -164,35 +157,34 @@ class ConfigOptionParser(CustomOptionParser):
 
     def __init__(
         self,
-        *args,  # type: Any
-        name,  # type: str
-        isolated=False,  # type: bool
-        **kwargs,  # type: Any
-    ):
-        # type: (...) -> None
+        *args: Any,
+        name: str,
+        isolated: bool = False,
+        **kwargs: Any,
+    ) -> None:
         self.name = name
         self.config = Configuration(isolated)
 
         assert self.name
         super().__init__(*args, **kwargs)
 
-    def check_default(self, option, key, val):
-        # type: (optparse.Option, str, Any) -> Any
+    def check_default(self, option: optparse.Option, key: str, val: Any) -> Any:
         try:
             return option.check_value(key, val)
         except optparse.OptionValueError as exc:
             print(f"An error occurred during configuration: {exc}")
             sys.exit(3)
 
-    def _get_ordered_configuration_items(self):
-        # type: () -> Iterator[Tuple[str, Any]]
+    def _get_ordered_configuration_items(
+        self,
+    ) -> Generator[Tuple[str, Any], None, None]:
         # Configuration gives keys in an unordered manner. Order them.
         override_order = ["global", self.name, ":env:"]
 
         # Pool the options into different groups
-        section_items = {
+        section_items: Dict[str, List[Tuple[str, Any]]] = {
             name: [] for name in override_order
-        }  # type: Dict[str, List[Tuple[str, Any]]]
+        }
         for section_key, val in self.config.items():
             # ignore empty values
             if not val:
@@ -211,8 +203,7 @@ class ConfigOptionParser(CustomOptionParser):
             for key, val in section_items[section]:
                 yield key, val
 
-    def _update_defaults(self, defaults):
-        # type: (Dict[str, Any]) -> Dict[str, Any]
+    def _update_defaults(self, defaults: Dict[str, Any]) -> Dict[str, Any]:
         """Updates the given defaults with values from the config files and
         the environ. Does a little special handling for certain types of
         options (lists)."""
@@ -276,8 +267,7 @@ class ConfigOptionParser(CustomOptionParser):
         self.values = None
         return defaults
 
-    def get_default_values(self):
-        # type: () -> optparse.Values
+    def get_default_values(self) -> optparse.Values:
         """Overriding to make updating the defaults after instantiation of
         the option parser possible, _update_defaults() does the dirty work."""
         if not self.process_default_values:
@@ -299,7 +289,6 @@ class ConfigOptionParser(CustomOptionParser):
                 defaults[option.dest] = option.check_value(opt_str, default)
         return optparse.Values(defaults)
 
-    def error(self, msg):
-        # type: (str) -> None
+    def error(self, msg: str) -> None:
         self.print_usage(sys.stderr)
         self.exit(UNKNOWN_ERROR, f"{msg}\n")
diff --git a/env/Lib/site-packages/pip/_internal/cli/progress_bars.py b/env/Lib/site-packages/pip/_internal/cli/progress_bars.py
index 3064c856..0ad14031 100644
--- a/env/Lib/site-packages/pip/_internal/cli/progress_bars.py
+++ b/env/Lib/site-packages/pip/_internal/cli/progress_bars.py
@@ -1,261 +1,68 @@
-import itertools
-import sys
-from signal import SIGINT, default_int_handler, signal
-from typing import Any, Dict, List
+import functools
+from typing import Callable, Generator, Iterable, Iterator, Optional, Tuple
+
+from pip._vendor.rich.progress import (
+    BarColumn,
+    DownloadColumn,
+    FileSizeColumn,
+    Progress,
+    ProgressColumn,
+    SpinnerColumn,
+    TextColumn,
+    TimeElapsedColumn,
+    TimeRemainingColumn,
+    TransferSpeedColumn,
+)
 
-from pip._vendor.progress.bar import Bar, FillingCirclesBar, IncrementalBar
-from pip._vendor.progress.spinner import Spinner
-
-from pip._internal.utils.compat import WINDOWS
 from pip._internal.utils.logging import get_indentation
-from pip._internal.utils.misc import format_size
-
-try:
-    from pip._vendor import colorama
-# Lots of different errors can come from this, including SystemError and
-# ImportError.
-except Exception:
-    colorama = None
-
-
-def _select_progress_class(preferred, fallback):
-    # type: (Bar, Bar) -> Bar
-    encoding = getattr(preferred.file, "encoding", None)
 
-    # If we don't know what encoding this file is in, then we'll just assume
-    # that it doesn't support unicode and use the ASCII bar.
-    if not encoding:
-        return fallback
-
-    # Collect all of the possible characters we want to use with the preferred
-    # bar.
-    characters = [
-        getattr(preferred, "empty_fill", ""),
-        getattr(preferred, "fill", ""),
-    ]
-    characters += list(getattr(preferred, "phases", []))
-
-    # Try to decode the characters we're using for the bar using the encoding
-    # of the given file, if this works then we'll assume that we can use the
-    # fancier bar and if not we'll fall back to the plaintext bar.
-    try:
-        "".join(characters).encode(encoding)
-    except UnicodeEncodeError:
-        return fallback
+DownloadProgressRenderer = Callable[[Iterable[bytes]], Iterator[bytes]]
+
+
+def _rich_progress_bar(
+    iterable: Iterable[bytes],
+    *,
+    bar_type: str,
+    size: int,
+) -> Generator[bytes, None, None]:
+    assert bar_type == "on", "This should only be used in the default mode."
+
+    if not size:
+        total = float("inf")
+        columns: Tuple[ProgressColumn, ...] = (
+            TextColumn("[progress.description]{task.description}"),
+            SpinnerColumn("line", speed=1.5),
+            FileSizeColumn(),
+            TransferSpeedColumn(),
+            TimeElapsedColumn(),
+        )
     else:
-        return preferred
-
-
-_BaseBar = _select_progress_class(IncrementalBar, Bar)  # type: Any
-
-
-class InterruptibleMixin:
-    """
-    Helper to ensure that self.finish() gets called on keyboard interrupt.
-
-    This allows downloads to be interrupted without leaving temporary state
-    (like hidden cursors) behind.
-
-    This class is similar to the progress library's existing SigIntMixin
-    helper, but as of version 1.2, that helper has the following problems:
-
-    1. It calls sys.exit().
-    2. It discards the existing SIGINT handler completely.
-    3. It leaves its own handler in place even after an uninterrupted finish,
-       which will have unexpected delayed effects if the user triggers an
-       unrelated keyboard interrupt some time after a progress-displaying
-       download has already completed, for example.
-    """
-
-    def __init__(self, *args, **kwargs):
-        # type: (List[Any], Dict[Any, Any]) -> None
-        """
-        Save the original SIGINT handler for later.
-        """
-        # https://github.com/python/mypy/issues/5887
-        super().__init__(*args, **kwargs)  # type: ignore
-
-        self.original_handler = signal(SIGINT, self.handle_sigint)
-
-        # If signal() returns None, the previous handler was not installed from
-        # Python, and we cannot restore it. This probably should not happen,
-        # but if it does, we must restore something sensible instead, at least.
-        # The least bad option should be Python's default SIGINT handler, which
-        # just raises KeyboardInterrupt.
-        if self.original_handler is None:
-            self.original_handler = default_int_handler
-
-    def finish(self):
-        # type: () -> None
-        """
-        Restore the original SIGINT handler after finishing.
-
-        This should happen regardless of whether the progress display finishes
-        normally, or gets interrupted.
-        """
-        super().finish()  # type: ignore
-        signal(SIGINT, self.original_handler)
-
-    def handle_sigint(self, signum, frame):  # type: ignore
-        """
-        Call self.finish() before delegating to the original SIGINT handler.
-
-        This handler should only be in place while the progress display is
-        active.
-        """
-        self.finish()
-        self.original_handler(signum, frame)
-
-
-class SilentBar(Bar):
-    def update(self):
-        # type: () -> None
-        pass
-
-
-class BlueEmojiBar(IncrementalBar):
-
-    suffix = "%(percent)d%%"
-    bar_prefix = " "
-    bar_suffix = " "
-    phases = ("\U0001F539", "\U0001F537", "\U0001F535")
-
-
-class DownloadProgressMixin:
-    def __init__(self, *args, **kwargs):
-        # type: (List[Any], Dict[Any, Any]) -> None
-        # https://github.com/python/mypy/issues/5887
-        super().__init__(*args, **kwargs)  # type: ignore
-        self.message = (" " * (get_indentation() + 2)) + self.message  # type: str
-
-    @property
-    def downloaded(self):
-        # type: () -> str
-        return format_size(self.index)  # type: ignore
-
-    @property
-    def download_speed(self):
-        # type: () -> str
-        # Avoid zero division errors...
-        if self.avg == 0.0:  # type: ignore
-            return "..."
-        return format_size(1 / self.avg) + "/s"  # type: ignore
-
-    @property
-    def pretty_eta(self):
-        # type: () -> str
-        if self.eta:  # type: ignore
-            return f"eta {self.eta_td}"  # type: ignore
-        return ""
-
-    def iter(self, it):  # type: ignore
-        for x in it:
-            yield x
-            # B305 is incorrectly raised here
-            # https://github.com/PyCQA/flake8-bugbear/issues/59
-            self.next(len(x))  # noqa: B305
-        self.finish()
-
-
-class WindowsMixin:
-    def __init__(self, *args, **kwargs):
-        # type: (List[Any], Dict[Any, Any]) -> None
-        # The Windows terminal does not support the hide/show cursor ANSI codes
-        # even with colorama. So we'll ensure that hide_cursor is False on
-        # Windows.
-        # This call needs to go before the super() call, so that hide_cursor
-        # is set in time. The base progress bar class writes the "hide cursor"
-        # code to the terminal in its init, so if we don't set this soon
-        # enough, we get a "hide" with no corresponding "show"...
-        if WINDOWS and self.hide_cursor:  # type: ignore
-            self.hide_cursor = False
-
-        # https://github.com/python/mypy/issues/5887
-        super().__init__(*args, **kwargs)  # type: ignore
-
-        # Check if we are running on Windows and we have the colorama module,
-        # if we do then wrap our file with it.
-        if WINDOWS and colorama:
-            self.file = colorama.AnsiToWin32(self.file)  # type: ignore
-            # The progress code expects to be able to call self.file.isatty()
-            # but the colorama.AnsiToWin32() object doesn't have that, so we'll
-            # add it.
-            self.file.isatty = lambda: self.file.wrapped.isatty()
-            # The progress code expects to be able to call self.file.flush()
-            # but the colorama.AnsiToWin32() object doesn't have that, so we'll
-            # add it.
-            self.file.flush = lambda: self.file.wrapped.flush()
-
-
-class BaseDownloadProgressBar(WindowsMixin, InterruptibleMixin, DownloadProgressMixin):
-
-    file = sys.stdout
-    message = "%(percent)d%%"
-    suffix = "%(downloaded)s %(download_speed)s %(pretty_eta)s"
-
-
-class DefaultDownloadProgressBar(BaseDownloadProgressBar, _BaseBar):
-    pass
-
-
-class DownloadSilentBar(BaseDownloadProgressBar, SilentBar):
-    pass
-
-
-class DownloadBar(BaseDownloadProgressBar, Bar):
-    pass
-
-
-class DownloadFillingCirclesBar(BaseDownloadProgressBar, FillingCirclesBar):
-    pass
-
-
-class DownloadBlueEmojiProgressBar(BaseDownloadProgressBar, BlueEmojiBar):
-    pass
-
-
-class DownloadProgressSpinner(
-    WindowsMixin, InterruptibleMixin, DownloadProgressMixin, Spinner
-):
-
-    file = sys.stdout
-    suffix = "%(downloaded)s %(download_speed)s"
-
-    def next_phase(self):
-        # type: () -> str
-        if not hasattr(self, "_phaser"):
-            self._phaser = itertools.cycle(self.phases)
-        return next(self._phaser)
-
-    def update(self):
-        # type: () -> None
-        message = self.message % self
-        phase = self.next_phase()
-        suffix = self.suffix % self
-        line = "".join(
-            [
-                message,
-                " " if message else "",
-                phase,
-                " " if suffix else "",
-                suffix,
-            ]
+        total = size
+        columns = (
+            TextColumn("[progress.description]{task.description}"),
+            BarColumn(),
+            DownloadColumn(),
+            TransferSpeedColumn(),
+            TextColumn("eta"),
+            TimeRemainingColumn(),
         )
 
-        self.writeln(line)
-
+    progress = Progress(*columns, refresh_per_second=30)
+    task_id = progress.add_task(" " * (get_indentation() + 2), total=total)
+    with progress:
+        for chunk in iterable:
+            yield chunk
+            progress.update(task_id, advance=len(chunk))
 
-BAR_TYPES = {
-    "off": (DownloadSilentBar, DownloadSilentBar),
-    "on": (DefaultDownloadProgressBar, DownloadProgressSpinner),
-    "ascii": (DownloadBar, DownloadProgressSpinner),
-    "pretty": (DownloadFillingCirclesBar, DownloadProgressSpinner),
-    "emoji": (DownloadBlueEmojiProgressBar, DownloadProgressSpinner),
-}
 
+def get_download_progress_renderer(
+    *, bar_type: str, size: Optional[int] = None
+) -> DownloadProgressRenderer:
+    """Get an object that can be used to render the download progress.
 
-def DownloadProgressProvider(progress_bar, max=None):  # type: ignore
-    if max is None or max == 0:
-        return BAR_TYPES[progress_bar][1]().iter
+    Returns a callable, that takes an iterable to "wrap".
+    """
+    if bar_type == "on":
+        return functools.partial(_rich_progress_bar, bar_type=bar_type, size=size)
     else:
-        return BAR_TYPES[progress_bar][0](max=max).iter
+        return iter  # no-op, when passed an iterator
diff --git a/env/Lib/site-packages/pip/_internal/cli/req_command.py b/env/Lib/site-packages/pip/_internal/cli/req_command.py
index 7ed62388..86070f10 100644
--- a/env/Lib/site-packages/pip/_internal/cli/req_command.py
+++ b/env/Lib/site-packages/pip/_internal/cli/req_command.py
@@ -10,7 +10,7 @@ import os
 import sys
 from functools import partial
 from optparse import Values
-from typing import Any, List, Optional, Tuple
+from typing import TYPE_CHECKING, Any, List, Optional, Tuple
 
 from pip._internal.cache import WheelCache
 from pip._internal.cli import cmdoptions
@@ -22,6 +22,7 @@ from pip._internal.index.package_finder import PackageFinder
 from pip._internal.models.selection_prefs import SelectionPreferences
 from pip._internal.models.target_python import TargetPython
 from pip._internal.network.session import PipSession
+from pip._internal.operations.build.build_tracker import BuildTracker
 from pip._internal.operations.prepare import RequirementPreparer
 from pip._internal.req.constructors import (
     install_req_from_editable,
@@ -31,7 +32,6 @@ from pip._internal.req.constructors import (
 )
 from pip._internal.req.req_file import parse_requirements
 from pip._internal.req.req_install import InstallRequirement
-from pip._internal.req.req_tracker import RequirementTracker
 from pip._internal.resolution.base import BaseResolver
 from pip._internal.self_outdated_check import pip_self_version_check
 from pip._internal.utils.temp_dir import (
@@ -41,23 +41,45 @@ from pip._internal.utils.temp_dir import (
 )
 from pip._internal.utils.virtualenv import running_under_virtualenv
 
+if TYPE_CHECKING:
+    from ssl import SSLContext
+
 logger = logging.getLogger(__name__)
 
 
+def _create_truststore_ssl_context() -> Optional["SSLContext"]:
+    if sys.version_info < (3, 10):
+        raise CommandError("The truststore feature is only available for Python 3.10+")
+
+    try:
+        import ssl
+    except ImportError:
+        logger.warning("Disabling truststore since ssl support is missing")
+        return None
+
+    try:
+        import truststore
+    except ImportError:
+        raise CommandError(
+            "To use the truststore feature, 'truststore' must be installed into "
+            "pip's current environment."
+        )
+
+    return truststore.SSLContext(ssl.PROTOCOL_TLS_CLIENT)
+
+
 class SessionCommandMixin(CommandContextMixIn):
 
     """
     A class mixin for command classes needing _build_session().
     """
 
-    def __init__(self):
-        # type: () -> None
+    def __init__(self) -> None:
         super().__init__()
-        self._session = None  # Optional[PipSession]
+        self._session: Optional[PipSession] = None
 
     @classmethod
-    def _get_index_urls(cls, options):
-        # type: (Values) -> Optional[List[str]]
+    def _get_index_urls(cls, options: Values) -> Optional[List[str]]:
         """Return a list of index urls from user-provided options."""
         index_urls = []
         if not getattr(options, "no_index", False):
@@ -70,8 +92,7 @@ class SessionCommandMixin(CommandContextMixIn):
         # Return None rather than an empty list
         return index_urls or None
 
-    def get_default_session(self, options):
-        # type: (Values) -> PipSession
+    def get_default_session(self, options: Values) -> PipSession:
         """Get a default-managed session."""
         if self._session is None:
             self._session = self.enter_context(self._build_session(options))
@@ -81,16 +102,32 @@ class SessionCommandMixin(CommandContextMixIn):
             assert self._session is not None
         return self._session
 
-    def _build_session(self, options, retries=None, timeout=None):
-        # type: (Values, Optional[int], Optional[int]) -> PipSession
-        assert not options.cache_dir or os.path.isabs(options.cache_dir)
+    def _build_session(
+        self,
+        options: Values,
+        retries: Optional[int] = None,
+        timeout: Optional[int] = None,
+        fallback_to_certifi: bool = False,
+    ) -> PipSession:
+        cache_dir = options.cache_dir
+        assert not cache_dir or os.path.isabs(cache_dir)
+
+        if "truststore" in options.features_enabled:
+            try:
+                ssl_context = _create_truststore_ssl_context()
+            except Exception:
+                if not fallback_to_certifi:
+                    raise
+                ssl_context = None
+        else:
+            ssl_context = None
+
         session = PipSession(
-            cache=(
-                os.path.join(options.cache_dir, "http") if options.cache_dir else None
-            ),
+            cache=os.path.join(cache_dir, "http") if cache_dir else None,
             retries=retries if retries is not None else options.retries,
             trusted_hosts=options.trusted_hosts,
             index_urls=self._get_index_urls(options),
+            ssl_context=ssl_context,
         )
 
         # Handle custom ca-bundles from the user
@@ -114,6 +151,7 @@ class SessionCommandMixin(CommandContextMixIn):
 
         # Determine if we can prompt the user for authentication or not
         session.auth.prompting = not options.no_input
+        session.auth.keyring_provider = options.keyring_provider
 
         return session
 
@@ -126,8 +164,7 @@ class IndexGroupCommand(Command, SessionCommandMixin):
     This also corresponds to the commands that permit the pip version check.
     """
 
-    def handle_pip_version_check(self, options):
-        # type: (Values) -> None
+    def handle_pip_version_check(self, options: Values) -> None:
         """
         Do the pip version check if not disabled.
 
@@ -141,7 +178,14 @@ class IndexGroupCommand(Command, SessionCommandMixin):
 
         # Otherwise, check if we're using the latest version of pip available.
         session = self._build_session(
-            options, retries=0, timeout=min(5, options.timeout)
+            options,
+            retries=0,
+            timeout=min(5, options.timeout),
+            # This is set to ensure the function does not fail when truststore is
+            # specified in use-feature but cannot be loaded. This usually raises a
+            # CommandError and shows a nice user-facing error, but this function is not
+            # called in that try-except block.
+            fallback_to_certifi=True,
         )
         with session:
             pip_self_version_check(session, options)
@@ -154,8 +198,7 @@ KEEPABLE_TEMPDIR_TYPES = [
 ]
 
 
-def warn_if_run_as_root():
-    # type: () -> None
+def warn_if_run_as_root() -> None:
     """Output a warning for sudo users on Unix.
 
     In a virtual environment, sudo pip still writes to virtualenv.
@@ -173,9 +216,10 @@ def warn_if_run_as_root():
     # checks: https://mypy.readthedocs.io/en/stable/common_issues.html
     if sys.platform == "win32" or sys.platform == "cygwin":
         return
-    if sys.platform == "darwin" or sys.platform == "linux":
-        if os.getuid() != 0:
-            return
+
+    if os.getuid() != 0:
+        return
+
     logger.warning(
         "Running pip as the 'root' user can result in broken permissions and "
         "conflicting behaviour with the system package manager. "
@@ -184,19 +228,18 @@ def warn_if_run_as_root():
     )
 
 
-def with_cleanup(func):
-    # type: (Any) -> Any
+def with_cleanup(func: Any) -> Any:
     """Decorator for common logic related to managing temporary
     directories.
     """
 
-    def configure_tempdir_registry(registry):
-        # type: (TempDirectoryTypeRegistry) -> None
+    def configure_tempdir_registry(registry: TempDirectoryTypeRegistry) -> None:
         for t in KEEPABLE_TEMPDIR_TYPES:
             registry.set_delete(t, False)
 
-    def wrapper(self, options, args):
-        # type: (RequirementCommand, Values, List[Any]) -> Optional[int]
+    def wrapper(
+        self: RequirementCommand, options: Values, args: List[Any]
+    ) -> Optional[int]:
         assert self.tempdir_registry is not None
         if options.no_clean:
             configure_tempdir_registry(self.tempdir_registry)
@@ -214,15 +257,13 @@ def with_cleanup(func):
 
 
 class RequirementCommand(IndexGroupCommand):
-    def __init__(self, *args, **kw):
-        # type: (Any, Any) -> None
+    def __init__(self, *args: Any, **kw: Any) -> None:
         super().__init__(*args, **kw)
 
         self.cmd_opts.add_option(cmdoptions.no_clean())
 
     @staticmethod
-    def determine_resolver_variant(options):
-        # type: (Values) -> str
+    def determine_resolver_variant(options: Values) -> str:
         """Determines which resolver should be used, based on the given options."""
         if "legacy-resolver" in options.deprecated_features_enabled:
             return "legacy"
@@ -232,20 +273,21 @@ class RequirementCommand(IndexGroupCommand):
     @classmethod
     def make_requirement_preparer(
         cls,
-        temp_build_dir,  # type: TempDirectory
-        options,  # type: Values
-        req_tracker,  # type: RequirementTracker
-        session,  # type: PipSession
-        finder,  # type: PackageFinder
-        use_user_site,  # type: bool
-        download_dir=None,  # type: str
-    ):
-        # type: (...) -> RequirementPreparer
+        temp_build_dir: TempDirectory,
+        options: Values,
+        build_tracker: BuildTracker,
+        session: PipSession,
+        finder: PackageFinder,
+        use_user_site: bool,
+        download_dir: Optional[str] = None,
+        verbosity: int = 0,
+    ) -> RequirementPreparer:
         """
         Create a RequirementPreparer instance for the given parameters.
         """
         temp_build_dir_path = temp_build_dir.path
         assert temp_build_dir_path is not None
+        legacy_resolver = False
 
         resolver_variant = cls.determine_resolver_variant(options)
         if resolver_variant == "2020-resolver":
@@ -259,6 +301,7 @@ class RequirementCommand(IndexGroupCommand):
                     "production."
                 )
         else:
+            legacy_resolver = True
             lazy_wheel = False
             if "fast-deps" in options.features_enabled:
                 logger.warning(
@@ -270,32 +313,33 @@ class RequirementCommand(IndexGroupCommand):
             src_dir=options.src_dir,
             download_dir=download_dir,
             build_isolation=options.build_isolation,
-            req_tracker=req_tracker,
+            check_build_deps=options.check_build_deps,
+            build_tracker=build_tracker,
             session=session,
             progress_bar=options.progress_bar,
             finder=finder,
             require_hashes=options.require_hashes,
             use_user_site=use_user_site,
             lazy_wheel=lazy_wheel,
-            in_tree_build="in-tree-build" in options.features_enabled,
+            verbosity=verbosity,
+            legacy_resolver=legacy_resolver,
         )
 
     @classmethod
     def make_resolver(
         cls,
-        preparer,  # type: RequirementPreparer
-        finder,  # type: PackageFinder
-        options,  # type: Values
-        wheel_cache=None,  # type: Optional[WheelCache]
-        use_user_site=False,  # type: bool
-        ignore_installed=True,  # type: bool
-        ignore_requires_python=False,  # type: bool
-        force_reinstall=False,  # type: bool
-        upgrade_strategy="to-satisfy-only",  # type: str
-        use_pep517=None,  # type: Optional[bool]
-        py_version_info=None,  # type: Optional[Tuple[int, ...]]
-    ):
-        # type: (...) -> BaseResolver
+        preparer: RequirementPreparer,
+        finder: PackageFinder,
+        options: Values,
+        wheel_cache: Optional[WheelCache] = None,
+        use_user_site: bool = False,
+        ignore_installed: bool = True,
+        ignore_requires_python: bool = False,
+        force_reinstall: bool = False,
+        upgrade_strategy: str = "to-satisfy-only",
+        use_pep517: Optional[bool] = None,
+        py_version_info: Optional[Tuple[int, ...]] = None,
+    ) -> BaseResolver:
         """
         Create a Resolver instance for the given parameters.
         """
@@ -342,16 +386,15 @@ class RequirementCommand(IndexGroupCommand):
 
     def get_requirements(
         self,
-        args,  # type: List[str]
-        options,  # type: Values
-        finder,  # type: PackageFinder
-        session,  # type: PipSession
-    ):
-        # type: (...) -> List[InstallRequirement]
+        args: List[str],
+        options: Values,
+        finder: PackageFinder,
+        session: PipSession,
+    ) -> List[InstallRequirement]:
         """
         Parse command-line arguments into the corresponding requirements.
         """
-        requirements = []  # type: List[InstallRequirement]
+        requirements: List[InstallRequirement] = []
         for filename in options.constraints:
             for parsed_req in parse_requirements(
                 filename,
@@ -370,10 +413,11 @@ class RequirementCommand(IndexGroupCommand):
         for req in args:
             req_to_add = install_req_from_line(
                 req,
-                None,
+                comes_from=None,
                 isolated=options.isolated_mode,
                 use_pep517=options.use_pep517,
                 user_supplied=True,
+                config_settings=getattr(options, "config_settings", None),
             )
             requirements.append(req_to_add)
 
@@ -383,6 +427,7 @@ class RequirementCommand(IndexGroupCommand):
                 user_supplied=True,
                 isolated=options.isolated_mode,
                 use_pep517=options.use_pep517,
+                config_settings=getattr(options, "config_settings", None),
             )
             requirements.append(req_to_add)
 
@@ -396,6 +441,9 @@ class RequirementCommand(IndexGroupCommand):
                     isolated=options.isolated_mode,
                     use_pep517=options.use_pep517,
                     user_supplied=True,
+                    config_settings=parsed_req.options.get("config_settings")
+                    if parsed_req.options
+                    else None,
                 )
                 requirements.append(req_to_add)
 
@@ -421,8 +469,7 @@ class RequirementCommand(IndexGroupCommand):
         return requirements
 
     @staticmethod
-    def trace_basic_info(finder):
-        # type: (PackageFinder) -> None
+    def trace_basic_info(finder: PackageFinder) -> None:
         """
         Trace basic information about the provided objects.
         """
@@ -434,12 +481,11 @@ class RequirementCommand(IndexGroupCommand):
 
     def _build_package_finder(
         self,
-        options,  # type: Values
-        session,  # type: PipSession
-        target_python=None,  # type: Optional[TargetPython]
-        ignore_requires_python=None,  # type: Optional[bool]
-    ):
-        # type: (...) -> PackageFinder
+        options: Values,
+        session: PipSession,
+        target_python: Optional[TargetPython] = None,
+        ignore_requires_python: Optional[bool] = None,
+    ) -> PackageFinder:
         """
         Create a package finder appropriate to this requirement command.
 
diff --git a/env/Lib/site-packages/pip/_internal/cli/spinners.py b/env/Lib/site-packages/pip/_internal/cli/spinners.py
index 08e15661..cf2b976f 100644
--- a/env/Lib/site-packages/pip/_internal/cli/spinners.py
+++ b/env/Lib/site-packages/pip/_internal/cli/spinners.py
@@ -3,9 +3,7 @@ import itertools
 import logging
 import sys
 import time
-from typing import IO, Iterator
-
-from pip._vendor.progress import HIDE_CURSOR, SHOW_CURSOR
+from typing import IO, Generator, Optional
 
 from pip._internal.utils.compat import WINDOWS
 from pip._internal.utils.logging import get_indentation
@@ -14,25 +12,22 @@ logger = logging.getLogger(__name__)
 
 
 class SpinnerInterface:
-    def spin(self):
-        # type: () -> None
+    def spin(self) -> None:
         raise NotImplementedError()
 
-    def finish(self, final_status):
-        # type: (str) -> None
+    def finish(self, final_status: str) -> None:
         raise NotImplementedError()
 
 
 class InteractiveSpinner(SpinnerInterface):
     def __init__(
         self,
-        message,
-        file=None,
-        spin_chars="-\\|/",
+        message: str,
+        file: Optional[IO[str]] = None,
+        spin_chars: str = "-\\|/",
         # Empirically, 8 updates/second looks nice
-        min_update_interval_seconds=0.125,
+        min_update_interval_seconds: float = 0.125,
     ):
-        # type: (str, IO[str], str, float) -> None
         self._message = message
         if file is None:
             file = sys.stdout
@@ -45,8 +40,7 @@ class InteractiveSpinner(SpinnerInterface):
         self._file.write(" " * get_indentation() + self._message + " ... ")
         self._width = 0
 
-    def _write(self, status):
-        # type: (str) -> None
+    def _write(self, status: str) -> None:
         assert not self._finished
         # Erase what we wrote before by backspacing to the beginning, writing
         # spaces to overwrite the old text, and then backspacing again
@@ -58,16 +52,14 @@ class InteractiveSpinner(SpinnerInterface):
         self._file.flush()
         self._rate_limiter.reset()
 
-    def spin(self):
-        # type: () -> None
+    def spin(self) -> None:
         if self._finished:
             return
         if not self._rate_limiter.ready():
             return
         self._write(next(self._spin_cycle))
 
-    def finish(self, final_status):
-        # type: (str) -> None
+    def finish(self, final_status: str) -> None:
         if self._finished:
             return
         self._write(final_status)
@@ -81,29 +73,25 @@ class InteractiveSpinner(SpinnerInterface):
 # act as a keep-alive for systems like Travis-CI that take lack-of-output as
 # an indication that a task has frozen.
 class NonInteractiveSpinner(SpinnerInterface):
-    def __init__(self, message, min_update_interval_seconds=60):
-        # type: (str, float) -> None
+    def __init__(self, message: str, min_update_interval_seconds: float = 60.0) -> None:
         self._message = message
         self._finished = False
         self._rate_limiter = RateLimiter(min_update_interval_seconds)
         self._update("started")
 
-    def _update(self, status):
-        # type: (str) -> None
+    def _update(self, status: str) -> None:
         assert not self._finished
         self._rate_limiter.reset()
         logger.info("%s: %s", self._message, status)
 
-    def spin(self):
-        # type: () -> None
+    def spin(self) -> None:
         if self._finished:
             return
         if not self._rate_limiter.ready():
             return
         self._update("still running...")
 
-    def finish(self, final_status):
-        # type: (str) -> None
+    def finish(self, final_status: str) -> None:
         if self._finished:
             return
         self._update(f"finished with status '{final_status}'")
@@ -111,32 +99,28 @@ class NonInteractiveSpinner(SpinnerInterface):
 
 
 class RateLimiter:
-    def __init__(self, min_update_interval_seconds):
-        # type: (float) -> None
+    def __init__(self, min_update_interval_seconds: float) -> None:
         self._min_update_interval_seconds = min_update_interval_seconds
-        self._last_update = 0  # type: float
+        self._last_update: float = 0
 
-    def ready(self):
-        # type: () -> bool
+    def ready(self) -> bool:
         now = time.time()
         delta = now - self._last_update
         return delta >= self._min_update_interval_seconds
 
-    def reset(self):
-        # type: () -> None
+    def reset(self) -> None:
         self._last_update = time.time()
 
 
 @contextlib.contextmanager
-def open_spinner(message):
-    # type: (str) -> Iterator[SpinnerInterface]
+def open_spinner(message: str) -> Generator[SpinnerInterface, None, None]:
     # Interactive spinner goes directly to sys.stdout rather than being routed
     # through the logging system, but it acts like it has level INFO,
     # i.e. it's only displayed if we're at level INFO or better.
     # Non-interactive spinner goes through the logging system, so it is always
     # in sync with logging configuration.
     if sys.stdout.isatty() and logger.getEffectiveLevel() <= logging.INFO:
-        spinner = InteractiveSpinner(message)  # type: SpinnerInterface
+        spinner: SpinnerInterface = InteractiveSpinner(message)
     else:
         spinner = NonInteractiveSpinner(message)
     try:
@@ -152,9 +136,12 @@ def open_spinner(message):
         spinner.finish("done")
 
 
+HIDE_CURSOR = "\x1b[?25l"
+SHOW_CURSOR = "\x1b[?25h"
+
+
 @contextlib.contextmanager
-def hidden_cursor(file):
-    # type: (IO[str]) -> Iterator[None]
+def hidden_cursor(file: IO[str]) -> Generator[None, None, None]:
     # The Windows terminal does not support the hide/show cursor ANSI codes,
     # even via colorama. So don't even try.
     if WINDOWS:
diff --git a/env/Lib/site-packages/pip/_internal/commands/__init__.py b/env/Lib/site-packages/pip/_internal/commands/__init__.py
index 31c985fd..858a4101 100644
--- a/env/Lib/site-packages/pip/_internal/commands/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/commands/__init__.py
@@ -3,87 +3,110 @@ Package containing all pip commands
 """
 
 import importlib
-from collections import OrderedDict, namedtuple
-from typing import Any, Optional
+from collections import namedtuple
+from typing import Any, Dict, Optional
 
 from pip._internal.cli.base_command import Command
 
-CommandInfo = namedtuple('CommandInfo', 'module_path, class_name, summary')
+CommandInfo = namedtuple("CommandInfo", "module_path, class_name, summary")
 
-# The ordering matters for help display.
-#    Also, even though the module path starts with the same
-# "pip._internal.commands" prefix in each case, we include the full path
-# because it makes testing easier (specifically when modifying commands_dict
-# in test setup / teardown by adding info for a FakeCommand class defined
-# in a test-related module).
-#    Finally, we need to pass an iterable of pairs here rather than a dict
-# so that the ordering won't be lost when using Python 2.7.
-commands_dict = OrderedDict([
-    ('install', CommandInfo(
-        'pip._internal.commands.install', 'InstallCommand',
-        'Install packages.',
-    )),
-    ('download', CommandInfo(
-        'pip._internal.commands.download', 'DownloadCommand',
-        'Download packages.',
-    )),
-    ('uninstall', CommandInfo(
-        'pip._internal.commands.uninstall', 'UninstallCommand',
-        'Uninstall packages.',
-    )),
-    ('freeze', CommandInfo(
-        'pip._internal.commands.freeze', 'FreezeCommand',
-        'Output installed packages in requirements format.',
-    )),
-    ('list', CommandInfo(
-        'pip._internal.commands.list', 'ListCommand',
-        'List installed packages.',
-    )),
-    ('show', CommandInfo(
-        'pip._internal.commands.show', 'ShowCommand',
-        'Show information about installed packages.',
-    )),
-    ('check', CommandInfo(
-        'pip._internal.commands.check', 'CheckCommand',
-        'Verify installed packages have compatible dependencies.',
-    )),
-    ('config', CommandInfo(
-        'pip._internal.commands.configuration', 'ConfigurationCommand',
-        'Manage local and global configuration.',
-    )),
-    ('search', CommandInfo(
-        'pip._internal.commands.search', 'SearchCommand',
-        'Search PyPI for packages.',
-    )),
-    ('cache', CommandInfo(
-        'pip._internal.commands.cache', 'CacheCommand',
+# This dictionary does a bunch of heavy lifting for help output:
+# - Enables avoiding additional (costly) imports for presenting `--help`.
+# - The ordering matters for help display.
+#
+# Even though the module path starts with the same "pip._internal.commands"
+# prefix, the full path makes testing easier (specifically when modifying
+# `commands_dict` in test setup / teardown).
+commands_dict: Dict[str, CommandInfo] = {
+    "install": CommandInfo(
+        "pip._internal.commands.install",
+        "InstallCommand",
+        "Install packages.",
+    ),
+    "download": CommandInfo(
+        "pip._internal.commands.download",
+        "DownloadCommand",
+        "Download packages.",
+    ),
+    "uninstall": CommandInfo(
+        "pip._internal.commands.uninstall",
+        "UninstallCommand",
+        "Uninstall packages.",
+    ),
+    "freeze": CommandInfo(
+        "pip._internal.commands.freeze",
+        "FreezeCommand",
+        "Output installed packages in requirements format.",
+    ),
+    "inspect": CommandInfo(
+        "pip._internal.commands.inspect",
+        "InspectCommand",
+        "Inspect the python environment.",
+    ),
+    "list": CommandInfo(
+        "pip._internal.commands.list",
+        "ListCommand",
+        "List installed packages.",
+    ),
+    "show": CommandInfo(
+        "pip._internal.commands.show",
+        "ShowCommand",
+        "Show information about installed packages.",
+    ),
+    "check": CommandInfo(
+        "pip._internal.commands.check",
+        "CheckCommand",
+        "Verify installed packages have compatible dependencies.",
+    ),
+    "config": CommandInfo(
+        "pip._internal.commands.configuration",
+        "ConfigurationCommand",
+        "Manage local and global configuration.",
+    ),
+    "search": CommandInfo(
+        "pip._internal.commands.search",
+        "SearchCommand",
+        "Search PyPI for packages.",
+    ),
+    "cache": CommandInfo(
+        "pip._internal.commands.cache",
+        "CacheCommand",
         "Inspect and manage pip's wheel cache.",
-    )),
-    ('wheel', CommandInfo(
-        'pip._internal.commands.wheel', 'WheelCommand',
-        'Build wheels from your requirements.',
-    )),
-    ('hash', CommandInfo(
-        'pip._internal.commands.hash', 'HashCommand',
-        'Compute hashes of package archives.',
-    )),
-    ('completion', CommandInfo(
-        'pip._internal.commands.completion', 'CompletionCommand',
-        'A helper command used for command completion.',
-    )),
-    ('debug', CommandInfo(
-        'pip._internal.commands.debug', 'DebugCommand',
-        'Show information useful for debugging.',
-    )),
-    ('help', CommandInfo(
-        'pip._internal.commands.help', 'HelpCommand',
-        'Show help for commands.',
-    )),
-])  # type: OrderedDict[str, CommandInfo]
+    ),
+    "index": CommandInfo(
+        "pip._internal.commands.index",
+        "IndexCommand",
+        "Inspect information available from package indexes.",
+    ),
+    "wheel": CommandInfo(
+        "pip._internal.commands.wheel",
+        "WheelCommand",
+        "Build wheels from your requirements.",
+    ),
+    "hash": CommandInfo(
+        "pip._internal.commands.hash",
+        "HashCommand",
+        "Compute hashes of package archives.",
+    ),
+    "completion": CommandInfo(
+        "pip._internal.commands.completion",
+        "CompletionCommand",
+        "A helper command used for command completion.",
+    ),
+    "debug": CommandInfo(
+        "pip._internal.commands.debug",
+        "DebugCommand",
+        "Show information useful for debugging.",
+    ),
+    "help": CommandInfo(
+        "pip._internal.commands.help",
+        "HelpCommand",
+        "Show help for commands.",
+    ),
+}
 
 
-def create_command(name, **kwargs):
-    # type: (str, **Any) -> Command
+def create_command(name: str, **kwargs: Any) -> Command:
     """
     Create an instance of the Command class with the given name.
     """
@@ -95,8 +118,7 @@ def create_command(name, **kwargs):
     return command
 
 
-def get_similar_commands(name):
-    # type: (str) -> Optional[str]
+def get_similar_commands(name: str) -> Optional[str]:
     """Command name auto-correct."""
     from difflib import get_close_matches
 
diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 04f7572180d336fd0d41a6dfd90ae1a40fc5da45..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2893
zcmYe~<>g{vU|^UdaWK`JkAdMah=Ytp7#J8F7#J9e4Hy|1QW&BbQW#U1au}l+Qy5d2
zbC`0OqnLA9qF5L~;w(9=xolBvx$IHwU_NUOM=oa+CnG~DOA1>GdoxoMS1NM~M=Dne
zX9`yecQbPuQwmQiR|;<mUkX2%Cy>gOBA6nSA`Iq<q;jQ*rii78gLx9ETq%+%QYq44
zo=hrNifoEpiaeO7kjj;!n4*-T4Cbk%a;2!IsHLcbc^au)DVix-DcWG3PAXT5Zi-%t
zKA2~a%9Uc6Vw7SG=9#2&rI@CerI>?x7O7k*mMK;#)?l7ZDp!haid~95nCFnnmExG<
zl;RBHrSms4MscUOq`0;)MDe7!rMR~+MDeCD1v6-RRH<?WBqnDkrl%?-=jW9qX69w)
zr7I-n<R}zm7APd==jJBnr4)0$1O>UDCetl$|Du%CqSO?Z%;b_=TzQGPsVOC;1v#mj
zOt+XF^D1v~_!pF9=I15mXfobncZO)c#SLY6=B4FVDdgs-l;)(y7bKQs=qM!TBo-IP
zgUr!UC@#&-O)RRs#h#g0T#}fRQzciBS)do6nOBlpl$V&J2Xl=cRQ?v9CqyCC_$omt
zU!efvrDDBX94Yzbc{%xsDOK_~41+1S#qR=D3Nua!CV*rfXK5bP_9{>aVRIc^#VvtQ
zm|~cb!f+8JGuhILQd6r^t7LJw5F&kx*A1);W|X0SX-Pq8i2~F)sVQ(16*BV_ic$+p
zGmBDlQ}arS71HvHauZARZn5NK7MD~><FE!Kd5ha8v$zCig#?I$#R9!sEX5i5<v2|O
zN#5cP&d4u^nWP2cC}ieAT#}ier;wPGkJa&dw^)-iQj@c*WN<hWEPIQ`8Kekiym?q^
zQD#~t7N;s?B$k1ac5XppNoG<`szOR?L26z~YF=_?YO&rew&eW0w9ND>6<n5qrAvzv
zL5cd7h%+)5X1SVgVjd{}<m4wO<|riQr6{E5<R>NOfHG8CW;#@}-YvG`)Wo9X44lyn
zk-o(n3|0m+T@u1o2&fG31Vtn~mO%lPn4FP{JD@<aw|JaE6wEYL&%EM-)Z`MdGjk#C
zF32oUFIFheNKMUANCqj^yTuCT;WQa6dy6L=qy=WOic@K3P71`BVuiG#{9J{~{L&(n
zgs69mB_pvo182GcN#5f2NG#5PnX2rZpIcB`lBxibN-b8%Pg8*AZ3R$RW|n~>kt;br
zw;(4K6h&2vI3p6K<dz`FOo(!rHM))p8L2r1sYS37PocCpH3b~p&_V|!0kuQ#7Hdjs
zQfWHQ-~r3t;&A~fg4v*kkpW7JQ`1Uwz;=K&q-W-(g90curvP^VrREge;`T_*DS(+P
z4mKC$c(6%O*B0v~GlEKNDCS^bU|?lnVDJXjlU5823?&RT43Z2n%(YCl%(W~fj0>1*
zm=-eDvX(H{u+}g)Gu5)yu%$87Fx0T5FwSABVO+x4$5_i=!ye3_$yDXWrJ$go;9QiN
zSdyxcm<P#pdC94u$SKK4Re(ATQnV|SXO?6rfP~XC%Tn_cKqb8%*Z@tYTPz^nEp}+R
zugP+Y7v}!>l+5IkTb!A>1^GoKIhjefcp=PqNab;hJw3G~v81F(lcPwDfq~%`TXuP3
zQF`$$Ziqa%a=FEYs9cKF!Kxs#aBJeh3U0AOZC%MwWW>P0@T=L`DkiizwWv5IH76yr
zD8@f8)ukx2ELA~QA=J+^%rz+3GsH1i!PC#h-_JGJ(=jI4)z>vR#5G94EG8hpCnnKE
zHzz+mv$!NPJ0>-+EXF4@DW*8HBvluhbc<sOG7I$K^_o7^`eOa~_{_Y_lK6PNg34Qb
z$>0Evhf0Qmq7K{=V&!AxV&q~JVJb3VU|>LrXJ!Tl1{MYe24|3BGX@4wn};cfA(ye1
zk&&T>VFA-ZhFXRi#u|na<^?PZ8Jd}DnQEAd^lF$=7$q5k8B&-bSd*nn3Kof=7*a?q
zEy>qS&MzuTO)k+Z0;McX##@5vsU`8rIr+t@@wtg5$r-7|ewwVe*i$mo(sDABicCQP
z&YF{7o?29-0b;Xcr&bngGK1p_BFhKS4fSC$IPf8aF-U_5$b#a`+{~QBB3LjKCxN`i
z14`G-JWL!+d`v8i985)^G_A>Zi#<L*B|kYnzDN_KpF24}Cnq%-R4f!1F)=VO6oJC$
z7F$VWL1tch5h$RFK)K=;dNU&@Q!gp8I2C4R5gSM^JBR>z1RU&O8zF85B^d|{>}n1h
rNFuWX1ygYsC`MQ~7zG#wn0T1DxR@AO7+DyZ{;{yonLf_uz`+Xu9I>3m

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/cache.cpython-39.pyc
deleted file mode 100644
index ce122136e9571e86ba5f72497a1a42bcb928e585..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5775
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
BwX*;K

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/check.cpython-39.pyc
deleted file mode 100644
index d1b8d60541ad768db4004959a8f6ad0911cd8ab3..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1541
zcmYe~<>g{vU|^UdaWK`Gje+4Yh=Yt-7#J8F7#J9es~8v<QW#Pga~PsPG*b>^E>jc}
zBZ$qM!<@?!#gfY!#R}%L<gn$kN3nz1tT`OHoKc*)Tv1$LK3fiVE>9FsE^ibsn9rWW
zm&+f;&&ZI<us|SHa3N!qkUK*PM+#>PLkedqdoy#Ca0+8EgC^HYkgNPO8E>(LCFYc-
z7HcxyVs^}{yv5>^SzMyYc#GXRKQ}iqFGZ8-7OQJekblrE_TW%wXV>6hO{QCd$r-81
z+3^L5$=QkNsqw|BCASoli&7IyQjx{t(~9zQ<1_P$OA>Q(Qd2Y;Z}F5DWtODI=a-fg
zl$IoeT!4(3U|}P}z`&5o5XG3n5XF?j7{#2z6vdLloWjz=5XG9p8qA={c8kXu<N~N0
ztIWevi!#$H72tL$K%G{skdauHs*s$YTaZ|inUs^Nkdj)EnwOHAmz<eetXCz*r2q!1
z1x5Mk3eoumC7Jno#j(lENbcfgU|`^6U|?_tMcWbv28I%bW`-E1TIO1o62=<lX2uw%
zTGm>&8devESiM^I8s-{yNro(@T8<i45X*%jR;-q@ggJ$=hP{TPhBJjplA)P}k)hC_
zP^yN_g(21iMGqTPk4y}6EmtjfEl&w^3Nu(IPYqWMcQYF!Lt#pxUkz*Vgc`Qu2{kN5
zQ%YEZ8A_N_Seh9b8A@1#8B!R688lh_s<c##6;z8Aic$+pGmBC|Y#oL2jLhT=h0J1w
zy!;YGaOo8>GB7Yy=|VJQB*Hc2rskC>s21xeB$bvZROXjLf)lJvuS(W0Um>X|KRY!K
zW(P=lu|isYX<mw+CR-6G)QUJ57#MD`m!%dJXXfV>fpSL?8v_GF5jz6|gC_4Smg3Z$
zv|H@ZkiW%}Sd?CTiyIn!pp+HGTaZ{(oSBy%Ur>~vRD6p)H?tVTy~UlJpO==CnOu^Y
zmwt<<peR2pHMt}{FEKZ@hzDdR7d)yfZ*iog7J#L0af4V;*W6+*N-bQ;P$a>?!0@ZV
z*(xTqIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00*wZm4*wxoH
zIK(wb!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{j)>X+h}g3JQ__{_YL)S|q^
z9Q|ZS{wmf7=Ow*@%3I7urFmkYM5X~seau{pJWL#nT#P)7OpHv7T>m&&K|CQikB5<k
ziG#69068b<6_w`sX|mnohzI*NKK>S0e0*+xN@-4NeEcn*`1r!o#2io%#mC=bkB?8u
zPmYhj#addNn4VfB1&S3=P=Lb&LP&zdxEUB21VHWr#Ty4B3lj@-5lBo^<Q98QetJ46
z{5kRqN<i_HS_I0)x7bQ53o`T4i$M9P2vp|Xk}Jq8(1ZJ4FF7YuFDbD&H69uaMXaDG
z!=k9TB(bElI6gT)CAAolaL|p*FGwv)1m|5naBzZC9XS2nl0db%v?Md9ST8rTI2oK4
zZ*iulmiXkSr>7PbNrRlg2J%sA5!i!}FhB$eC^T+y*g(S54wPkzLE*x|$ipbW#KS1S
LD8RzQ#KjB%UBjsv

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/completion.cpython-39.pyc
deleted file mode 100644
index ef90587f3b654e54f6b96290027aa7e696bf94f3..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/configuration.cpython-39.pyc
deleted file mode 100644
index 7e2472bd8f2106dea5261c6baae3a06dbd02249a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8078
zcmYe~<>g{vU|^UdaWM6pG6Tb75C<8vFfcGUFfcF_Z(?9zNMT4}%wdRv(2P-xU_Mh6
zQwl>0Qx0=3OB4$uNRBy&HJ2@lEtfrtJ(nYj11!dp!<ow!#RX=w=5XioMDgVEM)89A
zY&m?n{89Y50#O3Ff>DCGLQz6sarPYHT#+adFq<PsG*>K249w=t5zm!~lE{^el4N8^
zWmq7UD!q^~O2(Zbg)4=-g&~DIm8+RKN;ZWtm_d{0CCE2^nvA#D!V+^zQ;Rj3Z!tUO
zRo-Ip$t*6p#o=F2l9`{En4`&fi`_XtH#adaMU&|kt7}k@f6y)V;8160*Wh4HmRr2e
z`FUxX>7_-9AoaIcyfgDsZi%O-mc%C`OT?#T=A;(iV$IIXODWc5yu}faS>Re!lwYLD
zc#A7DFC{gvBt9oUU6bh+2S{&0QGWU@p7Ns1lGOP8(vpJGl4Ou`kuei20y-EN7*ZKP
zfgZ(_!WhMz!W6}l!W_k#!ji(;!Vtxl!j{6`!Vtxt!jZz+!Vtv)35+Pt6rL2`7KSLU
z6uuPx7KSM96oC}M7KSLE6rmL17KSL^6p<9s7KSLk6tNWX7KSMP6p0kc7KSK+6sZ*H
z7KSLn6qyv+7KSLH6uA`n7KSL{6op_0O~qRxC;<Wuy2K171_mw#1qB7)#Jt4xRE3=U
z<is3>#Jm)R^ql;p#2f{b(9+`qs|_wqN`?e|u@yu_S0N{}xWq~U6h{gr8L0}1$t9U(
zsi?XYH1dlS(u(qP!74xjuTWf&nw*)InVO;rHdt37H6^peO2IWHvjnUN#dZa-mdreb
z#5}ON{358P^wbh71@}~lmNHPPQAjK<&QH!vEJ;mKD9<d(P{>QnO@*p12B{8)ss@SM
zg0(<pOY^|;p&$zE1h6DN^HNfiO4E_Nj_KxNaDajhDpp8IP0P$nO;IS#OGzyP*^mnf
zLeDgXy!^aWh5R%HUER{+)FK@PU0rA-fZ{_}w>YyTRUxq`RiPlUxHvUMM<G$6EVHPj
zG%*M4_SC$x%%c3f+|;}hv~Y)nTd_iEacYV}W|{)Xn#^KY9Dxi6MHxsH#Gs1I;*w%L
z1^<$a)S~jt;#3`l#GD+3-29Zxw9I61ekxYTNGvEw%~QzF19?HABp*zHoDGSkq)M<+
zDXD3Rr8y;fU`|LP8zVHefl{0*C^IQU+kouV%?D>|yI62K0;|TYBwAM&luYuA6l@^0
zZb4#6hFvT;Q9uF{x90TJ5=3Iat*jWTOaUBg1RMlTGsKt*PAXu-k{OZ83=o^0fq}sp
zRBq=mFfi0GWHDqhrZA>3r7)*3fC`LWRz{d8TMD?yNa0FhMH1ys;Q<vSDZD76d@1~3
zQ31Fp(*oucL6G?inLuT8FoUL$Ulj)|L~pS{Li84EaY=qrYE=v<C*~J{;<vOo6-0sL
z!Ep_WHa&&V;?!b=FwfvnM<0d!A_Z3$&k+A01>~eymROXTn3R)R3`%)<`6UVkMfqi!
zDXA%Xnk=_iQc{acZn1$%i~PJ>?9k+LizOp9rvT(CNcz9U4WYq>^(`*2)8b2tN>kmc
zv_nD8%1Bixt}HG|&DAZ>OhGSoKn_*N&&#Q-VuNI?Tb!VD3O1}t1*RV)ge}{^G=ehU
zElv;#(P#|Qm|R*^1j=&Ae#R^Uzz!$^MYJZ%Eso^el=%FDlHyxji78-KW`5o+wt~c>
z;?$yB!kKx+sYN9q1)2GI@##hRr3EV)Z?P1o=A^A;C{kizVEEPHY!wq)oLW>IlbVx~
zSrp@+m+DdkDsXibLj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYs
zbMn(Oi%T-IV^Z_VVtg`_VnBY=El5nxPE1cNjw#42(2vi|D@iTNOU%)S75DlmKGQ3x
zyv2?1L9q!a{aS$%HWM2o69h6b{bJ*W^B9?avvJ_#RViSrru2|3NoEFF0L7qO18NU}
zbB+ijB<IvHWHHt-WHHq+WHHw;WU<sRWU;0&&S9%%u3;+Dt6@rEl4Pi1E@Le6C}CT`
zp2D2MvVfz6vxd2uaUmlpSCnuCGeA_;vQ&xHFl2GpFxIf7u$D2Tu=O(4vW7F{S+Fpa
z@KnxYWT<6hWT;XAnN!1-#S1cdAtNJ030F7+8$%>R3PUYh9a}JzHefJdDB-JN%;K+M
zO=0h4s$qy1sA0$wSRlBNfsvs~s)o6SMUtV0v4$yyBZZ-rNs^(NiIE|kA<qhA+XTi+
zJ~HeR3TDvc^wVU!#R96KZ?S;#?=9x^)RJ4w#i=E?Sixo2Emm;J1Wun-@_wnQDWEzQ
zk}DN7REsr1IlmyaC@sGzSFegmM?sUNNS%R!p-2NnXo3he1_lODn<+0fH6<QgXoA{I
znZ@}zpi1}_XHI@%N<1hty#!|h;al7w_drw@-{Q+JNX?7S%!>y(FTV)V*aFqfxA=-v
zOX5K+h|*hJU<ZRmZV7>nfFwzXbnz{=oc#3k)S_Fgsi0QeEtahO%)DD{#rZ`gsVPOE
z<Z_EYJ|(pzwJ0|;FBP1Xi+C9r7;dp77Nr*#ae|n<FjvRt=BK3I;)PfMZ%KlDQp5rB
zE_;z8NIg5G@+vL@CH-3*8Hsr*IjKd(MWUc^(FLhsOa*6K2%!uTVJ<4oiw0#EJ5Wky
zW?_WGUu;|gj4X^yj6DBXSXh`iSeO`D7&-oPG4nABFiJ5qF|z&VVCG_GVw7SO0EsYF
zNnp(~MWuNtSq0QFV1-pO4WP~eV+vCXLkU9`V+~^#QyNnVD7!Fbv4B~uHH=woX-sL%
zE)30#wahil#R)Y`#TF?H!3-tfEYreJ!qE)U%__+NQq#;>6j8#E#TpC}V+>}<6M<x@
z6xM8}qLLcs6gEkaUal1OX2vE)kU5$hekipdC|`pd84L;*2?hp+bcPy+Sb-R(TE<$Y
z8m1za8perCg)G64A`l#wn#{MD^bBq>XQx))Vg)BUurP!GhclNAD2*iN=N8y?gUkh4
zz{A4wr^*6rprIuVJsWU)xY$k)VGN3!L5+Qok;NdhrNA|JtWYf@C{PzL)i5q(3}awq
zC}aYAm(dU8-2CEOECq=r8MoL{!Obj9rXnX$f)D@|ztFx3Bv~qfk`I^w`-IabJvA@2
zqM*obD#$XBtt?DT|EtVN^a#w9B0Z4#pv+k11J3cO6^Y3uIhEknA-K*g$ydlPNG(b%
zNmVE<$j?*IfK;ELb}7iQAR1CHqZALC+(kSf53z&>y9O13!sHg4yN|z<qfZeiQg5*Y
zdxp3cNrRLyC+1Zaaf4Yosd?ahsL2A(Q$?U`QKZelz!1d)atpLFEQZ7^JWz@(85kHk
zLBXK{%0^6Vj9ei2mxB$QotQY7xc+glurYBk@-T8RF)=dzuTmi<xKJ_<DARy2xQ?*^
z$8i>@egL=5dYKs+O2D<v0_KGb&5SM#u_7@{wam3FB`hf{pc1{AnUSGT4x9p5{fbm!
zfxeRQ7GvHoR@Gu#)gn#STio&KpmHuATnd3KDY5~D3u|UcYHo3n00RTVN>-$h0hKgG
zAO{t>fD8l&2$%pRl_Grx28Jb|P+<dyiU5-sBaV6%lsTX!CvHD$VfeWgRIf5FV5(tW
z$XLr#!kofV!vd<SpuVi)0=2TEL8W#qB$)*;FfddxsTOOp6oIlg#B-b=FGF%I$b&_p
zSiEA$z`(E?$t#RJOjWX2qYz{m$VS}$03~=(%eRIJ(z5PlhQt)8y#Vq{4GXCDuVDbi
zB(!bJ;#VaE>Iy*oq7V&sZR|@>wl4zt3DrNKstT;)mT-J=Vp%FQJ40&@to}1%U|;}^
z)D%OaN`#S*sY)5E|3HR={0E6H6kmeM0(c4qRmrHnM2;;+26X@NfGbo5hz}95h2k@A
zuo{TXMUkMY4>_A65+gVXf(dXsG-hC6*ohW-@>o3wF(2eT6pw-GYk2c+3Pv&ndxjCz
zcq#!m_7<=}vtR}!VoO*-SrC*kYgk+uVgqVfOW2wj`pp;_O4zeF7I4<EE@Z4_D`8Dx
ztzoTU17*}2wxYZmh6P-pgbiwXrLeIuurPpR3T+G-ikl1=7{M?SRIJ++s->_6Gib6`
zS%SwsAngQ&?9@tKa4JwJNX#q(b+e1|i;ERfGSkvh!94}2I#9V*Tm;Ho;C2@{J^f-<
zEw-xSQ!Um}fK(4w3aUkZn%v-Ab4#S4C^N4lJ~gi_zAUi_5*@`wh|)qZvm~_$n&`lF
z2&CjF;sa$YHxS_tB0NAPiv+|hh+Dvlq2_5qS~ZXo7!<X)*uh=6ypmh2U?<;VO#?+#
z6gP+$4{;`XxeV$F900{UsK{qv7GUCF7GvaM<X{Aq#4L;~|5=z=7^~E=rUh`B1a%iU
z9E+1d`3+Q*fiNhsbHds&pgagl><bt{mF)tig$ynXu~somwM@0lCCtqX{W6RUB`hh7
zHB2?kpjZrNNMVA<sDL3uu>(qs3ZyUvGiWkb>4655(Blzx<SIW6H2ebU+vb&2v8fhY
zDX13vX|h5}HW5%^1aUj4Q48@*Q3xpT!Epg9?qD@tJSa9;Kp~2?ERSPgV7LSdNl-pu
zU}j@v`Y*u5!C0k>HSBOjDoUdT6oR1kE2#b`PGewTC}98<h@gB@!r08v@5IP}mY<X$
zjj$Bv8pZ{z3mIlJ%msxn11NXZFoD9gP$8Tlg%uXEd7zMuKn~dy)?fxrwklJUa4m*r
zkb<JrVo(n{u^9WnK@q5-e2X2L>~FCIcm~851u-x%_-V3%t42ryN8|$mQ1C<h<Di^U
ze2cZTpdhsf7UUq0LjpSm6eZvS3rv7Ztr$>*AVM6JYQ-4&7^^h#ggDe~&@6;fhJgxp
zP~3qmEiM9=VG9^QsTEc%FJ!1?sbNWBC}k*8DPc}w1htQ=gi2Tzu!5Qo=}e#wWjI5g
z84E)ROBP#Y4kJS?D<eadObK%e(*pJy)+~;NU_IfG4kv3JYaUk$LoI6^E2zT>u9BJk
zs#KlxOLI~bKm#!F?vFxZK|xV|K@n)26g+IFSEU6V@ChzWDk#cNPAx756-4l1)YOVh
z(BNW9szP<GCg&|dr1mnT=LSjt;0OR04<-5FE*-dScZ;hSZt5+r<c!qh?D*uwoSa)i
z&WSlWsVM;v3&F$hx7a{^&BT&hTt%rRrA2wk`6;QIZ0Ic@AyD)sf(X!*2YMl7zyO&a
zDFzopOk7N$s01|wg%|}GLA@%L|4jdJ)V8So(PU7T0Tn(V4612C7#yLXR$2)|4P!H7
z4RbbgkxB~V0>&EV5~gN`8m5JyRv>c?3n)Tsm{XXtnTkwm7*m)*9ibY=V1^WyU<OUr
zDld=JoC45LaK1urVs@%RacNO1c!Ui)=%SFG4;k4m%1qBFQOGOJO-d~S4HG98rI&(6
zdyBy%ilDK~Dlhl^5`|JwHz73{6lqu#gKCxnh-`JOo`ObdMPhD2PO6oHQgtnK08F8}
zR!I}m6ae)P{4`mL{6T@73nKVI1gOib32l&q>WC<Is4+!>pxncpTbzy_8=!XIXHd2R
zMH&MO4-?aWCT5PmEG!&M9E==HI2x!(&0>@?4CF3&83xMvReX?o0Mr@?XUJ1wVJKm$
zG=kLDCCm$0QW!z`sDw3z2^1ZX40%ij46wXm6`BVcp#%+bfSPU4P=Geu^b`VeQWJ|)
z6^c>|@{2$*0UA0lR!CGxDoxj`;`fA(ktu-Ft)3<uBnz;BOuEJCT9KRz9@;K41qBRe
zDx41r!XgDwV1kPtFaa)qA{iJMm>C%uiupjPjfIJkkC6v7An>1sxk>|T8HA;=iBe^P
zs!tFGr&v&jp@uPwA%&rou}A>K3T8-QEMd%IDgzZjj9E-6jGz>n!UPqw0MVe4tzd={
z<`ia7@PPx4#V?8tGV&Y6<_aG7ty02P$Uq7PP~espr|N046oC>z5vVx=F4IAC7U1GR
zlL;w%gM$N1fWst%fq{V^9wtm&jL@DQBNtPZ8ul=OmvZ0&D8I;0Q{)y$Jb2(JKK>S0
zJZNyIG$%Da{uWPsd|_!~4yX!_kH5tpAD@z+93Ov6I5RyjzbG}nD7COOvnVybEH$s}
z7Hes7VtQ&3sJmI@2#P#V4;0+tDgt#?ia_o8B2c@x$OI${s=bRq6-p7PFao#Y!0qQE
zkcW_R2*Rg=3=9lnplkvX;$UPEVqs+A;!x+%<B;ZHhe9C^4h~KZ0S*BUo+6NXO}Sg_
zpkc4fymWB57G;6b8b^LX31mna6!*8-N-7IL3P8gwMWFJm2vmsOk}Jq8(1Q>3>Lur7
z>Ln!>gSsx@xz!?2^@UAQaY<rHX>mNLTrLKWtAU5aZb_pVhdkE`9$hN})rH_rKV+Cd
z0#yS%e-wk$1iE>pC7C(JdN99&GRQ4710X7LGmDdpz$F!^sdWp~)ARw43l^1tq6L%}
u!6An&3T|=O<mRW8=A_zz3K?+a0cy8`TCO5YJd6U25^Ow-Jd6TNT+9IJ0z+~D

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/debug.cpython-39.pyc
deleted file mode 100644
index 2e13ff15c5b4c7755b5d713a303bfd2cfbd7c682..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6462
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
HB@R&lSwEjg

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/download.cpython-39.pyc
deleted file mode 100644
index 9a6089bad2293ba88c4b265ae8b2786b279e3be6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/freeze.cpython-39.pyc
deleted file mode 100644
index fcfde785a5b7a033456abe0d7a65cdb9dca147f0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/hash.cpython-39.pyc
deleted file mode 100644
index 86395283513416bb9f85def0919200009424cc90..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/help.cpython-39.pyc
deleted file mode 100644
index 8767c57e9cc95e4746bf30f1e65951f1184267ea..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1277
zcmYe~<>g{vU|^UdaWJ)(g@NHQh=Yt-7#J8F7#J9e0~i<>QW#Pga~N_NqZk=MY^EHh
zT;?cdFq=7tC6_gd70hPIVasKYVh6KXb2xH2qc|BE+!<2XQrKG<QrJ^jo0+4yQaFMc
zG&x^_?9ybs#TJ&BQ<_?=$#{#!C$qRjlkpb2bAE1aVqOY}864{D>>3=b$#{zgD(YHP
zlwXt#(u|CmV2)K_U|>jPh+<4(h+;}%jABk<iegD&j$%z=Nnveah+<1&3ue${zs2p5
zno|HZu}UmBBfnfBBQ>W$AuYd1AsJ$Qag`XC0vM<k6y>KY*g(bYLXw%0tOf-l2Ll6x
zGbpGgfP#uKg$Wc?wamFpwJf>JwXBQ`RXjCJDU6Z~wQS)Gd15RKB`lR@j0_-H!pg=F
z$q>w7z)-_h!(7H#R8_-T!`94L%bvnq!#0~Cg=H>tI%6$I4SP{e4aWku6xJGci0DE_
zMurmh6t)E%H5>~Wn;DxJYgoWKIcqqxI2Uj&WME_{VFmftuZWR>fkBh`7BAEb#qlYb
z$tAb=l8aIkOH$*ZqPIlSQ%mBDGjlU@5{qDh#Z`i(dD(gS<$17hQBeBDs8l7Gn^>8Y
zs!*9<s*szSm{+2pRK={ItDwn!ORONXKrcQsuOzi7FEK|CYIt!GD3FRc85kIfKtXnk
z%QG(}wE`TQMXU@A47b=43kp*6Qi|9>9G0y7%)DD{1&Kw)sYSQA3W_rGO5#B=q{(%Q
zr8qSw?G}4}K}lwQUhyrK#G-Tz(>aoJQ{wXyb5n1zrkAD`7vEyeEl$714t2~*h9XG@
z28Lht&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW
z!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g
z`tY#Ohgx5(5Aum#LFFyxqS8D8P{NS`r6?v5HYO$>Mjl2kCJsgpCO$?MMj<9XCJsg}
zrYe4<1glq6n&+p<ev2a>?8W%_TU_z+x%nxjIjQmSw|L^?3riDoK%S3}zr`LOpOT*(
zAAgIrv^X(6^_FmEdR~4}YJ5>@VQFSjYJ6F0URjYeC{{or0uB}kAq5g+XJB9eMOiT@
z@;De-m_V=yB<iQheTyT%pac>_pzL>xt)#LbGcUaelsj(8p{0VHOueMUVt86B0+lY<
z6cv{wmXsF9C+DZ67DLj71gc4?70IcPm<Oj6uwx)DMtA_^_FEh_kRY)GCH`Vin&V;Q
J0S7M+GXVF#RZ0K=

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/install.cpython-39.pyc
deleted file mode 100644
index d2303ddb9525c8b56dc3349e16f9af37930246d2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 16724
zcmYe~<>g{vU|^UdaWM6NCIiD`5C<8vGB7YWFfcF_A7W%+NMT4}%wdRv(2P-xU_Mh6
z6PRX>Vg}PJQ7mAZHHtNbA%!W2EtfrtJ(nYjgAt^UIfpZsD~c<ZJBmA(CyECw#*)LE
z%NNB5X0zt-=L$p#fZ1$0g1JIbLSQy~j&QC>ln9v3kt3Qb7A2M|9wnYD5hVc@<IIuF
zm5P$em5!1I^SN?la%H1rbLFDsz<ll;`CNr41u&Z@M=@6^N(s#7%~8%(iBbWx`Epcq
z)uPmL)uYtGeEuAbT+Jv=Fk2u;D_1*88_X8W(aF_~(gm}Ha`bZbqx8XS;T(fp!ze>A
zTO`LQ*Eq^J*Cfg$*EGsB*DT5mEH0X3o@)_h0cMNkSms(qS>;+sS%dlFIX1brQMS2u
zQFgiZQTB`ssf-I8QXLmEMmeQOq)4_fL^-=Nq)4Smw=kqgr;0T*N4cb^r^u$rwJ=7x
zrpTu#v@k@urD&umrYN;AM!Babr>L|rM0upBrl_?rM0ut#1~X`Cz68atpC;2S-r&%H
zfFRf4;CK&LpMYCzVTn1Vsl}Siw>UgYQi~Fka#C-x_+%EB+~V*rD9OyvOU%(^yd{{N
zn3tcInVguDS(O@}mzbNX$#{z^JR>zV$2l=M1I$a#P00uADAr`WC6t?(of=<~Sd^Yx
z5?@eRl98XM$$U#FD7COOvnVw;HLt`uKQ}iqFXfhSd16ssd}dmFQE6U$VsU&?etyX<
zp7P9+jQHf7)Wp2f0!^k{tgb;p{z13cgF~I2U4w%)nQrkw^}7}o<rm!&^vo+RNzBPf
z1i2V21acq9?&9Q(RIqFLLA=zwvdp6VJdpjGjJJ5*@{4j4OPurbN{aGxG?{MkJLl)6
z<zyz8xTKaOX66*%5>L)ZP0o(bgqR+m43!4^5GI(OS(cg?UzA!17KJ(l$)lQ#x5Pnq
z7a{x}Us9BqoSj;v$#_eoAhD=8H9jS?xTLfsGp9H{u_(QGCF3o@lGNgo`0}F65>S-H
zr(_msvfScI%_}Y~0;w*#1@=!tW<h*eYEf}!e%>vOf};GA)Z~(QkYHL-er|kjeoAIq
zW->TX;`8(3%QN#*^2>{F@qmm?jn6MFDJU%gg+oYcZh=c?QEGBYeo>_+(=Caj(!9LP
zy!80eyp+_U__EBRlG4PS)V#7=A_#VTUVeOfPJU8ijwbUhF{jMD#G*>aoSgjf)Rcgt
z)D)1tskc~@N;7j(ZYdOJ<d^28#DjV9Y57G+K?+U=$&8@%3B^nd3=GUrTr9xAz|hW+
z#+bsG!qmc1%UA<S&dh!&8eocrK_!*~0|P?|Lk&X~V*ytRV>4qdV+X?mrW(eDjI~TD
zOf^hp48aVV%zn2RZm}hS9j(b+#LmFLaEk?$u5Ss0;wlm150Fc96H7q3gSjZR@D?9D
z8-Vk`Eq*k0D;aO`rGe8FD5-!F)k=n6P0m&^p~b01#WATlDVaqv{&}e`MVV!(3c3oR
zex6~jLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5F
zKAA}|#hE3kx&?{J*@@|?#W4k$1^V%sc_pbud5Jmt$&idytPf3~dIgoYL?G!H;@^0v
zt4%?n#Rdv<CO$?k#ws(A&#@`gv&qR%PRuE`)59iPWWd0{pvhFE&%nS?WCS8W0!4Zt
zmLVuyC2*N*3~~Sq*a19jMIc@>h=YtlF$=DTKtw77sP2hkN@0v*PGO2-NnuW5X<>+B
zO=U}AO<`+cXl9IJPhn5tXkm!rNa0N3YGH`tOyN%9X<>-sO5qJ=(B!+t2hE?*(j(E6
zk%56rK|w(QDy{$vR0U8Dvf={E=_&+N26!rHB<7_k<d<Zm7Aa)rrKDD*7HcY$7H8(A
zD<EZUh2nzL<jl0p)S_ZNsOB)|V1<IB{H)aE5{1&D9Jsg-C{W=tDbW0vnTn<$zeu4d
zH8;N`RiQY)v?w`MA+abqBeM*o3~WI`W`ROtPI10MacMz8eo;xW0yN@5E(7^OK?%uy
z#R_SeIjO};Itt|(naLR->&r4zQo$xA<|(8m7FQ~iCsrzy<U@T@sgS5po{^uEs(@5@
zf~1pDVHTyPK)jl$3JXmI1=WJ0{B(urd`OKDt6+oV2B^uIsYP}Q(a-?b1qZ1vT)mzi
z#7s<+bc;|7gLsG>gQ9g)V-;-5l8Zrs0E-<v1>816G=TF0TuVV>Nd`VWHqh7t#k@XT
zF-qwLD(*NK7#N&E*`bPw0aSJ|EMP2QTEM)JVId<Ug3p4+XGP<)q4C)f{48(*3d%7l
z44~Z7%f`r1!nA;+h9L`XM;0R}_keOv3U@CH#NI5%6rL206y6d}6fwRO{uEGqPauV@
zmldv3FhvL~DvS^X`-2PN4lth^!Ovn$5lInE5li7r5l`VpGD{*wGDQm1>Pcrxkx7w7
zl95Z1PvJ~aKyi;^ic*Sl3TKK6!VIuYJP4b>d|os@9~z$@jW2-47ew&07*kYJI8)S8
z)KfH4G?Cn=mBO2%mZF`agA|6kDZD9qDe5WuC@Kw7cvB2h)KiQQqF`4FA#4Hjh0*vT
zXnavLz8HjG!n8oVgegm+h9OIGAyX|Qh+ZI-VqC+xkO>@Tl3*Sv1u%hHqQMNBCVo{+
zx+PT{y1J0I+bu2#4QhbgVou2{s#=OsQfB6r<SW>uWER=!DL7Rsq@<=LmgbZwlw@QU
zE0kyE<S69jmnama7UU!*rz)gYfNHY5bVxCzpO&AKl3D~RvS22J7N;uc>XsIy7bT{o
zg31{TozM~kp-BPMT2#nOEmwfHg^KkwS#GhUq!yRlV$V%2Ni0h&y2TE4*DaQe)SQAU
zHeKD);?$yByrspd@gP<_s7}4bRa}x^lp0@BRGM0~1Lo6`e1(#XRD}R=Ggbkl7*_Hr
zz)I~(g|z%4h06TWB87sS#1c>=Ku;m0vH;X%&Z$(W)7JwR8~Qp5`9%t<jsXEKjv<b!
zF;FA(^Ay4%Z8JRujo{Q&Wb0D$lS@JERd6c~YzxStdZEFtLGezG!LDGTw9=d$g%n7m
zRZmlsxyT$;@v<c*gWAJIRtyXbRh+uIdHE1Ob3;6tmY7qV3JM5tlbaJn#)C?zDqEPx
zQ_E6|DoZjz6-iMlsBv8ejuCLoCgy<K8zrd<AdQHC&;uo&f}+&4%!*sw5E^2tC)8Ak
zM<6l^<r%3(sR}unNjeHinRyC`8nz_AKsP6~EHy^~mP8VZQbA#xoSIU_q#FwI4>Xb7
zVuv!SnnIz;CNU=mUdf~&>U3yC=B1XW7MCa_mL+E9fLhnEWTU4Ll98&Ak(if~1M+fy
znnFryL26z~YF=_?YB7{ktdO4vjvuI{y2T|$i6yD&m7s)?qE{sZPrPuMTLMtE@i4Vj
zeEE4fmAaW}x_POoDXA&9SW^?zQ;QPa85tN{QcF^cax?Q%ixo2R%b~WW<|S7uKuiHS
z4bq%eNP@aHHANvBn!K$PRH3X`Jq0DOsY(jE2va~F0fi*Qtke{RqSW-nqLiG};$nsT
zG*Eni8#ti!o?Kc~l$uwPQwdA$sVT6KQYcO=$t+F-83s~`RJVgo0g1safM!>XVof~-
zB~)*NT&95H8jw855#S)MR7lAO7akDXD#5`{tX-Nc;7m|t3CaoV$r<^X$*IMVtRSeX
zo0eacoT^)t3T-Og;s*=F!v(6WgJ5zBpu`0AM6p6@S!$j_W*W#Tm0+hQ<`ktSrhp<x
zw<KRTC9xz`uZl_66O;}z)ARC+Qgxwrq^8^wfQZ04KdC8I8$7{kK*k}3GR!s|h5WMA
zB2aG)6zL@yskxvenpv!noS3JORFs;S4JmSpD~n4~bD_>c6tPfa6f(h)lBkf9nU<Cc
zic)wq<`*fHCxQx6aPK)a1yYhCtAv@6o0tbmp^Bh<mz<wlkeQQuiyg`csZw`_2*Juo
zXiF8`)C85`NtGq3$@wX%nk+@Opnd_Ucml@^Btm$=WfRo2Dm@oStV8((&16P06I|3u
zf{g=>E9e#{7iAWd=z<DgP*HeG1SA>{5sin5RvAET1W7_tA2iND!46SetdL(?Qk<ER
zsu189;!!1xumV0P05v=@DZjJ?)c*sIBotSvA{!2tR7fhy&rZ!l$&^K)4zQ;5Eso^e
zl=%FDlHyxji78-KW`14~Cnyo~ASeA>+{yWQpyDJmucY`EdtQEgN@_vzE#`uv)LR^>
zDUe}<Taq9%pfxyT6b58=W`16A5vbL9ixbizPsuF0#avvJd`k?PK%q7jLx*l|3FYNO
z`|g>=`Jjp*KkpV-X>n?NL27}iq4_P|ynIk43ghxagAZoeEk4LV0i4eXG7sGOzQqm7
z^6`+K=`CJRwUAl_<MKh>5ucG*oRM05iwD%HC`v6Zj!#M~x+Mr6V}kS;;?s-rOABss
zgL@HB4jXuArRbJ$W?pe>Q3=#?h@>XdEtcZcoU~h95FMZp2X|y41i0VI4GKJn@x?))
zw)q`U&y-1k5e%6G7}*$E7?~jOHyalZ6B~rh$n=Me1BuNFXEQSWW@AU;aR@L8Fu~3F
z!^R1dWdo_@gYlUDfb>Ca`@_Zsb^)UR$Snw4K{}A_MYRc)#{o5gQGkhsk%f`v9}6oV
zW0e%NiiY-%^^gJ}8PpR8`5%Ne7#J9MU;{KFEDQ`aj9Cmt5;crjj42GIj71V9OrVjM
zCdLxx1uUSE7e<B@rdsA2#w^w%qZ-C6wp!*A<}CIaMo@pG7t|JI%;G5UNN1>JDdAke
zmBL!W-OK=Lqn7Z1Os-+f;su#q!<fZa!<fYn>Rr?@#xtZa)Uu{9)Utu(if*JZ*D%Hl
zln7=CEf5BYEM%-<jAsP%MIij5ePEs_gjc+;geir+nX!qnL@b3Pg|nBjmbHd8OQ@Eu
zhGBtt4J)|k#h4{g@F1O`mc52yfh5Q$wHzf<HK0)?&Kia+=^DlwjvCGy#w?i>u3nZ}
zt`gZA#w@uS#w__}rdn>0IVB3s3=0`+c}m1;7_$_47*e=Xm{WLqnQM6`Fjd9XFf352
zVX9%Q;i}<S$WqH!qFe*=AxASPOc=6MYItiHYj|onYPdk*kiy%`R?A<*kfmC~4-%>2
z28q@%W(j~?P{Wv|Rs#xS^%TBdu3CW_h6NfmTwq@aWNCuUW#nN<;qPUt6|CZ`5nP~^
zBCwFLRw$eyPlAP^M0)~b<uyhI5KIxQ6^>-c<1t{U5z5j@VJKy&6)w@O5l#{6Wn^S1
z(W~Lgl5b}0gbd3Gr--z0)CgwjFECih;KI<%SSwOuSR+!yox+^Xkj{`I+RGZlR4ZC5
zmLirS(!x+9238|pBR+wt$fv|8MSOvAio^nw8u5jU3mHMN0a6hwQY%p-k)=L?sW>1-
zvPL4_bOKXhK#jlxvl_vLjJ1*}47E}<j9KP93=^30n`#)dENZ1|q$e;HO{rm6U|A!%
zkP$3zRVxFE>j_Ln%TfeuWlF4TBx_h|*um)tlxlcuK=Po}Ym*|?%ULU1VhavYkQ^u;
zK&g&DMY@-@R<6XZMy{E$R=!3y%f7^6fn$oyLdFzXP<W&>)GE}-x-i6s)GF2}W;xX=
zRcX}7FL16=TF6+dT%!!i5fhk;Olp*7Go;AXC}+9MW|+%ds}#<VC&I!|;yQu3(hC&o
zj0}+sc}xZjH3|#dKzbP&CNLMW)JQ?~SJW_Mxz|Y5Ff8x@rNb0?P`*h~SYT44u#mA<
zrAB1}bJ3&{&lJTP6;SF4XUGd+VJPvMz+Cx+k)c+Vk)g`0h9S#4MJb!LR;|RRMzux_
z<kx2ATJ;jnEZ-XS8nqN<keMZZ;S6jHk)YhATBjNer41MiK;gtVfu)G6hIImS@eePC
zCdL|u1^%EAu3-h`?S;&Y3?%{042%pVfx!%#Dt=Y!&WU;87F=?EZc=7ms)9PC+ocX}
z>8rzfnd(*iCHcD0R-P`XLI}}hyu||<ZG==`RUDz<p*GcGO_n0iU|<nw__D|zR59{G
zDy7tv_}u)I)GFH$@U(*hs4oL)3>7ORm6m{-L7<)}sC5G!>efN@Pm}ZWN;30GQ}u4K
zK`hi{yv358nU|u;a*G{W3EW~YPAvwHwev#MK&!{15Rfa_p_QH{^DVZN)ErPNJ`*G^
z0IB<OD&rw-s1!}MTYM#{xdqS~H6^pCC<~;JyC}6V9y&8nlnoMLO9RzTMMc)25mv5S
z90f(G1&KweMMXuRMifL-IcO3lJ{dF%16Eh$29g80sK^z>asm-yAOje0i9tdXI#8IJ
z5)al4YBgjQxPc}DazQf&m7tOTg3JPpK`PLsAb5yfih+S4ouP&yR;ZS-grSD9gQ1zJ
zh^2;cB2yttFax*>)nqJEV_;xd$#jcJ&)^ng(MrZ5BallBKm@pY<+91iEG_{x^6Y{b
z85oK|6OwG;8kFTf%l|4hw7RIMG!HQjjnJyeQd9yCs<PCg%(Ti|ypR?RG{%Y|85kHa
z`~j-Uf<YC!1k4`-pm~KX29O`JP<+8u1PZz$O^~ZAKm^$RU;^Zcq8h0A#h_tqHYSe$
zRRPYRnGSHG2RjASo=nXt26xk|YoVjArNyZV0j>cGriSL=oRFND2TGdAL#ogobxvg!
zla4~>1_cHNO}1MspuYAkmW=$|)LU$zwo+zAkq5|GpcHb8v!D_boS8YPnyj~2K;sle
z4Is&S5YY$<B@S3l0sBak@fLG-YUM9RT}{SY0!69C`8j2v>7K-*%*4EsUyKS>lEJ0P
z$*IM~pz#IdZlG%MOK^LY@fJsFMRI&*URu6p5G475vn6QK2GVGif+RU;-hd`~NRB9S
z1i1^8K4A$HGz%7Alv-R;lnEKRhyXd7Ehj%cJ+<f-Yf5TTX?l?yNK7~-H90c{I&uRw
z98xTRN`#_xkjbEoaEmFw_!bMOB)G+%m{bgAuz|;*if^%I7K8GhBFH@6RM7MZsMTJQ
zT2TT{HjtShXlFVen)8c5sq~g8)F05!Q9Lx8f-@axB=;64I6s00%^=evk{~-c^70{5
znzsZ%Ga}HoEof|~_?CK6Drf{6-X)0#kGG_zz`Bai#%u8{NpPbVNpC!?P`Jelm4ZYg
zB=>_-?=1mPp^_S(lvtbziK|=e(8z|&A|jb~i^Ds$5<G!=iw9C3XQrmaCsh{7gF+NE
zMN{Mh@(WuTc-pu~6(lSO76FZUC6?S`$;!{nyCs^Fnx2?k33q-`YGQGI-YqeZ$Dz>$
z9tVogFG@)THPOM{U{D_hKHgH~2{KkBJ_S^gg2qEYu><K-LDIZ9$ZmI#BJd1TPG%A!
z_|i*Li;Gi>i$KNIEtcZ^qLN!2`30#(i6!|(x405ZN<b6SC8<T=d;p0LP~t1fOezKU
z6WO67iMKdiE0R;elNh(y5(^4a^HOe!#)JBa@!+l;!cDiN5DtZgZc%(0Br6qx<|J>i
z`v*fpma{CiC@H@<v!wEtcydu{Vo7RzesO#%XeK*8H?_DpF+KGbE0|lv2lAd!Ja|kB
zKA#RswV>vA5kII{*C+zbnn9`%7SQZ*5hzO)fwK-jw4MT2H=tgg2$}$RXbzm*!8J}%
z4k%2)wF{_JEh+?A&j}yoyu|{V<}NA*iE_X^d5a$@{lpiimfT_o%|I8W78aF*6!L=f
z#Fs!jkhd7)Z}EW(#`v_v%$(Aq)Z$xGkX|G-Q$dBnGpxl$RUjj{O7dYT=@uuVzby?J
z2E!U1;3RU36PngiQ*QAhr;p-W%&B>0w^%bvQge%Mu@$8jm*$k*VgYe)@xk?gXXR1&
zsl~}f+d(ekE6&I-2UpgqNr}nXpkZckyn*Y!qH0hmg6fA`%tfVnk3dyT45++h7GUIH
z;$mcBWMgDw;$z}s;$vh2^}ZnZHwOo(FUH2m#wftZ$H?=aiHV7k=|2k_7b6=Z7ZV6_
zz<Zo5f7sagn0T0&7{PVsUp6)tMgb7-KMM=Ap9rZ-f3a~O_#pE^n2C|)8yhbd6AL59
ze>N5-Mm|P9MlKdEkPa}P<v$Ax7f6mB+P?+K{O00fV`BQp#sadDg^A-I(|;B&4n__}
zkU32MSy)*>e*4G7!p6wO!p6wK$O3XdNGI6UAXl(3vV3Rb0r?q(Sr}P<v$1n92{E!T
za)AB8#mL1d!pO(S#>fXUi;;<u;~yI<$p1`?EdM!}1sJ)Qm>4<!voP~9NilISg2IyP
zKMM;RW0eqQdm$NADTDf}APmYdpt2cM`4{^!g4YNzHZw9ZfP0;cDU3BtSxhNRy-eU<
zAagBS4Qm!lEqe`X7Hcg>30oG^0`?lVg^Wc`H7pA_KrBWEs3`kF#-fB8_8PWq=As0!
zEIX*z1(oGk$XHYc7Uckm*08uR#Gb3=EMZ%~S;M)I(S;#)UoBS+XAMU-Q_&%?9xhOS
zZy{4BLkTx{;R9%vo1+Fa+s4|;Bnj?gH8U0+D(rx&W~|{_$W+S>=CRjsFJzp+SY%Mc
zT>PPgX8~^tTMaj;Ck<822bJdm%YjrgF)~2q_@Q!YB?1csL2O2bJgyS91ws&ZiNFG3
zupJ=RaxG+nnOj(u0$NeQ;a8*%DvlVzZ4Qh!7bq$~)kiU?%~it?3vO{OVCZ02$QZ`J
z$WX`xGGryAA86f9aY<rPNik?rN0X_j5|rH-K}%v-Qa}YCyzO<1(<VJNFSVke$nFs%
z1H)%fBv+ZBr2@>76R8mi)Bf`R|NsB1yrJC&cxk7gTC4yY-Gww6^b~@@v-_2(GgRQQ
zW7rHAs6N-LY9VYGxZ#&stdOXXlbM&TrvRGAhfkL!mX_q_CYC^_k6=?^Ace&`3I#c-
ziN&c3pj827si09`s65DOP%kGXwK%gVHAPQTq(~N25($BbiJ)*~FDNZa&B;u<#SWUK
z0x?)p5=#<`CV*5-1`!*<%0Ml1P+%_w@t70yDvNqSEOt=EmzkG-i!HMl<d&i-AW^pB
zjM9?KoLg)~xg|xZsi5LCH@__P77K{f<bhOA;AY`2kPV<#-z^?cX`GT-6c4iL78_)h
z)-7(R^FR%!Tij45f;k)@XM$PmP@P3*L3YC`I8ezAl7^JO*Fg4w%HN_L3=9k>K)nk;
zQ1W2nU}0eal`f$2mj_(da53^Qaxrl*@-c$293!MG1ecLaOn+HeL3|cQCKjgOEbJgQ
z4-=@g<6&g_SEWcWttEp7SwR+qFo+E*fWXuIpw%%|T%f*FGh;YIFarxi31g)OWEcQ6
z@t?v7Dl9;q@L&c522kG6Wb&&j2e%(UeTbY?1#rU}G(ZiSd4yMrdI|xM)BzfMS4hlL
z$Sf`{O$E(a6=W8u7el$A24Qw;k(EM5Nl8JmmA-y@W=TeAl3sFtu6{vfL83lrNfB6Q
zv3_1^xh6}I7$`_LfCz9(;7o-zi!_-a5quOR2hN;e0v!4)q5dugHDef<m>5B!%>t^^
zSgMrKLl4n>f_nyK&=F(?sPzpFzfTOHLB|-TTILw0T9#VY8kS;-8rEV7P)MbNh6I^X
z7_*s*3~JaGFr+Yn!ZJ^+hAD+Po2l3aJa7RLX90<W3uK#G_8R6Ic1ea5R!N3h4$vSG
zsGyBis^v^!%VMly2MzP3faE!PnQOT~rb33+3X=-GYFJ$uVgt}jU<H}x!Vqf~!(7W<
z%Tvpn!U;8pw}!ih2jZ5Z6DeGIOrRx7y=*9^E-CB*rvlyuETF0e<W7*!H2M5)u|Zna
zRZAf83E?585-Js7?J|Xw{M2G_KNK`mkeQNNgsci4#-RRbo<ebIPHJ)qC^bR*G{w-F
zrli!2#Ij7#ymn?Wc$TUdvIr?3JOu`toXyEE2kC=Pl~yXi&DN{pH8L<V(1kgvYB|Kw
zNNQnHNUnuXJC-D7gVq?8<SQg5C+C;um4K(>K$D9wM=F$LB$j}u;oyxns<<0G8&l;_
z4O$Uct56N?4AjCFdKD{FBei*JVQZ-}A;FDsN>L}MMq~zeGK$uN$}7+qPbqW-Y*jkZ
z=7WZ>sw?wLYZWpQ%Tg7pQ&J1S?c-Vq6Yf69nyyUHj2>ttAh9GfDJNC$7IS5OX%$;#
zeyMs+jwTzzIYsY5ZsLHMc8eRtf*Mxz0VK!BrO8?ZsuPNqfbusu?{g#<WrAy_B2e|9
z$p_B=w*+9Z4(hOh7S9&7gACw?Mir!EkegWy8pQ)oUV*!Epvr``094(BCwIVoU{Ih#
zLW>KLP>L>s?EeTNKzYAN8^i*aG++W;+-zcCVBltAU?>I+i7+tnfSaJ8rX{GzVPoR~
zHADZiuyZi-F!C@l{bynUHE!8{v2pM*fy9L1VjyuQM!xTC+<Z(`D(D3js1ii){rPEf
z-{Ob|$4PwrEv|UbNMvbFYJB`Hp7{8}(!?B)r{d#pvB$@!<R{0+-(oEVb@Pf+LEhj6
z5tl#&sJbcwm6}B$zd$N8u>ZgW*pns<3=DRl9)$=40|N&m3l9rBM?Hfe6C+nWLmGz#
z2X_%jg<CRcuntuGf-q>2C%ozb^+ih<QW$F(Y8Y#nYM5(SQkZ(#z^z`!8rCePbSCin
zSV(J*wWt~7F2pcW3y2FEOVVU60=Fw}g9Jb`W14I@)fPPmDFXWeOn^PIih+T_5fob>
zV;DFfVGbpKv2hfE<S{Bx&_Z2s1ppca0{J3^sfD40v4jcan-u0=re;Ra{6aHmkuZxN
zMk^HD_y+|Zs5+}*h~<NfUp6DPL5nVf+$s&qxUj}&3Q|OXoqmIXfgud!bWokn!dRsV
zT9OkFP3gt(Rohsank$)#z@u@XVAN#3#hjRvbBnn+wFK<jA|^%#$ml7=LXcgz#ITzk
z0<s=d9WpR+FfuW6{b%}L#LCFPfD-SZGyrONgF_6Ifom927)u$8q-q$7rAinUFhZ)v
z6y{)t8ipdb8pa~65~dUu&@4;|b2CGcMF~p^E0_mT%LcB7*g<Mj7)u$7gTNIjV{uds
zQ&9%kG;j|GWLgPp7F%%*Sd0^_i#eE~gdLpLxO$n2rh#R+;W7*hI8u1PJoaD)P2R*P
z<Yh3R3JS6&B_FgNBoVaE2DAbfyktQkDX};;1=PF&RSTJU1*Ihl(6L`V$l_hkG>`_+
z>~s-$i5IAW?3S2QoT{Ucm#>hRl9CA;@JY;pw5N)}l}So|UMghyDK_09MWv}a3Yp*u
z1#lxQH3dAn3oCImb23XRAuB1stA)X9YvGOpFE+;FCcpf=R2^^)3mtM)KvcbuVi3Oa
z2x%d%4%l#bv0qS>4_eKeqL2hxECaS*A+abOyo3z8u-LCk#V<b(yc7(!<^-fZwW1&=
zGdUBqRIji!wYbEsDvZ$V4P*pbT_F+NG^kX_%q_^NR6r~<f!2iJkv;|3YK!8kD44kg
zsYResLxn`dybx52o&speyaFig!`HckqXslgUY1!5s@D`U^B{{15qlE!sv!EHreO0{
zNR=^$?^8;_>)Ld6Aszy)(SuD*K~qze35KSm)Z|3aI6i2c9nGOBnZ=-WWhvkcU1fk%
zE2{TE>wHo{`l@_gAZsW=?W&S|Q2K=@ct}{n?9KyiHpoG<9oh_m8>h($?!6WDfeJS8
z$h<O$1s=6!0XgB8fUBRQlaFgWcu`@nXNW7fD7nP~9@l4ujO(M$xj{zQ!G$@P02Nh5
z{R|8YF`#k@R0A;xfjU?$;N=D2VJz^l5fgY|iG`Vm89aEy%my05VS%XRVgj3hQs#ro
zdw9*&#lXM--Uh-@%aqPg%Ur|Y!Vqgv%TmLV#Zb#y!dS!F%vj4-!&W3v!@Phgg?RyU
z4O0!<0+xjg&5SiH3&GuhLV+5_qO1}|@Ekr!Z5CK93$j|!Of(}y4Rdi(3TrS!32O@5
z0_GI<1#C6UAQ@132ol%isG8)NrjVFd2~XO($r*`x>7ZECg{}I6u4qT(L4|VAipPS)
zVo<r2mR|(Uz(}phVo>UXE-{2|<<QN^gq96?pp7);3W=bWd{HW7XO9A?J(8K14k@ru
zsyxt`BdCf3Pj-R&Pms_9g&VkrMB7FKQVI%euyRlZ3!dW>t7S}KSin%jxB$F_92AU@
zc|J|%Di&Sc>e`}1pybpBsWF#;8hz~00SV~v4Wz*dPA6ajoLE3JXY-jD7>aI!R;LCN
zIsbvEQb7erB5YAlF+v<MH3+UmLG#FvvKQPqD+UWf2#_=2`*k2{isyooFDM)sn5yh4
zbW;^iwPH~%cq55Ib#0Xxf(MOP(7;csU)2oIMi5XXgh)P6*C?drm*%B_$~pA(WTjAD
z3+?G-7AutI!KZX}K&1s}ED5@L7G_dTW;S?Tb#ZEujsmQp1F=9eiaOx2D0q<vDm_yZ
zQ}n8stQ9ob!7~X(pebKON8lDqc4}pD5x6h`cLLbK(?Z}$h$3!A28LUl`DtmOshpx>
za3=$7$Sna_9RQoof<y!&QOsswV3+}l0&oe!%E7|I1R59y4SR!zWO)8F{Ra(n!}y?9
z4+|R$c%Yeund2|h|00kHD8mMzwl4^S+dvDz6TY>~HOvbbAVVxQjKw-&9=LP>u}T<g
z7@EPuFL_)behM?FWm3bO!otb`8Xz!dU}mrZ?a5#&Vaj68W-97SVXI|HVXtK^VQFS4
zuBu@wuBu^Pz*@tS!coJzfNdc|I@kn=Y0z~=Ap0RLBd!JPpmJpa$3lh_R&mfsDtA>8
zWMd*|_y#-;qyU{20yi@f^Aw;HNzevPi9&8-r9yska%mB$G%Cr=O;t!KEdmuophi(@
zMQSp5QVX=c7bF0RUeKCWXexx18&x`pd25&gSc6spT0bIeu41xMxW%YfbPJU8K_jnK
zO3wLtpyiQ8&@E9QixPCfjf@0X9V+S!+D!>=;}n3FID^+x6j!l;O1vs2JuXO>gA<(0
zZZQ{^6oF^K^73!7xjKUOeHJN!3KzE2iW1N?9BWQ~d1?{34|<CgG-X_%$p)UBDY^hs
z#t+__g=qH`{RD{$fNE=K>Wc^UJ8uafIRz|&o+h_3FfbefrAZZVSBixhJn6tFz{JHY
zzyj)1f~P$|lRE!6Sh*Ovn2JC;G+EvJ{M`IBS^WI`+%&z41VNdC9W;}jnU`L)1{7}K
zL08b^P!StQk|V#M1hQfgRQ?o!x+=HWN-7IL>Oqb8B2a6-2$Ym>Nf%@m=*5?%=B4Bp
z=|N%%Q~`iSVT&Pq8HK?rV0!}fz|+x1pt3zm5KSg06FgBLC4(WZhuF~znf8{&R03ME
z0!>Fn+#pZ!fCx~B_Ldx`>f(~blG5UM&`RK9@YE)F2J@B#s!I6KBD8=3H&nz?)xZjp
zVsIz)mKdrmXwL^|z!)<9tBfX@pOTtWtOu<>K<j>r@^gwny=inOLne$tt7Rb@AB#jm
zo&$9qZ=r=EXtEPD9UX-hL`A8EdY~YJ=BOgj<i{->YM^7XMc}mpN~mrI$E+S`h8oNQ
zZxRL<$>>f7OY4Egej#hZi)28l9xZ?&igGiHlOgj1psF4+!4Dc6xP_JyAgW<A$VK4g
z5@>M?QG#fOgEMLosFev#s_=veUT_4N=uIsu0_7;k5(3a#p<A5ksU<$(wH`%(Kp_np
zZ31r#1rKRJy2zkDF1VQpF6qHp4JpIIYm!?WHo5sJr8%i~pf*r(0(h(hG*=110*oR|
zJWM>GfgnZ^R?u2l2wMOw0%1$A@h}Roh_G=nb8rjPGe95*c!4Bnoc=eLFb5Zu_nXUx
GLkj=~Q8gF<

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/list.cpython-39.pyc
deleted file mode 100644
index e8376fc691603f5cd9336d1b06101f7de917a3cc..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8835
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
T&?s1f4V1;Xm<8$?@;KB0tR^RH

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/search.cpython-39.pyc
deleted file mode 100644
index 8f67ca4d02b7926ac728fc80dbeb4b9cbc175acd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4934
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
F8vuh?0>l6S

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/show.cpython-39.pyc
deleted file mode 100644
index 575e0e6764f229fdd77450afb66c5e5dbf14a090..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6333
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
LCN5?H6^<wXjdw$x

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/uninstall.cpython-39.pyc
deleted file mode 100644
index ac30940333179e957cd821fb0e2ce525a52ec5f7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2882
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
aR4l^4z`(=E!^FeH!zjSW1BL=DJj?*3sZcZk

diff --git a/env/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/commands/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index de43dd9d54fcdc00b2f5635f96d32e63919dba27..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/commands/cache.py b/env/Lib/site-packages/pip/_internal/commands/cache.py
index 5155a505..e96d2b49 100644
--- a/env/Lib/site-packages/pip/_internal/commands/cache.py
+++ b/env/Lib/site-packages/pip/_internal/commands/cache.py
@@ -1,4 +1,3 @@
-import logging
 import os
 import textwrap
 from optparse import Values
@@ -8,8 +7,9 @@ import pip._internal.utils.filesystem as filesystem
 from pip._internal.cli.base_command import Command
 from pip._internal.cli.status_codes import ERROR, SUCCESS
 from pip._internal.exceptions import CommandError, PipError
+from pip._internal.utils.logging import getLogger
 
-logger = logging.getLogger(__name__)
+logger = getLogger(__name__)
 
 
 class CacheCommand(Command):
@@ -36,22 +36,19 @@ class CacheCommand(Command):
         %prog purge
     """
 
-    def add_options(self):
-        # type: () -> None
-
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '--format',
-            action='store',
-            dest='list_format',
+            "--format",
+            action="store",
+            dest="list_format",
             default="human",
-            choices=('human', 'abspath'),
-            help="Select the output format among: human (default) or abspath"
+            choices=("human", "abspath"),
+            help="Select the output format among: human (default) or abspath",
         )
 
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[Any]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         handlers = {
             "dir": self.get_cache_dir,
             "info": self.get_cache_info,
@@ -61,8 +58,7 @@ class CacheCommand(Command):
         }
 
         if not options.cache_dir:
-            logger.error("pip cache commands can not "
-                         "function since cache is disabled.")
+            logger.error("pip cache commands can not function since cache is disabled.")
             return ERROR
 
         # Determine action
@@ -84,78 +80,77 @@ class CacheCommand(Command):
 
         return SUCCESS
 
-    def get_cache_dir(self, options, args):
-        # type: (Values, List[Any]) -> None
+    def get_cache_dir(self, options: Values, args: List[Any]) -> None:
         if args:
-            raise CommandError('Too many arguments')
+            raise CommandError("Too many arguments")
 
         logger.info(options.cache_dir)
 
-    def get_cache_info(self, options, args):
-        # type: (Values, List[Any]) -> None
+    def get_cache_info(self, options: Values, args: List[Any]) -> None:
         if args:
-            raise CommandError('Too many arguments')
+            raise CommandError("Too many arguments")
 
         num_http_files = len(self._find_http_files(options))
-        num_packages = len(self._find_wheels(options, '*'))
+        num_packages = len(self._find_wheels(options, "*"))
 
-        http_cache_location = self._cache_dir(options, 'http')
-        wheels_cache_location = self._cache_dir(options, 'wheels')
+        http_cache_location = self._cache_dir(options, "http")
+        wheels_cache_location = self._cache_dir(options, "wheels")
         http_cache_size = filesystem.format_directory_size(http_cache_location)
-        wheels_cache_size = filesystem.format_directory_size(
-            wheels_cache_location
+        wheels_cache_size = filesystem.format_directory_size(wheels_cache_location)
+
+        message = (
+            textwrap.dedent(
+                """
+                    Package index page cache location: {http_cache_location}
+                    Package index page cache size: {http_cache_size}
+                    Number of HTTP files: {num_http_files}
+                    Locally built wheels location: {wheels_cache_location}
+                    Locally built wheels size: {wheels_cache_size}
+                    Number of locally built wheels: {package_count}
+                """
+            )
+            .format(
+                http_cache_location=http_cache_location,
+                http_cache_size=http_cache_size,
+                num_http_files=num_http_files,
+                wheels_cache_location=wheels_cache_location,
+                package_count=num_packages,
+                wheels_cache_size=wheels_cache_size,
+            )
+            .strip()
         )
 
-        message = textwrap.dedent("""
-            Package index page cache location: {http_cache_location}
-            Package index page cache size: {http_cache_size}
-            Number of HTTP files: {num_http_files}
-            Wheels location: {wheels_cache_location}
-            Wheels size: {wheels_cache_size}
-            Number of wheels: {package_count}
-        """).format(
-            http_cache_location=http_cache_location,
-            http_cache_size=http_cache_size,
-            num_http_files=num_http_files,
-            wheels_cache_location=wheels_cache_location,
-            package_count=num_packages,
-            wheels_cache_size=wheels_cache_size,
-        ).strip()
-
         logger.info(message)
 
-    def list_cache_items(self, options, args):
-        # type: (Values, List[Any]) -> None
+    def list_cache_items(self, options: Values, args: List[Any]) -> None:
         if len(args) > 1:
-            raise CommandError('Too many arguments')
+            raise CommandError("Too many arguments")
 
         if args:
             pattern = args[0]
         else:
-            pattern = '*'
+            pattern = "*"
 
         files = self._find_wheels(options, pattern)
-        if options.list_format == 'human':
+        if options.list_format == "human":
             self.format_for_human(files)
         else:
             self.format_for_abspath(files)
 
-    def format_for_human(self, files):
-        # type: (List[str]) -> None
+    def format_for_human(self, files: List[str]) -> None:
         if not files:
-            logger.info('Nothing cached.')
+            logger.info("No locally built wheels cached.")
             return
 
         results = []
         for filename in files:
             wheel = os.path.basename(filename)
             size = filesystem.format_file_size(filename)
-            results.append(f' - {wheel} ({size})')
-        logger.info('Cache contents:\n')
-        logger.info('\n'.join(sorted(results)))
+            results.append(f" - {wheel} ({size})")
+        logger.info("Cache contents:\n")
+        logger.info("\n".join(sorted(results)))
 
-    def format_for_abspath(self, files):
-        # type: (List[str]) -> None
+    def format_for_abspath(self, files: List[str]) -> None:
         if not files:
             return
 
@@ -163,49 +158,48 @@ class CacheCommand(Command):
         for filename in files:
             results.append(filename)
 
-        logger.info('\n'.join(sorted(results)))
+        logger.info("\n".join(sorted(results)))
 
-    def remove_cache_items(self, options, args):
-        # type: (Values, List[Any]) -> None
+    def remove_cache_items(self, options: Values, args: List[Any]) -> None:
         if len(args) > 1:
-            raise CommandError('Too many arguments')
+            raise CommandError("Too many arguments")
 
         if not args:
-            raise CommandError('Please provide a pattern')
+            raise CommandError("Please provide a pattern")
 
         files = self._find_wheels(options, args[0])
 
-        # Only fetch http files if no specific pattern given
-        if args[0] == '*':
+        no_matching_msg = "No matching packages"
+        if args[0] == "*":
+            # Only fetch http files if no specific pattern given
             files += self._find_http_files(options)
+        else:
+            # Add the pattern to the log message
+            no_matching_msg += ' for pattern "{}"'.format(args[0])
 
         if not files:
-            raise CommandError('No matching packages')
+            logger.warning(no_matching_msg)
 
         for filename in files:
             os.unlink(filename)
-            logger.debug('Removed %s', filename)
-        logger.info('Files removed: %s', len(files))
+            logger.verbose("Removed %s", filename)
+        logger.info("Files removed: %s", len(files))
 
-    def purge_cache(self, options, args):
-        # type: (Values, List[Any]) -> None
+    def purge_cache(self, options: Values, args: List[Any]) -> None:
         if args:
-            raise CommandError('Too many arguments')
+            raise CommandError("Too many arguments")
 
-        return self.remove_cache_items(options, ['*'])
+        return self.remove_cache_items(options, ["*"])
 
-    def _cache_dir(self, options, subdir):
-        # type: (Values, str) -> str
+    def _cache_dir(self, options: Values, subdir: str) -> str:
         return os.path.join(options.cache_dir, subdir)
 
-    def _find_http_files(self, options):
-        # type: (Values) -> List[str]
-        http_dir = self._cache_dir(options, 'http')
-        return filesystem.find_files(http_dir, '*')
+    def _find_http_files(self, options: Values) -> List[str]:
+        http_dir = self._cache_dir(options, "http")
+        return filesystem.find_files(http_dir, "*")
 
-    def _find_wheels(self, options, pattern):
-        # type: (Values, str) -> List[str]
-        wheel_dir = self._cache_dir(options, 'wheels')
+    def _find_wheels(self, options: Values, pattern: str) -> List[str]:
+        wheel_dir = self._cache_dir(options, "wheels")
 
         # The wheel filename format, as specified in PEP 427, is:
         #     {distribution}-{version}(-{build})?-{python}-{abi}-{platform}.whl
diff --git a/env/Lib/site-packages/pip/_internal/commands/check.py b/env/Lib/site-packages/pip/_internal/commands/check.py
index 70aa5af2..5efd0a34 100644
--- a/env/Lib/site-packages/pip/_internal/commands/check.py
+++ b/env/Lib/site-packages/pip/_internal/commands/check.py
@@ -1,12 +1,13 @@
 import logging
 from optparse import Values
-from typing import Any, List
+from typing import List
 
 from pip._internal.cli.base_command import Command
 from pip._internal.cli.status_codes import ERROR, SUCCESS
 from pip._internal.operations.check import (
     check_package_set,
     create_package_set_from_installed,
+    warn_legacy_versions_and_specifiers,
 )
 from pip._internal.utils.misc import write_output
 
@@ -19,10 +20,9 @@ class CheckCommand(Command):
     usage = """
       %prog [options]"""
 
-    def run(self, options, args):
-        # type: (Values, List[Any]) -> int
-
+    def run(self, options: Values, args: List[str]) -> int:
         package_set, parsing_probs = create_package_set_from_installed()
+        warn_legacy_versions_and_specifiers(package_set)
         missing, conflicting = check_package_set(package_set)
 
         for project_name in missing:
@@ -30,7 +30,9 @@ class CheckCommand(Command):
             for dependency in missing[project_name]:
                 write_output(
                     "%s %s requires %s, which is not installed.",
-                    project_name, version, dependency[0],
+                    project_name,
+                    version,
+                    dependency[0],
                 )
 
         for project_name in conflicting:
@@ -38,7 +40,11 @@ class CheckCommand(Command):
             for dep_name, dep_version, req in conflicting[project_name]:
                 write_output(
                     "%s %s has requirement %s, but you have %s %s.",
-                    project_name, version, req, dep_name, dep_version,
+                    project_name,
+                    version,
+                    req,
+                    dep_name,
+                    dep_version,
                 )
 
         if missing or conflicting or parsing_probs:
diff --git a/env/Lib/site-packages/pip/_internal/commands/completion.py b/env/Lib/site-packages/pip/_internal/commands/completion.py
index 92cb7882..30233fc7 100644
--- a/env/Lib/site-packages/pip/_internal/commands/completion.py
+++ b/env/Lib/site-packages/pip/_internal/commands/completion.py
@@ -12,7 +12,7 @@ BASE_COMPLETION = """
 """
 
 COMPLETION_SCRIPTS = {
-    'bash': """
+    "bash": """
         _pip_completion()
         {{
             COMPREPLY=( $( COMP_WORDS="${{COMP_WORDS[*]}}" \\
@@ -21,18 +21,13 @@ COMPLETION_SCRIPTS = {
         }}
         complete -o default -F _pip_completion {prog}
     """,
-    'zsh': """
-        function _pip_completion {{
-          local words cword
-          read -Ac words
-          read -cn cword
-          reply=( $( COMP_WORDS="$words[*]" \\
-                     COMP_CWORD=$(( cword-1 )) \\
-                     PIP_AUTO_COMPLETE=1 $words[1] 2>/dev/null ))
-        }}
-        compctl -K _pip_completion {prog}
+    "zsh": """
+        #compdef -P pip[0-9.]#
+        compadd $( COMP_WORDS="$words[*]" \\
+                   COMP_CWORD=$((CURRENT-1)) \\
+                   PIP_AUTO_COMPLETE=1 $words[1] 2>/dev/null )
     """,
-    'fish': """
+    "fish": """
         function __fish_complete_pip
             set -lx COMP_WORDS (commandline -o) ""
             set -lx COMP_CWORD ( \\
@@ -43,6 +38,28 @@ COMPLETION_SCRIPTS = {
         end
         complete -fa "(__fish_complete_pip)" -c {prog}
     """,
+    "powershell": """
+        if ((Test-Path Function:\\TabExpansion) -and -not `
+            (Test-Path Function:\\_pip_completeBackup)) {{
+            Rename-Item Function:\\TabExpansion _pip_completeBackup
+        }}
+        function TabExpansion($line, $lastWord) {{
+            $lastBlock = [regex]::Split($line, '[|;]')[-1].TrimStart()
+            if ($lastBlock.StartsWith("{prog} ")) {{
+                $Env:COMP_WORDS=$lastBlock
+                $Env:COMP_CWORD=$lastBlock.Split().Length - 1
+                $Env:PIP_AUTO_COMPLETE=1
+                (& {prog}).Split()
+                Remove-Item Env:COMP_WORDS
+                Remove-Item Env:COMP_CWORD
+                Remove-Item Env:PIP_AUTO_COMPLETE
+            }}
+            elseif (Test-Path Function:\\_pip_completeBackup) {{
+                # Fall back on existing tab expansion
+                _pip_completeBackup $line $lastWord
+            }}
+        }}
+    """,
 }
 
 
@@ -51,43 +68,54 @@ class CompletionCommand(Command):
 
     ignore_require_venv = True
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
+        self.cmd_opts.add_option(
+            "--bash",
+            "-b",
+            action="store_const",
+            const="bash",
+            dest="shell",
+            help="Emit completion code for bash",
+        )
         self.cmd_opts.add_option(
-            '--bash', '-b',
-            action='store_const',
-            const='bash',
-            dest='shell',
-            help='Emit completion code for bash')
+            "--zsh",
+            "-z",
+            action="store_const",
+            const="zsh",
+            dest="shell",
+            help="Emit completion code for zsh",
+        )
         self.cmd_opts.add_option(
-            '--zsh', '-z',
-            action='store_const',
-            const='zsh',
-            dest='shell',
-            help='Emit completion code for zsh')
+            "--fish",
+            "-f",
+            action="store_const",
+            const="fish",
+            dest="shell",
+            help="Emit completion code for fish",
+        )
         self.cmd_opts.add_option(
-            '--fish', '-f',
-            action='store_const',
-            const='fish',
-            dest='shell',
-            help='Emit completion code for fish')
+            "--powershell",
+            "-p",
+            action="store_const",
+            const="powershell",
+            dest="shell",
+            help="Emit completion code for powershell",
+        )
 
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        #  type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         """Prints the completion code of the given shell"""
         shells = COMPLETION_SCRIPTS.keys()
-        shell_options = ['--' + shell for shell in sorted(shells)]
+        shell_options = ["--" + shell for shell in sorted(shells)]
         if options.shell in shells:
             script = textwrap.dedent(
-                COMPLETION_SCRIPTS.get(options.shell, '').format(
-                    prog=get_prog())
+                COMPLETION_SCRIPTS.get(options.shell, "").format(prog=get_prog())
             )
             print(BASE_COMPLETION.format(script=script, shell=options.shell))
             return SUCCESS
         else:
             sys.stderr.write(
-                'ERROR: You must pass {}\n' .format(' or '.join(shell_options))
+                "ERROR: You must pass {}\n".format(" or ".join(shell_options))
             )
             return SUCCESS
diff --git a/env/Lib/site-packages/pip/_internal/commands/configuration.py b/env/Lib/site-packages/pip/_internal/commands/configuration.py
index e13f7142..84b134e4 100644
--- a/env/Lib/site-packages/pip/_internal/commands/configuration.py
+++ b/env/Lib/site-packages/pip/_internal/commands/configuration.py
@@ -27,14 +27,20 @@ class ConfigurationCommand(Command):
 
     - list: List the active configuration (or from the file specified)
     - edit: Edit the configuration file in an editor
-    - get: Get the value associated with name
-    - set: Set the name=value
-    - unset: Unset the value associated with name
+    - get: Get the value associated with command.option
+    - set: Set the command.option=value
+    - unset: Unset the value associated with command.option
     - debug: List the configuration files and values defined under them
 
+    Configuration keys should be dot separated command and option name,
+    with the special prefix "global" affecting any command. For example,
+    "pip config set global.index-url https://example.org/" would configure
+    the index url for all commands, but "pip config set download.timeout 10"
+    would configure a 10 second timeout only for "pip download" commands.
+
     If none of --user, --global and --site are passed, a virtual
     environment configuration file is used if one is active and the file
-    exists. Otherwise, all modifications happen on the to the user file by
+    exists. Otherwise, all modifications happen to the user file by
     default.
     """
 
@@ -43,53 +49,51 @@ class ConfigurationCommand(Command):
         %prog [<file-option>] list
         %prog [<file-option>] [--editor <editor-path>] edit
 
-        %prog [<file-option>] get name
-        %prog [<file-option>] set name value
-        %prog [<file-option>] unset name
+        %prog [<file-option>] get command.option
+        %prog [<file-option>] set command.option value
+        %prog [<file-option>] unset command.option
         %prog [<file-option>] debug
     """
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '--editor',
-            dest='editor',
-            action='store',
+            "--editor",
+            dest="editor",
+            action="store",
             default=None,
             help=(
-                'Editor to use to edit the file. Uses VISUAL or EDITOR '
-                'environment variables if not provided.'
-            )
+                "Editor to use to edit the file. Uses VISUAL or EDITOR "
+                "environment variables if not provided."
+            ),
         )
 
         self.cmd_opts.add_option(
-            '--global',
-            dest='global_file',
-            action='store_true',
+            "--global",
+            dest="global_file",
+            action="store_true",
             default=False,
-            help='Use the system-wide configuration file only'
+            help="Use the system-wide configuration file only",
         )
 
         self.cmd_opts.add_option(
-            '--user',
-            dest='user_file',
-            action='store_true',
+            "--user",
+            dest="user_file",
+            action="store_true",
             default=False,
-            help='Use the user configuration file only'
+            help="Use the user configuration file only",
         )
 
         self.cmd_opts.add_option(
-            '--site',
-            dest='site_file',
-            action='store_true',
+            "--site",
+            dest="site_file",
+            action="store_true",
             default=False,
-            help='Use the current environment configuration file only'
+            help="Use the current environment configuration file only",
         )
 
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         handlers = {
             "list": self.list_values,
             "edit": self.open_in_editor,
@@ -134,13 +138,16 @@ class ConfigurationCommand(Command):
 
         return SUCCESS
 
-    def _determine_file(self, options, need_value):
-        # type: (Values, bool) -> Optional[Kind]
-        file_options = [key for key, value in (
-            (kinds.USER, options.user_file),
-            (kinds.GLOBAL, options.global_file),
-            (kinds.SITE, options.site_file),
-        ) if value]
+    def _determine_file(self, options: Values, need_value: bool) -> Optional[Kind]:
+        file_options = [
+            key
+            for key, value in (
+                (kinds.USER, options.user_file),
+                (kinds.GLOBAL, options.global_file),
+                (kinds.SITE, options.site_file),
+            )
+            if value
+        ]
 
         if not file_options:
             if not need_value:
@@ -161,36 +168,31 @@ class ConfigurationCommand(Command):
             "(--user, --site, --global) to perform."
         )
 
-    def list_values(self, options, args):
-        # type: (Values, List[str]) -> None
+    def list_values(self, options: Values, args: List[str]) -> None:
         self._get_n_args(args, "list", n=0)
 
         for key, value in sorted(self.configuration.items()):
             write_output("%s=%r", key, value)
 
-    def get_name(self, options, args):
-        # type: (Values, List[str]) -> None
+    def get_name(self, options: Values, args: List[str]) -> None:
         key = self._get_n_args(args, "get [name]", n=1)
         value = self.configuration.get_value(key)
 
         write_output("%s", value)
 
-    def set_name_value(self, options, args):
-        # type: (Values, List[str]) -> None
+    def set_name_value(self, options: Values, args: List[str]) -> None:
         key, value = self._get_n_args(args, "set [name] [value]", n=2)
         self.configuration.set_value(key, value)
 
         self._save_configuration()
 
-    def unset_name(self, options, args):
-        # type: (Values, List[str]) -> None
+    def unset_name(self, options: Values, args: List[str]) -> None:
         key = self._get_n_args(args, "unset [name]", n=1)
         self.configuration.unset_value(key)
 
         self._save_configuration()
 
-    def list_config_values(self, options, args):
-        # type: (Values, List[str]) -> None
+    def list_config_values(self, options: Values, args: List[str]) -> None:
         """List config key-value pairs across different config files"""
         self._get_n_args(args, "debug", n=0)
 
@@ -202,51 +204,53 @@ class ConfigurationCommand(Command):
             for fname in files:
                 with indent_log():
                     file_exists = os.path.exists(fname)
-                    write_output("%s, exists: %r",
-                                 fname, file_exists)
+                    write_output("%s, exists: %r", fname, file_exists)
                     if file_exists:
                         self.print_config_file_values(variant)
 
-    def print_config_file_values(self, variant):
-        # type: (Kind) -> None
+    def print_config_file_values(self, variant: Kind) -> None:
         """Get key-value pairs from the file of a variant"""
-        for name, value in self.configuration.\
-                get_values_in_config(variant).items():
+        for name, value in self.configuration.get_values_in_config(variant).items():
             with indent_log():
                 write_output("%s: %s", name, value)
 
-    def print_env_var_values(self):
-        # type: () -> None
+    def print_env_var_values(self) -> None:
         """Get key-values pairs present as environment variables"""
-        write_output("%s:", 'env_var')
+        write_output("%s:", "env_var")
         with indent_log():
             for key, value in sorted(self.configuration.get_environ_vars()):
-                env_var = f'PIP_{key.upper()}'
+                env_var = f"PIP_{key.upper()}"
                 write_output("%s=%r", env_var, value)
 
-    def open_in_editor(self, options, args):
-        # type: (Values, List[str]) -> None
+    def open_in_editor(self, options: Values, args: List[str]) -> None:
         editor = self._determine_editor(options)
 
         fname = self.configuration.get_file_to_edit()
         if fname is None:
             raise PipError("Could not determine appropriate file.")
+        elif '"' in fname:
+            # This shouldn't happen, unless we see a username like that.
+            # If that happens, we'd appreciate a pull request fixing this.
+            raise PipError(
+                f'Can not open an editor for a file name containing "\n{fname}'
+            )
 
         try:
-            subprocess.check_call([editor, fname])
+            subprocess.check_call(f'{editor} "{fname}"', shell=True)
+        except FileNotFoundError as e:
+            if not e.filename:
+                e.filename = editor
+            raise
         except subprocess.CalledProcessError as e:
             raise PipError(
-                "Editor Subprocess exited with exit code {}"
-                .format(e.returncode)
+                "Editor Subprocess exited with exit code {}".format(e.returncode)
             )
 
-    def _get_n_args(self, args, example, n):
-        # type: (List[str], str, int) -> Any
-        """Helper to make sure the command got the right number of arguments
-        """
+    def _get_n_args(self, args: List[str], example: str, n: int) -> Any:
+        """Helper to make sure the command got the right number of arguments"""
         if len(args) != n:
             msg = (
-                'Got unexpected number of arguments, expected {}. '
+                "Got unexpected number of arguments, expected {}. "
                 '(example: "{} config {}")'
             ).format(n, get_prog(), example)
             raise PipError(msg)
@@ -256,8 +260,7 @@ class ConfigurationCommand(Command):
         else:
             return args
 
-    def _save_configuration(self):
-        # type: () -> None
+    def _save_configuration(self) -> None:
         # We successfully ran a modifying command. Need to save the
         # configuration.
         try:
@@ -268,8 +271,7 @@ class ConfigurationCommand(Command):
             )
             raise PipError("Internal Error.")
 
-    def _determine_editor(self, options):
-        # type: (Values) -> str
+    def _determine_editor(self, options: Values) -> str:
         if options.editor is not None:
             return options.editor
         elif "VISUAL" in os.environ:
diff --git a/env/Lib/site-packages/pip/_internal/commands/debug.py b/env/Lib/site-packages/pip/_internal/commands/debug.py
index ead5119a..2a3e7d29 100644
--- a/env/Lib/site-packages/pip/_internal/commands/debug.py
+++ b/env/Lib/site-packages/pip/_internal/commands/debug.py
@@ -1,3 +1,4 @@
+import importlib.resources
 import locale
 import logging
 import os
@@ -10,7 +11,6 @@ import pip._vendor
 from pip._vendor.certifi import where
 from pip._vendor.packaging.version import parse as parse_version
 
-from pip import __file__ as pip_location
 from pip._internal.cli import cmdoptions
 from pip._internal.cli.base_command import Command
 from pip._internal.cli.cmdoptions import make_target_python
@@ -23,61 +23,47 @@ from pip._internal.utils.misc import get_pip_version
 logger = logging.getLogger(__name__)
 
 
-def show_value(name, value):
-    # type: (str, Any) -> None
-    logger.info('%s: %s', name, value)
+def show_value(name: str, value: Any) -> None:
+    logger.info("%s: %s", name, value)
 
 
-def show_sys_implementation():
-    # type: () -> None
-    logger.info('sys.implementation:')
+def show_sys_implementation() -> None:
+    logger.info("sys.implementation:")
     implementation_name = sys.implementation.name
     with indent_log():
-        show_value('name', implementation_name)
+        show_value("name", implementation_name)
 
 
-def create_vendor_txt_map():
-    # type: () -> Dict[str, str]
-    vendor_txt_path = os.path.join(
-        os.path.dirname(pip_location),
-        '_vendor',
-        'vendor.txt'
-    )
-
-    with open(vendor_txt_path) as f:
+def create_vendor_txt_map() -> Dict[str, str]:
+    with importlib.resources.open_text("pip._vendor", "vendor.txt") as f:
         # Purge non version specifying lines.
         # Also, remove any space prefix or suffixes (including comments).
-        lines = [line.strip().split(' ', 1)[0]
-                 for line in f.readlines() if '==' in line]
+        lines = [
+            line.strip().split(" ", 1)[0] for line in f.readlines() if "==" in line
+        ]
 
     # Transform into "module" -> version dict.
-    return dict(line.split('==', 1) for line in lines)  # type: ignore
+    return dict(line.split("==", 1) for line in lines)
 
 
-def get_module_from_module_name(module_name):
-    # type: (str) -> ModuleType
+def get_module_from_module_name(module_name: str) -> ModuleType:
     # Module name can be uppercase in vendor.txt for some reason...
-    module_name = module_name.lower()
+    module_name = module_name.lower().replace("-", "_")
     # PATCH: setuptools is actually only pkg_resources.
-    if module_name == 'setuptools':
-        module_name = 'pkg_resources'
-
-    __import__(
-        f'pip._vendor.{module_name}',
-        globals(),
-        locals(),
-        level=0
-    )
+    if module_name == "setuptools":
+        module_name = "pkg_resources"
+
+    __import__(f"pip._vendor.{module_name}", globals(), locals(), level=0)
     return getattr(pip._vendor, module_name)
 
 
-def get_vendor_version_from_module(module_name):
-    # type: (str) -> Optional[str]
+def get_vendor_version_from_module(module_name: str) -> Optional[str]:
     module = get_module_from_module_name(module_name)
-    version = getattr(module, '__version__', None)
+    version = getattr(module, "__version__", None)
 
     if not version:
         # Try to find version in debundled module info.
+        assert module.__file__ is not None
         env = get_environment([os.path.dirname(module.__file__)])
         dist = env.get_distribution(module_name)
         if dist:
@@ -86,35 +72,36 @@ def get_vendor_version_from_module(module_name):
     return version
 
 
-def show_actual_vendor_versions(vendor_txt_versions):
-    # type: (Dict[str, str]) -> None
+def show_actual_vendor_versions(vendor_txt_versions: Dict[str, str]) -> None:
     """Log the actual version and print extra info if there is
     a conflict or if the actual version could not be imported.
     """
     for module_name, expected_version in vendor_txt_versions.items():
-        extra_message = ''
+        extra_message = ""
         actual_version = get_vendor_version_from_module(module_name)
         if not actual_version:
-            extra_message = ' (Unable to locate actual module version, using'\
-                            ' vendor.txt specified version)'
+            extra_message = (
+                " (Unable to locate actual module version, using"
+                " vendor.txt specified version)"
+            )
             actual_version = expected_version
         elif parse_version(actual_version) != parse_version(expected_version):
-            extra_message = ' (CONFLICT: vendor.txt suggests version should'\
-                            ' be {})'.format(expected_version)
-        logger.info('%s==%s%s', module_name, actual_version, extra_message)
+            extra_message = (
+                " (CONFLICT: vendor.txt suggests version should"
+                " be {})".format(expected_version)
+            )
+        logger.info("%s==%s%s", module_name, actual_version, extra_message)
 
 
-def show_vendor_versions():
-    # type: () -> None
-    logger.info('vendored library versions:')
+def show_vendor_versions() -> None:
+    logger.info("vendored library versions:")
 
     vendor_txt_versions = create_vendor_txt_map()
     with indent_log():
         show_actual_vendor_versions(vendor_txt_versions)
 
 
-def show_tags(options):
-    # type: (Values) -> None
+def show_tags(options: Values) -> None:
     tag_limit = 10
 
     target_python = make_target_python(options)
@@ -122,11 +109,11 @@ def show_tags(options):
 
     # Display the target options that were explicitly provided.
     formatted_target = target_python.format_given()
-    suffix = ''
+    suffix = ""
     if formatted_target:
-        suffix = f' (target: {formatted_target})'
+        suffix = f" (target: {formatted_target})"
 
-    msg = 'Compatible tags: {}{}'.format(len(tags), suffix)
+    msg = "Compatible tags: {}{}".format(len(tags), suffix)
     logger.info(msg)
 
     if options.verbose < 1 and len(tags) > tag_limit:
@@ -141,30 +128,28 @@ def show_tags(options):
 
         if tags_limited:
             msg = (
-                '...\n'
-                '[First {tag_limit} tags shown. Pass --verbose to show all.]'
+                "...\n[First {tag_limit} tags shown. Pass --verbose to show all.]"
             ).format(tag_limit=tag_limit)
             logger.info(msg)
 
 
-def ca_bundle_info(config):
-    # type: (Configuration) -> str
+def ca_bundle_info(config: Configuration) -> str:
     levels = set()
     for key, _ in config.items():
-        levels.add(key.split('.')[0])
+        levels.add(key.split(".")[0])
 
     if not levels:
         return "Not specified"
 
-    levels_that_override_global = ['install', 'wheel', 'download']
+    levels_that_override_global = ["install", "wheel", "download"]
     global_overriding_level = [
         level for level in levels if level in levels_that_override_global
     ]
     if not global_overriding_level:
-        return 'global'
+        return "global"
 
-    if 'global' in levels:
-        levels.remove('global')
+    if "global" in levels:
+        levels.remove("global")
     return ", ".join(levels)
 
 
@@ -177,34 +162,33 @@ class DebugCommand(Command):
       %prog <options>"""
     ignore_require_venv = True
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         cmdoptions.add_target_python_options(self.cmd_opts)
         self.parser.insert_option_group(0, self.cmd_opts)
         self.parser.config.load()
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         logger.warning(
             "This command is only meant for debugging. "
             "Do not use this with automation for parsing and getting these "
             "details, since the output and options of this command may "
             "change without notice."
         )
-        show_value('pip version', get_pip_version())
-        show_value('sys.version', sys.version)
-        show_value('sys.executable', sys.executable)
-        show_value('sys.getdefaultencoding', sys.getdefaultencoding())
-        show_value('sys.getfilesystemencoding', sys.getfilesystemencoding())
+        show_value("pip version", get_pip_version())
+        show_value("sys.version", sys.version)
+        show_value("sys.executable", sys.executable)
+        show_value("sys.getdefaultencoding", sys.getdefaultencoding())
+        show_value("sys.getfilesystemencoding", sys.getfilesystemencoding())
         show_value(
-            'locale.getpreferredencoding', locale.getpreferredencoding(),
+            "locale.getpreferredencoding",
+            locale.getpreferredencoding(),
         )
-        show_value('sys.platform', sys.platform)
+        show_value("sys.platform", sys.platform)
         show_sys_implementation()
 
         show_value("'cert' config value", ca_bundle_info(self.parser.config))
-        show_value("REQUESTS_CA_BUNDLE", os.environ.get('REQUESTS_CA_BUNDLE'))
-        show_value("CURL_CA_BUNDLE", os.environ.get('CURL_CA_BUNDLE'))
+        show_value("REQUESTS_CA_BUNDLE", os.environ.get("REQUESTS_CA_BUNDLE"))
+        show_value("CURL_CA_BUNDLE", os.environ.get("CURL_CA_BUNDLE"))
         show_value("pip._vendor.certifi.where()", where())
         show_value("pip._vendor.DEBUNDLED", pip._vendor.DEBUNDLED)
 
diff --git a/env/Lib/site-packages/pip/_internal/commands/download.py b/env/Lib/site-packages/pip/_internal/commands/download.py
index 19f8d6c0..54247a78 100644
--- a/env/Lib/site-packages/pip/_internal/commands/download.py
+++ b/env/Lib/site-packages/pip/_internal/commands/download.py
@@ -7,7 +7,8 @@ from pip._internal.cli import cmdoptions
 from pip._internal.cli.cmdoptions import make_target_python
 from pip._internal.cli.req_command import RequirementCommand, with_cleanup
 from pip._internal.cli.status_codes import SUCCESS
-from pip._internal.req.req_tracker import get_requirement_tracker
+from pip._internal.operations.build.build_tracker import get_build_tracker
+from pip._internal.req.req_install import check_legacy_setup_py_options
 from pip._internal.utils.misc import ensure_dir, normalize_path, write_output
 from pip._internal.utils.temp_dir import TempDirectory
 
@@ -34,11 +35,9 @@ class DownloadCommand(RequirementCommand):
       %prog [options] <local project path> ...
       %prog [options] <archive url/path> ..."""
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(cmdoptions.constraints())
         self.cmd_opts.add_option(cmdoptions.requirements())
-        self.cmd_opts.add_option(cmdoptions.build_dir())
         self.cmd_opts.add_option(cmdoptions.no_deps())
         self.cmd_opts.add_option(cmdoptions.global_options())
         self.cmd_opts.add_option(cmdoptions.no_binary())
@@ -51,14 +50,18 @@ class DownloadCommand(RequirementCommand):
         self.cmd_opts.add_option(cmdoptions.no_build_isolation())
         self.cmd_opts.add_option(cmdoptions.use_pep517())
         self.cmd_opts.add_option(cmdoptions.no_use_pep517())
+        self.cmd_opts.add_option(cmdoptions.check_build_deps())
         self.cmd_opts.add_option(cmdoptions.ignore_requires_python())
 
         self.cmd_opts.add_option(
-            '-d', '--dest', '--destination-dir', '--destination-directory',
-            dest='download_dir',
-            metavar='dir',
+            "-d",
+            "--dest",
+            "--destination-dir",
+            "--destination-directory",
+            dest="download_dir",
+            metavar="dir",
             default=os.curdir,
-            help=("Download packages into <dir>."),
+            help="Download packages into <dir>.",
         )
 
         cmdoptions.add_target_python_options(self.cmd_opts)
@@ -72,9 +75,7 @@ class DownloadCommand(RequirementCommand):
         self.parser.insert_option_group(0, self.cmd_opts)
 
     @with_cleanup
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
-
+    def run(self, options: Values, args: List[str]) -> int:
         options.ignore_installed = True
         # editable doesn't really make sense for `pip download`, but the bowels
         # of the RequirementSet code require that property.
@@ -95,7 +96,7 @@ class DownloadCommand(RequirementCommand):
             ignore_requires_python=options.ignore_requires_python,
         )
 
-        req_tracker = self.enter_context(get_requirement_tracker())
+        build_tracker = self.enter_context(get_build_tracker())
 
         directory = TempDirectory(
             delete=not options.no_clean,
@@ -104,15 +105,17 @@ class DownloadCommand(RequirementCommand):
         )
 
         reqs = self.get_requirements(args, options, finder, session)
+        check_legacy_setup_py_options(options, reqs)
 
         preparer = self.make_requirement_preparer(
             temp_build_dir=directory,
             options=options,
-            req_tracker=req_tracker,
+            build_tracker=build_tracker,
             session=session,
             finder=finder,
             download_dir=options.download_dir,
             use_user_site=False,
+            verbosity=self.verbosity,
         )
 
         resolver = self.make_resolver(
@@ -120,22 +123,25 @@ class DownloadCommand(RequirementCommand):
             finder=finder,
             options=options,
             ignore_requires_python=options.ignore_requires_python,
+            use_pep517=options.use_pep517,
             py_version_info=options.python_version,
         )
 
         self.trace_basic_info(finder)
 
-        requirement_set = resolver.resolve(
-            reqs, check_supported_wheels=True
-        )
+        requirement_set = resolver.resolve(reqs, check_supported_wheels=True)
 
-        downloaded = []  # type: List[str]
+        downloaded: List[str] = []
         for req in requirement_set.requirements.values():
             if req.satisfied_by is None:
                 assert req.name is not None
                 preparer.save_linked_requirement(req)
                 downloaded.append(req.name)
+
+        preparer.prepare_linked_requirements_more(requirement_set.requirements.values())
+        requirement_set.warn_legacy_versions_and_specifiers()
+
         if downloaded:
-            write_output('Successfully downloaded %s', ' '.join(downloaded))
+            write_output("Successfully downloaded %s", " ".join(downloaded))
 
         return SUCCESS
diff --git a/env/Lib/site-packages/pip/_internal/commands/freeze.py b/env/Lib/site-packages/pip/_internal/commands/freeze.py
index 430d1018..fd9d88a8 100644
--- a/env/Lib/site-packages/pip/_internal/commands/freeze.py
+++ b/env/Lib/site-packages/pip/_internal/commands/freeze.py
@@ -1,15 +1,25 @@
 import sys
 from optparse import Values
-from typing import List
+from typing import AbstractSet, List
 
 from pip._internal.cli import cmdoptions
 from pip._internal.cli.base_command import Command
 from pip._internal.cli.status_codes import SUCCESS
 from pip._internal.operations.freeze import freeze
 from pip._internal.utils.compat import stdlib_pkgs
-from pip._internal.utils.deprecation import deprecated
 
-DEV_PKGS = {'pip', 'setuptools', 'distribute', 'wheel'}
+
+def _should_suppress_build_backends() -> bool:
+    return sys.version_info < (3, 12)
+
+
+def _dev_pkgs() -> AbstractSet[str]:
+    pkgs = {"pip"}
+
+    if _should_suppress_build_backends():
+        pkgs |= {"setuptools", "distribute", "wheel"}
+
+    return pkgs
 
 
 class FreezeCommand(Command):
@@ -23,76 +33,70 @@ class FreezeCommand(Command):
       %prog [options]"""
     log_streams = ("ext://sys.stderr", "ext://sys.stderr")
 
-    def add_options(self):
-        # type: () -> None
-        self.cmd_opts.add_option(
-            '-r', '--requirement',
-            dest='requirements',
-            action='append',
-            default=[],
-            metavar='file',
-            help="Use the order in the given requirements file and its "
-                 "comments when generating output. This option can be "
-                 "used multiple times.")
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-f', '--find-links',
-            dest='find_links',
-            action='append',
+            "-r",
+            "--requirement",
+            dest="requirements",
+            action="append",
             default=[],
-            metavar='URL',
-            help='URL for finding packages, which will be added to the '
-                 'output.')
+            metavar="file",
+            help=(
+                "Use the order in the given requirements file and its "
+                "comments when generating output. This option can be "
+                "used multiple times."
+            ),
+        )
         self.cmd_opts.add_option(
-            '-l', '--local',
-            dest='local',
-            action='store_true',
+            "-l",
+            "--local",
+            dest="local",
+            action="store_true",
             default=False,
-            help='If in a virtualenv that has global access, do not output '
-                 'globally-installed packages.')
+            help=(
+                "If in a virtualenv that has global access, do not output "
+                "globally-installed packages."
+            ),
+        )
         self.cmd_opts.add_option(
-            '--user',
-            dest='user',
-            action='store_true',
+            "--user",
+            dest="user",
+            action="store_true",
             default=False,
-            help='Only output packages installed in user-site.')
+            help="Only output packages installed in user-site.",
+        )
         self.cmd_opts.add_option(cmdoptions.list_path())
         self.cmd_opts.add_option(
-            '--all',
-            dest='freeze_all',
-            action='store_true',
-            help='Do not skip these packages in the output:'
-                 ' {}'.format(', '.join(DEV_PKGS)))
+            "--all",
+            dest="freeze_all",
+            action="store_true",
+            help=(
+                "Do not skip these packages in the output:"
+                " {}".format(", ".join(_dev_pkgs()))
+            ),
+        )
         self.cmd_opts.add_option(
-            '--exclude-editable',
-            dest='exclude_editable',
-            action='store_true',
-            help='Exclude editable package from output.')
+            "--exclude-editable",
+            dest="exclude_editable",
+            action="store_true",
+            help="Exclude editable package from output.",
+        )
         self.cmd_opts.add_option(cmdoptions.list_exclude())
 
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         skip = set(stdlib_pkgs)
         if not options.freeze_all:
-            skip.update(DEV_PKGS)
+            skip.update(_dev_pkgs())
 
         if options.excludes:
             skip.update(options.excludes)
 
         cmdoptions.check_list_path_option(options)
 
-        if options.find_links:
-            deprecated(
-                "--find-links option in pip freeze is deprecated.",
-                replacement=None,
-                gone_in="21.2",
-                issue=9069,
-            )
-
         for line in freeze(
             requirement=options.requirements,
-            find_links=options.find_links,
             local_only=options.local,
             user_only=options.user,
             paths=options.path,
@@ -100,5 +104,5 @@ class FreezeCommand(Command):
             skip=skip,
             exclude_editable=options.exclude_editable,
         ):
-            sys.stdout.write(line + '\n')
+            sys.stdout.write(line + "\n")
         return SUCCESS
diff --git a/env/Lib/site-packages/pip/_internal/commands/hash.py b/env/Lib/site-packages/pip/_internal/commands/hash.py
index bca48dcc..042dac81 100644
--- a/env/Lib/site-packages/pip/_internal/commands/hash.py
+++ b/env/Lib/site-packages/pip/_internal/commands/hash.py
@@ -20,38 +20,39 @@ class HashCommand(Command):
     installs.
     """
 
-    usage = '%prog [options] <file> ...'
+    usage = "%prog [options] <file> ..."
     ignore_require_venv = True
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-a', '--algorithm',
-            dest='algorithm',
+            "-a",
+            "--algorithm",
+            dest="algorithm",
             choices=STRONG_HASHES,
-            action='store',
+            action="store",
             default=FAVORITE_HASH,
-            help='The hash algorithm to use: one of {}'.format(
-                 ', '.join(STRONG_HASHES)))
+            help="The hash algorithm to use: one of {}".format(
+                ", ".join(STRONG_HASHES)
+            ),
+        )
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         if not args:
             self.parser.print_usage(sys.stderr)
             return ERROR
 
         algorithm = options.algorithm
         for path in args:
-            write_output('%s:\n--hash=%s:%s',
-                         path, algorithm, _hash_of_file(path, algorithm))
+            write_output(
+                "%s:\n--hash=%s:%s", path, algorithm, _hash_of_file(path, algorithm)
+            )
         return SUCCESS
 
 
-def _hash_of_file(path, algorithm):
-    # type: (str, str) -> str
+def _hash_of_file(path: str, algorithm: str) -> str:
     """Return the hash digest of a file."""
-    with open(path, 'rb') as archive:
+    with open(path, "rb") as archive:
         hash = hashlib.new(algorithm)
         for chunk in read_chunks(archive):
             hash.update(chunk)
diff --git a/env/Lib/site-packages/pip/_internal/commands/help.py b/env/Lib/site-packages/pip/_internal/commands/help.py
index 79d0eb49..62066318 100644
--- a/env/Lib/site-packages/pip/_internal/commands/help.py
+++ b/env/Lib/site-packages/pip/_internal/commands/help.py
@@ -13,8 +13,7 @@ class HelpCommand(Command):
       %prog <command>"""
     ignore_require_venv = True
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         from pip._internal.commands import (
             commands_dict,
             create_command,
@@ -34,7 +33,7 @@ class HelpCommand(Command):
             if guess:
                 msg.append(f'maybe you meant "{guess}"')
 
-            raise CommandError(' - '.join(msg))
+            raise CommandError(" - ".join(msg))
 
         command = create_command(cmd_name)
         command.parser.print_help()
diff --git a/env/Lib/site-packages/pip/_internal/commands/install.py b/env/Lib/site-packages/pip/_internal/commands/install.py
index 6932f5a6..f6a30080 100644
--- a/env/Lib/site-packages/pip/_internal/commands/install.py
+++ b/env/Lib/site-packages/pip/_internal/commands/install.py
@@ -1,13 +1,13 @@
 import errno
-import logging
+import json
 import operator
 import os
 import shutil
 import site
 from optparse import SUPPRESS_HELP, Values
-from typing import Iterable, List, Optional
+from typing import List, Optional
 
-from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.rich import print_json
 
 from pip._internal.cache import WheelCache
 from pip._internal.cli import cmdoptions
@@ -21,14 +21,19 @@ from pip._internal.cli.status_codes import ERROR, SUCCESS
 from pip._internal.exceptions import CommandError, InstallationError
 from pip._internal.locations import get_scheme
 from pip._internal.metadata import get_environment
-from pip._internal.models.format_control import FormatControl
+from pip._internal.models.installation_report import InstallationReport
+from pip._internal.operations.build.build_tracker import get_build_tracker
 from pip._internal.operations.check import ConflictDetails, check_install_conflicts
 from pip._internal.req import install_given_reqs
-from pip._internal.req.req_install import InstallRequirement
-from pip._internal.req.req_tracker import get_requirement_tracker
-from pip._internal.utils.distutils_args import parse_distutils_args
+from pip._internal.req.req_install import (
+    InstallRequirement,
+    check_legacy_setup_py_options,
+)
+from pip._internal.utils.compat import WINDOWS
 from pip._internal.utils.filesystem import test_writable_dir
+from pip._internal.utils.logging import getLogger
 from pip._internal.utils.misc import (
+    check_externally_managed,
     ensure_dir,
     get_pip_version,
     protect_pip_from_modification_on_windows,
@@ -39,24 +44,9 @@ from pip._internal.utils.virtualenv import (
     running_under_virtualenv,
     virtualenv_no_global,
 )
-from pip._internal.wheel_builder import (
-    BinaryAllowedPredicate,
-    build,
-    should_build_for_install_command,
-)
-
-logger = logging.getLogger(__name__)
-
+from pip._internal.wheel_builder import build, should_build_for_install_command
 
-def get_check_binary_allowed(format_control):
-    # type: (FormatControl) -> BinaryAllowedPredicate
-    def check_binary_allowed(req):
-        # type: (InstallRequirement) -> bool
-        canonical_name = canonicalize_name(req.name or "")
-        allowed_formats = format_control.get_allowed_formats(canonical_name)
-        return "binary" in allowed_formats
-
-    return check_binary_allowed
+logger = getLogger(__name__)
 
 
 class InstallCommand(RequirementCommand):
@@ -79,8 +69,7 @@ class InstallCommand(RequirementCommand):
       %prog [options] [-e] <local project path> ...
       %prog [options] <archive url/path> ..."""
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(cmdoptions.requirements())
         self.cmd_opts.add_option(cmdoptions.constraints())
         self.cmd_opts.add_option(cmdoptions.no_deps())
@@ -88,95 +77,129 @@ class InstallCommand(RequirementCommand):
 
         self.cmd_opts.add_option(cmdoptions.editable())
         self.cmd_opts.add_option(
-            '-t', '--target',
-            dest='target_dir',
-            metavar='dir',
+            "--dry-run",
+            action="store_true",
+            dest="dry_run",
+            default=False,
+            help=(
+                "Don't actually install anything, just print what would be. "
+                "Can be used in combination with --ignore-installed "
+                "to 'resolve' the requirements."
+            ),
+        )
+        self.cmd_opts.add_option(
+            "-t",
+            "--target",
+            dest="target_dir",
+            metavar="dir",
             default=None,
-            help='Install packages into <dir>. '
-                 'By default this will not replace existing files/folders in '
-                 '<dir>. Use --upgrade to replace existing packages in <dir> '
-                 'with new versions.'
+            help=(
+                "Install packages into <dir>. "
+                "By default this will not replace existing files/folders in "
+                "<dir>. Use --upgrade to replace existing packages in <dir> "
+                "with new versions."
+            ),
         )
         cmdoptions.add_target_python_options(self.cmd_opts)
 
         self.cmd_opts.add_option(
-            '--user',
-            dest='use_user_site',
-            action='store_true',
-            help="Install to the Python user install directory for your "
-                 "platform. Typically ~/.local/, or %APPDATA%\\Python on "
-                 "Windows. (See the Python documentation for site.USER_BASE "
-                 "for full details.)")
+            "--user",
+            dest="use_user_site",
+            action="store_true",
+            help=(
+                "Install to the Python user install directory for your "
+                "platform. Typically ~/.local/, or %APPDATA%\\Python on "
+                "Windows. (See the Python documentation for site.USER_BASE "
+                "for full details.)"
+            ),
+        )
         self.cmd_opts.add_option(
-            '--no-user',
-            dest='use_user_site',
-            action='store_false',
-            help=SUPPRESS_HELP)
+            "--no-user",
+            dest="use_user_site",
+            action="store_false",
+            help=SUPPRESS_HELP,
+        )
         self.cmd_opts.add_option(
-            '--root',
-            dest='root_path',
-            metavar='dir',
+            "--root",
+            dest="root_path",
+            metavar="dir",
             default=None,
-            help="Install everything relative to this alternate root "
-                 "directory.")
+            help="Install everything relative to this alternate root directory.",
+        )
         self.cmd_opts.add_option(
-            '--prefix',
-            dest='prefix_path',
-            metavar='dir',
+            "--prefix",
+            dest="prefix_path",
+            metavar="dir",
             default=None,
-            help="Installation prefix where lib, bin and other top-level "
-                 "folders are placed")
-
-        self.cmd_opts.add_option(cmdoptions.build_dir())
+            help=(
+                "Installation prefix where lib, bin and other top-level "
+                "folders are placed. Note that the resulting installation may "
+                "contain scripts and other resources which reference the "
+                "Python interpreter of pip, and not that of ``--prefix``. "
+                "See also the ``--python`` option if the intention is to "
+                "install packages into another (possibly pip-free) "
+                "environment."
+            ),
+        )
 
         self.cmd_opts.add_option(cmdoptions.src())
 
         self.cmd_opts.add_option(
-            '-U', '--upgrade',
-            dest='upgrade',
-            action='store_true',
-            help='Upgrade all specified packages to the newest available '
-                 'version. The handling of dependencies depends on the '
-                 'upgrade-strategy used.'
+            "-U",
+            "--upgrade",
+            dest="upgrade",
+            action="store_true",
+            help=(
+                "Upgrade all specified packages to the newest available "
+                "version. The handling of dependencies depends on the "
+                "upgrade-strategy used."
+            ),
         )
 
         self.cmd_opts.add_option(
-            '--upgrade-strategy',
-            dest='upgrade_strategy',
-            default='only-if-needed',
-            choices=['only-if-needed', 'eager'],
-            help='Determines how dependency upgrading should be handled '
-                 '[default: %default]. '
-                 '"eager" - dependencies are upgraded regardless of '
-                 'whether the currently installed version satisfies the '
-                 'requirements of the upgraded package(s). '
-                 '"only-if-needed" -  are upgraded only when they do not '
-                 'satisfy the requirements of the upgraded package(s).'
+            "--upgrade-strategy",
+            dest="upgrade_strategy",
+            default="only-if-needed",
+            choices=["only-if-needed", "eager"],
+            help=(
+                "Determines how dependency upgrading should be handled "
+                "[default: %default]. "
+                '"eager" - dependencies are upgraded regardless of '
+                "whether the currently installed version satisfies the "
+                "requirements of the upgraded package(s). "
+                '"only-if-needed" -  are upgraded only when they do not '
+                "satisfy the requirements of the upgraded package(s)."
+            ),
         )
 
         self.cmd_opts.add_option(
-            '--force-reinstall',
-            dest='force_reinstall',
-            action='store_true',
-            help='Reinstall all packages even if they are already '
-                 'up-to-date.')
+            "--force-reinstall",
+            dest="force_reinstall",
+            action="store_true",
+            help="Reinstall all packages even if they are already up-to-date.",
+        )
 
         self.cmd_opts.add_option(
-            '-I', '--ignore-installed',
-            dest='ignore_installed',
-            action='store_true',
-            help='Ignore the installed packages, overwriting them. '
-                 'This can break your system if the existing package '
-                 'is of a different version or was installed '
-                 'with a different package manager!'
+            "-I",
+            "--ignore-installed",
+            dest="ignore_installed",
+            action="store_true",
+            help=(
+                "Ignore the installed packages, overwriting them. "
+                "This can break your system if the existing package "
+                "is of a different version or was installed "
+                "with a different package manager!"
+            ),
         )
 
         self.cmd_opts.add_option(cmdoptions.ignore_requires_python())
         self.cmd_opts.add_option(cmdoptions.no_build_isolation())
         self.cmd_opts.add_option(cmdoptions.use_pep517())
         self.cmd_opts.add_option(cmdoptions.no_use_pep517())
+        self.cmd_opts.add_option(cmdoptions.check_build_deps())
+        self.cmd_opts.add_option(cmdoptions.override_externally_managed())
 
-        self.cmd_opts.add_option(cmdoptions.install_options())
+        self.cmd_opts.add_option(cmdoptions.config_settings())
         self.cmd_opts.add_option(cmdoptions.global_options())
 
         self.cmd_opts.add_option(
@@ -208,12 +231,12 @@ class InstallCommand(RequirementCommand):
             default=True,
             help="Do not warn about broken dependencies",
         )
-
         self.cmd_opts.add_option(cmdoptions.no_binary())
         self.cmd_opts.add_option(cmdoptions.only_binary())
         self.cmd_opts.add_option(cmdoptions.prefer_binary())
         self.cmd_opts.add_option(cmdoptions.require_hashes())
         self.cmd_opts.add_option(cmdoptions.progress_bar())
+        self.cmd_opts.add_option(cmdoptions.root_user_action())
 
         index_opts = cmdoptions.make_option_group(
             cmdoptions.index_group,
@@ -223,22 +246,51 @@ class InstallCommand(RequirementCommand):
         self.parser.insert_option_group(0, index_opts)
         self.parser.insert_option_group(0, self.cmd_opts)
 
+        self.cmd_opts.add_option(
+            "--report",
+            dest="json_report_file",
+            metavar="file",
+            default=None,
+            help=(
+                "Generate a JSON file describing what pip did to install "
+                "the provided requirements. "
+                "Can be used in combination with --dry-run and --ignore-installed "
+                "to 'resolve' the requirements. "
+                "When - is used as file name it writes to stdout. "
+                "When writing to stdout, please combine with the --quiet option "
+                "to avoid mixing pip logging output with JSON output."
+            ),
+        )
+
     @with_cleanup
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         if options.use_user_site and options.target_dir is not None:
             raise CommandError("Can not combine '--user' and '--target'")
 
-        cmdoptions.check_install_build_global(options)
+        # Check whether the environment we're installing into is externally
+        # managed, as specified in PEP 668. Specifying --root, --target, or
+        # --prefix disables the check, since there's no reliable way to locate
+        # the EXTERNALLY-MANAGED file for those cases. An exception is also
+        # made specifically for "--dry-run --report" for convenience.
+        installing_into_current_environment = (
+            not (options.dry_run and options.json_report_file)
+            and options.root_path is None
+            and options.target_dir is None
+            and options.prefix_path is None
+        )
+        if (
+            installing_into_current_environment
+            and not options.override_externally_managed
+        ):
+            check_externally_managed()
+
         upgrade_strategy = "to-satisfy-only"
         if options.upgrade:
             upgrade_strategy = options.upgrade_strategy
 
         cmdoptions.check_dist_restriction(options, check_target=True)
 
-        install_options = options.install_options or []
-
-        logger.debug("Using %s", get_pip_version())
+        logger.verbose("Using %s", get_pip_version())
         options.use_user_site = decide_user_install(
             options.use_user_site,
             prefix_path=options.prefix_path,
@@ -247,16 +299,19 @@ class InstallCommand(RequirementCommand):
             isolated_mode=options.isolated_mode,
         )
 
-        target_temp_dir = None  # type: Optional[TempDirectory]
-        target_temp_dir_path = None  # type: Optional[str]
+        target_temp_dir: Optional[TempDirectory] = None
+        target_temp_dir_path: Optional[str] = None
         if options.target_dir:
             options.ignore_installed = True
             options.target_dir = os.path.abspath(options.target_dir)
-            if (os.path.exists(options.target_dir) and not
-                    os.path.isdir(options.target_dir)):
+            if (
+                # fmt: off
+                os.path.exists(options.target_dir) and
+                not os.path.isdir(options.target_dir)
+                # fmt: on
+            ):
                 raise CommandError(
-                    "Target path exists but is not a directory, will not "
-                    "continue."
+                    "Target path exists but is not a directory, will not continue."
                 )
 
             # Create a target directory for using with the target option
@@ -275,9 +330,7 @@ class InstallCommand(RequirementCommand):
             target_python=target_python,
             ignore_requires_python=options.ignore_requires_python,
         )
-        wheel_cache = WheelCache(options.cache_dir, options.format_control)
-
-        req_tracker = self.enter_context(get_requirement_tracker())
+        build_tracker = self.enter_context(get_build_tracker())
 
         directory = TempDirectory(
             delete=not options.no_clean,
@@ -287,18 +340,24 @@ class InstallCommand(RequirementCommand):
 
         try:
             reqs = self.get_requirements(args, options, finder, session)
+            check_legacy_setup_py_options(options, reqs)
 
-            reject_location_related_install_options(
-                reqs, options.install_options
-            )
+            wheel_cache = WheelCache(options.cache_dir)
+
+            # Only when installing is it permitted to use PEP 660.
+            # In other circumstances (pip wheel, pip download) we generate
+            # regular (i.e. non editable) metadata and wheels.
+            for req in reqs:
+                req.permit_editable_wheels = True
 
             preparer = self.make_requirement_preparer(
                 temp_build_dir=directory,
                 options=options,
-                req_tracker=req_tracker,
+                build_tracker=build_tracker,
                 session=session,
                 finder=finder,
                 use_user_site=options.use_user_site,
+                verbosity=self.verbosity,
             )
             resolver = self.make_resolver(
                 preparer=preparer,
@@ -319,6 +378,29 @@ class InstallCommand(RequirementCommand):
                 reqs, check_supported_wheels=not options.target_dir
             )
 
+            if options.json_report_file:
+                report = InstallationReport(requirement_set.requirements_to_install)
+                if options.json_report_file == "-":
+                    print_json(data=report.to_dict())
+                else:
+                    with open(options.json_report_file, "w", encoding="utf-8") as f:
+                        json.dump(report.to_dict(), f, indent=2, ensure_ascii=False)
+
+            if options.dry_run:
+                # In non dry-run mode, the legacy versions and specifiers check
+                # will be done as part of conflict detection.
+                requirement_set.warn_legacy_versions_and_specifiers()
+                would_install_items = sorted(
+                    (r.metadata["name"], r.metadata["version"])
+                    for r in requirement_set.requirements_to_install
+                )
+                if would_install_items:
+                    write_output(
+                        "Would install %s",
+                        " ".join("-".join(item) for item in would_install_items),
+                    )
+                return SUCCESS
+
             try:
                 pip_req = requirement_set.get_requirement("pip")
             except KeyError:
@@ -327,19 +409,12 @@ class InstallCommand(RequirementCommand):
                 # If we're not replacing an already installed pip,
                 # we're not modifying it.
                 modifying_pip = pip_req.satisfied_by is None
-            protect_pip_from_modification_on_windows(
-                modifying_pip=modifying_pip
-            )
-
-            check_binary_allowed = get_check_binary_allowed(
-                finder.format_control
-            )
+            protect_pip_from_modification_on_windows(modifying_pip=modifying_pip)
 
             reqs_to_build = [
-                r for r in requirement_set.requirements.values()
-                if should_build_for_install_command(
-                    r, check_binary_allowed
-                )
+                r
+                for r in requirement_set.requirements.values()
+                if should_build_for_install_command(r)
             ]
 
             _, build_failures = build(
@@ -347,52 +422,35 @@ class InstallCommand(RequirementCommand):
                 wheel_cache=wheel_cache,
                 verify=True,
                 build_options=[],
-                global_options=[],
+                global_options=global_options,
             )
 
-            # If we're using PEP 517, we cannot do a direct install
-            # so we fail here.
-            pep517_build_failure_names = [
-                r.name   # type: ignore
-                for r in build_failures if r.use_pep517
-            ]  # type: List[str]
-            if pep517_build_failure_names:
+            if build_failures:
                 raise InstallationError(
-                    "Could not build wheels for {} which use"
-                    " PEP 517 and cannot be installed directly".format(
-                        ", ".join(pep517_build_failure_names)
+                    "Could not build wheels for {}, which is required to "
+                    "install pyproject.toml-based projects".format(
+                        ", ".join(r.name for r in build_failures)  # type: ignore
                     )
                 )
 
-            # For now, we just warn about failures building legacy
-            # requirements, as we'll fall through to a direct
-            # install for those.
-            for r in build_failures:
-                if not r.use_pep517:
-                    r.legacy_install_reason = 8368
-
-            to_install = resolver.get_installation_order(
-                requirement_set
-            )
+            to_install = resolver.get_installation_order(requirement_set)
 
             # Check for conflicts in the package set we're installing.
-            conflicts = None  # type: Optional[ConflictDetails]
+            conflicts: Optional[ConflictDetails] = None
             should_warn_about_conflicts = (
-                not options.ignore_dependencies and
-                options.warn_about_conflicts
+                not options.ignore_dependencies and options.warn_about_conflicts
             )
             if should_warn_about_conflicts:
                 conflicts = self._determine_conflicts(to_install)
 
             # Don't warn about script install locations if
-            # --target has been specified
+            # --target or --prefix has been specified
             warn_script_location = options.warn_script_location
-            if options.target_dir:
+            if options.target_dir or options.prefix_path:
                 warn_script_location = False
 
             installed = install_given_reqs(
                 to_install,
-                install_options,
                 global_options,
                 root=options.root_path,
                 home=target_temp_dir_path,
@@ -411,7 +469,7 @@ class InstallCommand(RequirementCommand):
             )
             env = get_environment(lib_locations)
 
-            installed.sort(key=operator.attrgetter('name'))
+            installed.sort(key=operator.attrgetter("name"))
             items = []
             for result in installed:
                 item = result.name
@@ -429,16 +487,19 @@ class InstallCommand(RequirementCommand):
                     resolver_variant=self.determine_resolver_variant(options),
                 )
 
-            installed_desc = ' '.join(items)
+            installed_desc = " ".join(items)
             if installed_desc:
                 write_output(
-                    'Successfully installed %s', installed_desc,
+                    "Successfully installed %s",
+                    installed_desc,
                 )
         except OSError as error:
-            show_traceback = (self.verbosity >= 1)
+            show_traceback = self.verbosity >= 1
 
             message = create_os_error_message(
-                error, show_traceback, options.use_user_site,
+                error,
+                show_traceback,
+                options.use_user_site,
             )
             logger.error(message, exc_info=show_traceback)  # noqa
 
@@ -449,12 +510,13 @@ class InstallCommand(RequirementCommand):
             self._handle_target_dir(
                 options.target_dir, target_temp_dir, options.upgrade
             )
-
-        warn_if_run_as_root()
+        if options.root_user_action == "warn":
+            warn_if_run_as_root()
         return SUCCESS
 
-    def _handle_target_dir(self, target_dir, target_temp_dir, upgrade):
-        # type: (str, TempDirectory, bool) -> None
+    def _handle_target_dir(
+        self, target_dir: str, target_temp_dir: TempDirectory, upgrade: bool
+    ) -> None:
         ensure_dir(target_dir)
 
         # Checking both purelib and platlib directories for installed
@@ -463,7 +525,7 @@ class InstallCommand(RequirementCommand):
 
         # Checking both purelib and platlib directories for installed
         # packages to be moved to target directory
-        scheme = get_scheme('', home=target_temp_dir.path)
+        scheme = get_scheme("", home=target_temp_dir.path)
         purelib_dir = scheme.purelib
         platlib_dir = scheme.platlib
         data_dir = scheme.data
@@ -485,18 +547,18 @@ class InstallCommand(RequirementCommand):
                 if os.path.exists(target_item_dir):
                     if not upgrade:
                         logger.warning(
-                            'Target directory %s already exists. Specify '
-                            '--upgrade to force replacement.',
-                            target_item_dir
+                            "Target directory %s already exists. Specify "
+                            "--upgrade to force replacement.",
+                            target_item_dir,
                         )
                         continue
                     if os.path.islink(target_item_dir):
                         logger.warning(
-                            'Target directory %s already exists and is '
-                            'a link. pip will not automatically replace '
-                            'links, please remove if replacement is '
-                            'desired.',
-                            target_item_dir
+                            "Target directory %s already exists and is "
+                            "a link. pip will not automatically replace "
+                            "links, please remove if replacement is "
+                            "desired.",
+                            target_item_dir,
                         )
                         continue
                     if os.path.isdir(target_item_dir):
@@ -504,13 +566,11 @@ class InstallCommand(RequirementCommand):
                     else:
                         os.remove(target_item_dir)
 
-                shutil.move(
-                    os.path.join(lib_dir, item),
-                    target_item_dir
-                )
+                shutil.move(os.path.join(lib_dir, item), target_item_dir)
 
-    def _determine_conflicts(self, to_install):
-        # type: (List[InstallRequirement]) -> Optional[ConflictDetails]
+    def _determine_conflicts(
+        self, to_install: List[InstallRequirement]
+    ) -> Optional[ConflictDetails]:
         try:
             return check_install_conflicts(to_install)
         except Exception:
@@ -520,13 +580,14 @@ class InstallCommand(RequirementCommand):
             )
             return None
 
-    def _warn_about_conflicts(self, conflict_details, resolver_variant):
-        # type: (ConflictDetails, str) -> None
+    def _warn_about_conflicts(
+        self, conflict_details: ConflictDetails, resolver_variant: str
+    ) -> None:
         package_set, (missing, conflicting) = conflict_details
         if not missing and not conflicting:
             return
 
-        parts = []  # type: List[str]
+        parts: List[str] = []
         if resolver_variant == "legacy":
             parts.append(
                 "pip's legacy dependency resolver does not consider dependency "
@@ -567,7 +628,7 @@ class InstallCommand(RequirementCommand):
                     requirement=req,
                     dep_name=dep_name,
                     dep_version=dep_version,
-                    you=("you" if resolver_variant == "2020-resolver" else "you'll")
+                    you=("you" if resolver_variant == "2020-resolver" else "you'll"),
                 )
                 parts.append(message)
 
@@ -575,15 +636,14 @@ class InstallCommand(RequirementCommand):
 
 
 def get_lib_location_guesses(
-        user=False,  # type: bool
-        home=None,  # type: Optional[str]
-        root=None,  # type: Optional[str]
-        isolated=False,  # type: bool
-        prefix=None  # type: Optional[str]
-):
-    # type:(...) -> List[str]
+    user: bool = False,
+    home: Optional[str] = None,
+    root: Optional[str] = None,
+    isolated: bool = False,
+    prefix: Optional[str] = None,
+) -> List[str]:
     scheme = get_scheme(
-        '',
+        "",
         user=user,
         home=home,
         root=root,
@@ -593,22 +653,20 @@ def get_lib_location_guesses(
     return [scheme.purelib, scheme.platlib]
 
 
-def site_packages_writable(root, isolated):
-    # type: (Optional[str], bool) -> bool
+def site_packages_writable(root: Optional[str], isolated: bool) -> bool:
     return all(
-        test_writable_dir(d) for d in set(
-            get_lib_location_guesses(root=root, isolated=isolated))
+        test_writable_dir(d)
+        for d in set(get_lib_location_guesses(root=root, isolated=isolated))
     )
 
 
 def decide_user_install(
-    use_user_site,  # type: Optional[bool]
-    prefix_path=None,  # type: Optional[str]
-    target_dir=None,  # type: Optional[str]
-    root_path=None,  # type: Optional[str]
-    isolated_mode=False,  # type: bool
-):
-    # type: (...) -> bool
+    use_user_site: Optional[bool],
+    prefix_path: Optional[str] = None,
+    target_dir: Optional[str] = None,
+    root_path: Optional[str] = None,
+    isolated_mode: bool = False,
+) -> bool:
     """Determine whether to do a user install based on the input options.
 
     If use_user_site is False, no additional checks are done.
@@ -656,55 +714,16 @@ def decide_user_install(
         logger.debug("Non-user install because site-packages writeable")
         return False
 
-    logger.info("Defaulting to user installation because normal site-packages "
-                "is not writeable")
-    return True
-
-
-def reject_location_related_install_options(requirements, options):
-    # type: (List[InstallRequirement], Optional[List[str]]) -> None
-    """If any location-changing --install-option arguments were passed for
-    requirements or on the command-line, then show a deprecation warning.
-    """
-    def format_options(option_names):
-        # type: (Iterable[str]) -> List[str]
-        return ["--{}".format(name.replace("_", "-")) for name in option_names]
-
-    offenders = []
-
-    for requirement in requirements:
-        install_options = requirement.install_options
-        location_options = parse_distutils_args(install_options)
-        if location_options:
-            offenders.append(
-                "{!r} from {}".format(
-                    format_options(location_options.keys()), requirement
-                )
-            )
-
-    if options:
-        location_options = parse_distutils_args(options)
-        if location_options:
-            offenders.append(
-                "{!r} from command line".format(
-                    format_options(location_options.keys())
-                )
-            )
-
-    if not offenders:
-        return
-
-    raise CommandError(
-        "Location-changing options found in --install-option: {}."
-        " This is unsupported, use pip-level options like --user,"
-        " --prefix, --root, and --target instead.".format(
-            "; ".join(offenders)
-        )
+    logger.info(
+        "Defaulting to user installation because normal site-packages "
+        "is not writeable"
     )
+    return True
 
 
-def create_os_error_message(error, show_traceback, using_user_site):
-    # type: (OSError, bool, bool) -> str
+def create_os_error_message(
+    error: OSError, show_traceback: bool, using_user_site: bool
+) -> str:
     """Format an error message for an OSError
 
     It may occur anytime during the execution of the install command.
@@ -729,12 +748,31 @@ def create_os_error_message(error, show_traceback, using_user_site):
         permissions_part = "Check the permissions"
 
         if not running_under_virtualenv() and not using_user_site:
-            parts.extend([
-                user_option_part, " or ",
-                permissions_part.lower(),
-            ])
+            parts.extend(
+                [
+                    user_option_part,
+                    " or ",
+                    permissions_part.lower(),
+                ]
+            )
         else:
             parts.append(permissions_part)
         parts.append(".\n")
 
+    # Suggest the user to enable Long Paths if path length is
+    # more than 260
+    if (
+        WINDOWS
+        and error.errno == errno.ENOENT
+        and error.filename
+        and len(error.filename) > 260
+    ):
+        parts.append(
+            "HINT: This error might have occurred since "
+            "this system does not have Windows Long Path "
+            "support enabled. You can find information on "
+            "how to enable this at "
+            "https://pip.pypa.io/warnings/enable-long-paths\n"
+        )
+
     return "".join(parts).strip() + "\n"
diff --git a/env/Lib/site-packages/pip/_internal/commands/list.py b/env/Lib/site-packages/pip/_internal/commands/list.py
index dcf94326..ac103531 100644
--- a/env/Lib/site-packages/pip/_internal/commands/list.py
+++ b/env/Lib/site-packages/pip/_internal/commands/list.py
@@ -1,9 +1,9 @@
 import json
 import logging
 from optparse import Values
-from typing import Iterator, List, Set, Tuple
+from typing import TYPE_CHECKING, Generator, List, Optional, Sequence, Tuple, cast
 
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.packaging.utils import canonicalize_name
 
 from pip._internal.cli import cmdoptions
 from pip._internal.cli.req_command import IndexGroupCommand
@@ -11,17 +11,27 @@ from pip._internal.cli.status_codes import SUCCESS
 from pip._internal.exceptions import CommandError
 from pip._internal.index.collector import LinkCollector
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata import BaseDistribution, get_environment
 from pip._internal.models.selection_prefs import SelectionPreferences
 from pip._internal.network.session import PipSession
 from pip._internal.utils.compat import stdlib_pkgs
-from pip._internal.utils.misc import (
-    dist_is_editable,
-    get_installed_distributions,
-    tabulate,
-    write_output,
-)
-from pip._internal.utils.packaging import get_installer
-from pip._internal.utils.parallel import map_multithread
+from pip._internal.utils.misc import tabulate, write_output
+
+if TYPE_CHECKING:
+    from pip._internal.metadata.base import DistributionVersion
+
+    class _DistWithLatestInfo(BaseDistribution):
+        """Give the distribution object a couple of extra fields.
+
+        These will be populated during ``get_outdated()``. This is dirty but
+        makes the rest of the code much cleaner.
+        """
+
+        latest_version: DistributionVersion
+        latest_filetype: str
+
+    _ProcessedDists = Sequence[_DistWithLatestInfo]
+
 
 logger = logging.getLogger(__name__)
 
@@ -37,86 +47,97 @@ class ListCommand(IndexGroupCommand):
     usage = """
       %prog [options]"""
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-o', '--outdated',
-            action='store_true',
+            "-o",
+            "--outdated",
+            action="store_true",
             default=False,
-            help='List outdated packages')
+            help="List outdated packages",
+        )
         self.cmd_opts.add_option(
-            '-u', '--uptodate',
-            action='store_true',
+            "-u",
+            "--uptodate",
+            action="store_true",
             default=False,
-            help='List uptodate packages')
+            help="List uptodate packages",
+        )
         self.cmd_opts.add_option(
-            '-e', '--editable',
-            action='store_true',
+            "-e",
+            "--editable",
+            action="store_true",
             default=False,
-            help='List editable projects.')
+            help="List editable projects.",
+        )
         self.cmd_opts.add_option(
-            '-l', '--local',
-            action='store_true',
+            "-l",
+            "--local",
+            action="store_true",
             default=False,
-            help=('If in a virtualenv that has global access, do not list '
-                  'globally-installed packages.'),
+            help=(
+                "If in a virtualenv that has global access, do not list "
+                "globally-installed packages."
+            ),
         )
         self.cmd_opts.add_option(
-            '--user',
-            dest='user',
-            action='store_true',
+            "--user",
+            dest="user",
+            action="store_true",
             default=False,
-            help='Only output packages installed in user-site.')
+            help="Only output packages installed in user-site.",
+        )
         self.cmd_opts.add_option(cmdoptions.list_path())
         self.cmd_opts.add_option(
-            '--pre',
-            action='store_true',
+            "--pre",
+            action="store_true",
             default=False,
-            help=("Include pre-release and development versions. By default, "
-                  "pip only finds stable versions."),
+            help=(
+                "Include pre-release and development versions. By default, "
+                "pip only finds stable versions."
+            ),
         )
 
         self.cmd_opts.add_option(
-            '--format',
-            action='store',
-            dest='list_format',
+            "--format",
+            action="store",
+            dest="list_format",
             default="columns",
-            choices=('columns', 'freeze', 'json'),
-            help="Select the output format among: columns (default), freeze, "
-                 "or json",
+            choices=("columns", "freeze", "json"),
+            help=(
+                "Select the output format among: columns (default), freeze, or json. "
+                "The 'freeze' format cannot be used with the --outdated option."
+            ),
         )
 
         self.cmd_opts.add_option(
-            '--not-required',
-            action='store_true',
-            dest='not_required',
-            help="List packages that are not dependencies of "
-                 "installed packages.",
+            "--not-required",
+            action="store_true",
+            dest="not_required",
+            help="List packages that are not dependencies of installed packages.",
         )
 
         self.cmd_opts.add_option(
-            '--exclude-editable',
-            action='store_false',
-            dest='include_editable',
-            help='Exclude editable package from output.',
+            "--exclude-editable",
+            action="store_false",
+            dest="include_editable",
+            help="Exclude editable package from output.",
         )
         self.cmd_opts.add_option(
-            '--include-editable',
-            action='store_true',
-            dest='include_editable',
-            help='Include editable package from output.',
+            "--include-editable",
+            action="store_true",
+            dest="include_editable",
+            help="Include editable package from output.",
             default=True,
         )
         self.cmd_opts.add_option(cmdoptions.list_exclude())
-        index_opts = cmdoptions.make_option_group(
-            cmdoptions.index_group, self.parser
-        )
+        index_opts = cmdoptions.make_option_group(cmdoptions.index_group, self.parser)
 
         self.parser.insert_option_group(0, index_opts)
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def _build_package_finder(self, options, session):
-        # type: (Values, PipSession) -> PackageFinder
+    def _build_package_finder(
+        self, options: Values, session: PipSession
+    ) -> PackageFinder:
         """
         Create a package finder appropriate to this list command.
         """
@@ -133,26 +154,31 @@ class ListCommand(IndexGroupCommand):
             selection_prefs=selection_prefs,
         )
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         if options.outdated and options.uptodate:
+            raise CommandError("Options --outdated and --uptodate cannot be combined.")
+
+        if options.outdated and options.list_format == "freeze":
             raise CommandError(
-                "Options --outdated and --uptodate cannot be combined.")
+                "List format 'freeze' cannot be used with the --outdated option."
+            )
 
         cmdoptions.check_list_path_option(options)
 
         skip = set(stdlib_pkgs)
         if options.excludes:
-            skip.update(options.excludes)
-
-        packages = get_installed_distributions(
-            local_only=options.local,
-            user_only=options.user,
-            editables_only=options.editable,
-            include_editables=options.include_editable,
-            paths=options.path,
-            skip=skip,
-        )
+            skip.update(canonicalize_name(n) for n in options.excludes)
+
+        packages: "_ProcessedDists" = [
+            cast("_DistWithLatestInfo", d)
+            for d in get_environment(options.path).iter_installed_distributions(
+                local_only=options.local,
+                user_only=options.user,
+                editables_only=options.editable,
+                include_editables=options.include_editable,
+                skip=skip,
+            )
+        ]
 
         # get_not_required must be called firstly in order to find and
         # filter out all dependencies correctly. Otherwise a package
@@ -169,46 +195,58 @@ class ListCommand(IndexGroupCommand):
         self.output_package_listing(packages, options)
         return SUCCESS
 
-    def get_outdated(self, packages, options):
-        # type: (List[Distribution], Values) -> List[Distribution]
+    def get_outdated(
+        self, packages: "_ProcessedDists", options: Values
+    ) -> "_ProcessedDists":
         return [
-            dist for dist in self.iter_packages_latest_infos(packages, options)
-            if dist.latest_version > dist.parsed_version
+            dist
+            for dist in self.iter_packages_latest_infos(packages, options)
+            if dist.latest_version > dist.version
         ]
 
-    def get_uptodate(self, packages, options):
-        # type: (List[Distribution], Values) -> List[Distribution]
+    def get_uptodate(
+        self, packages: "_ProcessedDists", options: Values
+    ) -> "_ProcessedDists":
         return [
-            dist for dist in self.iter_packages_latest_infos(packages, options)
-            if dist.latest_version == dist.parsed_version
+            dist
+            for dist in self.iter_packages_latest_infos(packages, options)
+            if dist.latest_version == dist.version
         ]
 
-    def get_not_required(self, packages, options):
-        # type: (List[Distribution], Values) -> List[Distribution]
-        dep_keys = set()  # type: Set[Distribution]
-        for dist in packages:
-            dep_keys.update(requirement.key for requirement in dist.requires())
+    def get_not_required(
+        self, packages: "_ProcessedDists", options: Values
+    ) -> "_ProcessedDists":
+        dep_keys = {
+            canonicalize_name(dep.name)
+            for dist in packages
+            for dep in (dist.iter_dependencies() or ())
+        }
 
         # Create a set to remove duplicate packages, and cast it to a list
         # to keep the return type consistent with get_outdated and
         # get_uptodate
-        return list({pkg for pkg in packages if pkg.key not in dep_keys})
+        return list({pkg for pkg in packages if pkg.canonical_name not in dep_keys})
 
-    def iter_packages_latest_infos(self, packages, options):
-        # type: (List[Distribution], Values) -> Iterator[Distribution]
+    def iter_packages_latest_infos(
+        self, packages: "_ProcessedDists", options: Values
+    ) -> Generator["_DistWithLatestInfo", None, None]:
         with self._build_session(options) as session:
             finder = self._build_package_finder(options, session)
 
-            def latest_info(dist):
-                # type: (Distribution) -> Distribution
-                all_candidates = finder.find_all_candidates(dist.key)
+            def latest_info(
+                dist: "_DistWithLatestInfo",
+            ) -> Optional["_DistWithLatestInfo"]:
+                all_candidates = finder.find_all_candidates(dist.canonical_name)
                 if not options.pre:
                     # Remove prereleases
-                    all_candidates = [candidate for candidate in all_candidates
-                                      if not candidate.version.is_prerelease]
+                    all_candidates = [
+                        candidate
+                        for candidate in all_candidates
+                        if not candidate.version.is_prerelease
+                    ]
 
                 evaluator = finder.make_candidate_evaluator(
-                    project_name=dist.project_name,
+                    project_name=dist.canonical_name,
                 )
                 best_candidate = evaluator.sort_best_candidate(all_candidates)
                 if best_candidate is None:
@@ -216,39 +254,41 @@ class ListCommand(IndexGroupCommand):
 
                 remote_version = best_candidate.version
                 if best_candidate.link.is_wheel:
-                    typ = 'wheel'
+                    typ = "wheel"
                 else:
-                    typ = 'sdist'
-                # This is dirty but makes the rest of the code much cleaner
+                    typ = "sdist"
                 dist.latest_version = remote_version
                 dist.latest_filetype = typ
                 return dist
 
-            for dist in map_multithread(latest_info, packages):
+            for dist in map(latest_info, packages):
                 if dist is not None:
                     yield dist
 
-    def output_package_listing(self, packages, options):
-        # type: (List[Distribution], Values) -> None
+    def output_package_listing(
+        self, packages: "_ProcessedDists", options: Values
+    ) -> None:
         packages = sorted(
             packages,
-            key=lambda dist: dist.project_name.lower(),
+            key=lambda dist: dist.canonical_name,
         )
-        if options.list_format == 'columns' and packages:
+        if options.list_format == "columns" and packages:
             data, header = format_for_columns(packages, options)
             self.output_package_listing_columns(data, header)
-        elif options.list_format == 'freeze':
+        elif options.list_format == "freeze":
             for dist in packages:
                 if options.verbose >= 1:
-                    write_output("%s==%s (%s)", dist.project_name,
-                                 dist.version, dist.location)
+                    write_output(
+                        "%s==%s (%s)", dist.raw_name, dist.version, dist.location
+                    )
                 else:
-                    write_output("%s==%s", dist.project_name, dist.version)
-        elif options.list_format == 'json':
+                    write_output("%s==%s", dist.raw_name, dist.version)
+        elif options.list_format == "json":
             write_output(format_for_json(packages, options))
 
-    def output_package_listing_columns(self, data, header):
-        # type: (List[List[str]], List[str]) -> None
+    def output_package_listing_columns(
+        self, data: List[List[str]], header: List[str]
+    ) -> None:
         # insert the header first: we need to know the size of column names
         if len(data) > 0:
             data.insert(0, header)
@@ -257,63 +297,72 @@ class ListCommand(IndexGroupCommand):
 
         # Create and add a separator.
         if len(data) > 0:
-            pkg_strings.insert(1, " ".join(map(lambda x: '-' * x, sizes)))
+            pkg_strings.insert(1, " ".join(map(lambda x: "-" * x, sizes)))
 
         for val in pkg_strings:
             write_output(val)
 
 
-def format_for_columns(pkgs, options):
-    # type: (List[Distribution], Values) -> Tuple[List[List[str]], List[str]]
+def format_for_columns(
+    pkgs: "_ProcessedDists", options: Values
+) -> Tuple[List[List[str]], List[str]]:
     """
     Convert the package data into something usable
     by output_package_listing_columns.
     """
+    header = ["Package", "Version"]
+
     running_outdated = options.outdated
-    # Adjust the header for the `pip list --outdated` case.
     if running_outdated:
-        header = ["Package", "Version", "Latest", "Type"]
-    else:
-        header = ["Package", "Version"]
+        header.extend(["Latest", "Type"])
 
-    data = []
-    if options.verbose >= 1 or any(dist_is_editable(x) for x in pkgs):
+    has_editables = any(x.editable for x in pkgs)
+    if has_editables:
+        header.append("Editable project location")
+
+    if options.verbose >= 1:
         header.append("Location")
     if options.verbose >= 1:
         header.append("Installer")
 
+    data = []
     for proj in pkgs:
         # if we're working on the 'outdated' list, separate out the
         # latest_version and type
-        row = [proj.project_name, proj.version]
+        row = [proj.raw_name, str(proj.version)]
 
         if running_outdated:
-            row.append(proj.latest_version)
+            row.append(str(proj.latest_version))
             row.append(proj.latest_filetype)
 
-        if options.verbose >= 1 or dist_is_editable(proj):
-            row.append(proj.location)
+        if has_editables:
+            row.append(proj.editable_project_location or "")
+
+        if options.verbose >= 1:
+            row.append(proj.location or "")
         if options.verbose >= 1:
-            row.append(get_installer(proj))
+            row.append(proj.installer)
 
         data.append(row)
 
     return data, header
 
 
-def format_for_json(packages, options):
-    # type: (List[Distribution], Values) -> str
+def format_for_json(packages: "_ProcessedDists", options: Values) -> str:
     data = []
     for dist in packages:
         info = {
-            'name': dist.project_name,
-            'version': str(dist.version),
+            "name": dist.raw_name,
+            "version": str(dist.version),
         }
         if options.verbose >= 1:
-            info['location'] = dist.location
-            info['installer'] = get_installer(dist)
+            info["location"] = dist.location or ""
+            info["installer"] = dist.installer
         if options.outdated:
-            info['latest_version'] = str(dist.latest_version)
-            info['latest_filetype'] = dist.latest_filetype
+            info["latest_version"] = str(dist.latest_version)
+            info["latest_filetype"] = dist.latest_filetype
+        editable_project_location = dist.editable_project_location
+        if editable_project_location:
+            info["editable_project_location"] = editable_project_location
         data.append(info)
     return json.dumps(data)
diff --git a/env/Lib/site-packages/pip/_internal/commands/search.py b/env/Lib/site-packages/pip/_internal/commands/search.py
index d66e8234..03ed925b 100644
--- a/env/Lib/site-packages/pip/_internal/commands/search.py
+++ b/env/Lib/site-packages/pip/_internal/commands/search.py
@@ -27,6 +27,7 @@ if TYPE_CHECKING:
         summary: str
         versions: List[str]
 
+
 logger = logging.getLogger(__name__)
 
 
@@ -37,21 +38,21 @@ class SearchCommand(Command, SessionCommandMixin):
       %prog [options] <query>"""
     ignore_require_venv = True
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-i', '--index',
-            dest='index',
-            metavar='URL',
+            "-i",
+            "--index",
+            dest="index",
+            metavar="URL",
             default=PyPI.pypi_url,
-            help='Base URL of Python Package Index (default %default)')
+            help="Base URL of Python Package Index (default %default)",
+        )
 
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         if not args:
-            raise CommandError('Missing required argument (search query).')
+            raise CommandError("Missing required argument (search query).")
         query = args
         pypi_hits = self.search(query, options)
         hits = transform_hits(pypi_hits)
@@ -65,8 +66,7 @@ class SearchCommand(Command, SessionCommandMixin):
             return SUCCESS
         return NO_MATCHES_FOUND
 
-    def search(self, query, options):
-        # type: (List[str], Values) -> List[Dict[str, str]]
+    def search(self, query: List[str], options: Values) -> List[Dict[str, str]]:
         index_url = options.index
 
         session = self.get_default_session(options)
@@ -74,7 +74,7 @@ class SearchCommand(Command, SessionCommandMixin):
         transport = PipXmlrpcTransport(index_url, session)
         pypi = xmlrpc.client.ServerProxy(index_url, transport)
         try:
-            hits = pypi.search({'name': query, 'summary': query}, 'or')
+            hits = pypi.search({"name": query, "summary": query}, "or")
         except xmlrpc.client.Fault as fault:
             message = "XMLRPC request failed [code: {code}]\n{string}".format(
                 code=fault.faultCode,
@@ -85,78 +85,90 @@ class SearchCommand(Command, SessionCommandMixin):
         return hits
 
 
-def transform_hits(hits):
-    # type: (List[Dict[str, str]]) -> List[TransformedHit]
+def transform_hits(hits: List[Dict[str, str]]) -> List["TransformedHit"]:
     """
     The list from pypi is really a list of versions. We want a list of
     packages with the list of versions stored inline. This converts the
     list from pypi into one we can use.
     """
-    packages = OrderedDict()  # type: OrderedDict[str, TransformedHit]
+    packages: Dict[str, "TransformedHit"] = OrderedDict()
     for hit in hits:
-        name = hit['name']
-        summary = hit['summary']
-        version = hit['version']
+        name = hit["name"]
+        summary = hit["summary"]
+        version = hit["version"]
 
         if name not in packages.keys():
             packages[name] = {
-                'name': name,
-                'summary': summary,
-                'versions': [version],
+                "name": name,
+                "summary": summary,
+                "versions": [version],
             }
         else:
-            packages[name]['versions'].append(version)
+            packages[name]["versions"].append(version)
 
             # if this is the highest version, replace summary and score
-            if version == highest_version(packages[name]['versions']):
-                packages[name]['summary'] = summary
+            if version == highest_version(packages[name]["versions"]):
+                packages[name]["summary"] = summary
 
     return list(packages.values())
 
 
-def print_results(hits, name_column_width=None, terminal_width=None):
-    # type: (List[TransformedHit], Optional[int], Optional[int]) -> None
+def print_dist_installation_info(name: str, latest: str) -> None:
+    env = get_default_environment()
+    dist = env.get_distribution(name)
+    if dist is not None:
+        with indent_log():
+            if dist.version == latest:
+                write_output("INSTALLED: %s (latest)", dist.version)
+            else:
+                write_output("INSTALLED: %s", dist.version)
+                if parse_version(latest).pre:
+                    write_output(
+                        "LATEST:    %s (pre-release; install"
+                        " with `pip install --pre`)",
+                        latest,
+                    )
+                else:
+                    write_output("LATEST:    %s", latest)
+
+
+def print_results(
+    hits: List["TransformedHit"],
+    name_column_width: Optional[int] = None,
+    terminal_width: Optional[int] = None,
+) -> None:
     if not hits:
         return
     if name_column_width is None:
-        name_column_width = max([
-            len(hit['name']) + len(highest_version(hit.get('versions', ['-'])))
-            for hit in hits
-        ]) + 4
+        name_column_width = (
+            max(
+                [
+                    len(hit["name"]) + len(highest_version(hit.get("versions", ["-"])))
+                    for hit in hits
+                ]
+            )
+            + 4
+        )
 
-    env = get_default_environment()
     for hit in hits:
-        name = hit['name']
-        summary = hit['summary'] or ''
-        latest = highest_version(hit.get('versions', ['-']))
+        name = hit["name"]
+        summary = hit["summary"] or ""
+        latest = highest_version(hit.get("versions", ["-"]))
         if terminal_width is not None:
             target_width = terminal_width - name_column_width - 5
             if target_width > 10:
                 # wrap and indent summary to fit terminal
                 summary_lines = textwrap.wrap(summary, target_width)
-                summary = ('\n' + ' ' * (name_column_width + 3)).join(
-                    summary_lines)
+                summary = ("\n" + " " * (name_column_width + 3)).join(summary_lines)
 
-        name_latest = f'{name} ({latest})'
-        line = f'{name_latest:{name_column_width}} - {summary}'
+        name_latest = f"{name} ({latest})"
+        line = f"{name_latest:{name_column_width}} - {summary}"
         try:
             write_output(line)
-            dist = env.get_distribution(name)
-            if dist is not None:
-                with indent_log():
-                    if dist.version == latest:
-                        write_output('INSTALLED: %s (latest)', dist.version)
-                    else:
-                        write_output('INSTALLED: %s', dist.version)
-                        if parse_version(latest).pre:
-                            write_output('LATEST:    %s (pre-release; install'
-                                         ' with "pip install --pre")', latest)
-                        else:
-                            write_output('LATEST:    %s', latest)
+            print_dist_installation_info(name, latest)
         except UnicodeEncodeError:
             pass
 
 
-def highest_version(versions):
-    # type: (List[str]) -> str
+def highest_version(versions: List[str]) -> str:
     return max(versions, key=parse_version)
diff --git a/env/Lib/site-packages/pip/_internal/commands/show.py b/env/Lib/site-packages/pip/_internal/commands/show.py
index 24e855a8..3f10701f 100644
--- a/env/Lib/site-packages/pip/_internal/commands/show.py
+++ b/env/Lib/site-packages/pip/_internal/commands/show.py
@@ -1,14 +1,12 @@
 import logging
-import os
-from email.parser import FeedParser
 from optparse import Values
-from typing import Dict, Iterator, List
+from typing import Generator, Iterable, Iterator, List, NamedTuple, Optional
 
-from pip._vendor import pkg_resources
 from pip._vendor.packaging.utils import canonicalize_name
 
 from pip._internal.cli.base_command import Command
 from pip._internal.cli.status_codes import ERROR, SUCCESS
+from pip._internal.metadata import BaseDistribution, get_default_environment
 from pip._internal.utils.misc import write_output
 
 logger = logging.getLogger(__name__)
@@ -25,123 +23,126 @@ class ShowCommand(Command):
       %prog [options] <package> ..."""
     ignore_require_venv = True
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-f', '--files',
-            dest='files',
-            action='store_true',
+            "-f",
+            "--files",
+            dest="files",
+            action="store_true",
             default=False,
-            help='Show the full list of installed files for each package.')
+            help="Show the full list of installed files for each package.",
+        )
 
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         if not args:
-            logger.warning('ERROR: Please provide a package name or names.')
+            logger.warning("ERROR: Please provide a package name or names.")
             return ERROR
         query = args
 
         results = search_packages_info(query)
         if not print_results(
-                results, list_files=options.files, verbose=options.verbose):
+            results, list_files=options.files, verbose=options.verbose
+        ):
             return ERROR
         return SUCCESS
 
 
-def search_packages_info(query):
-    # type: (List[str]) -> Iterator[Dict[str, str]]
+class _PackageInfo(NamedTuple):
+    name: str
+    version: str
+    location: str
+    editable_project_location: Optional[str]
+    requires: List[str]
+    required_by: List[str]
+    installer: str
+    metadata_version: str
+    classifiers: List[str]
+    summary: str
+    homepage: str
+    project_urls: List[str]
+    author: str
+    author_email: str
+    license: str
+    entry_points: List[str]
+    files: Optional[List[str]]
+
+
+def search_packages_info(query: List[str]) -> Generator[_PackageInfo, None, None]:
     """
     Gather details from installed distributions. Print distribution name,
     version, location, and installed files. Installed files requires a
     pip generated 'installed-files.txt' in the distributions '.egg-info'
     directory.
     """
-    installed = {}
-    for p in pkg_resources.working_set:
-        installed[canonicalize_name(p.project_name)] = p
+    env = get_default_environment()
 
+    installed = {dist.canonical_name: dist for dist in env.iter_all_distributions()}
     query_names = [canonicalize_name(name) for name in query]
     missing = sorted(
         [name for name, pkg in zip(query, query_names) if pkg not in installed]
     )
     if missing:
-        logger.warning('Package(s) not found: %s', ', '.join(missing))
-
-    def get_requiring_packages(package_name):
-        # type: (str) -> List[str]
-        canonical_name = canonicalize_name(package_name)
-        return [
-            pkg.project_name for pkg in pkg_resources.working_set
-            if canonical_name in
-               [canonicalize_name(required.name) for required in
-                pkg.requires()]
-        ]
-
-    for dist in [installed[pkg] for pkg in query_names if pkg in installed]:
-        package = {
-            'name': dist.project_name,
-            'version': dist.version,
-            'location': dist.location,
-            'requires': [dep.project_name for dep in dist.requires()],
-            'required_by': get_requiring_packages(dist.project_name)
-        }
-        file_list = None
-        metadata = ''
-        if isinstance(dist, pkg_resources.DistInfoDistribution):
-            # RECORDs should be part of .dist-info metadatas
-            if dist.has_metadata('RECORD'):
-                lines = dist.get_metadata_lines('RECORD')
-                paths = [line.split(',')[0] for line in lines]
-                paths = [os.path.join(dist.location, p) for p in paths]
-                file_list = [os.path.relpath(p, dist.location) for p in paths]
-
-            if dist.has_metadata('METADATA'):
-                metadata = dist.get_metadata('METADATA')
+        logger.warning("Package(s) not found: %s", ", ".join(missing))
+
+    def _get_requiring_packages(current_dist: BaseDistribution) -> Iterator[str]:
+        return (
+            dist.metadata["Name"] or "UNKNOWN"
+            for dist in installed.values()
+            if current_dist.canonical_name
+            in {canonicalize_name(d.name) for d in dist.iter_dependencies()}
+        )
+
+    for query_name in query_names:
+        try:
+            dist = installed[query_name]
+        except KeyError:
+            continue
+
+        requires = sorted((req.name for req in dist.iter_dependencies()), key=str.lower)
+        required_by = sorted(_get_requiring_packages(dist), key=str.lower)
+
+        try:
+            entry_points_text = dist.read_text("entry_points.txt")
+            entry_points = entry_points_text.splitlines(keepends=False)
+        except FileNotFoundError:
+            entry_points = []
+
+        files_iter = dist.iter_declared_entries()
+        if files_iter is None:
+            files: Optional[List[str]] = None
         else:
-            # Otherwise use pip's log for .egg-info's
-            if dist.has_metadata('installed-files.txt'):
-                paths = dist.get_metadata_lines('installed-files.txt')
-                paths = [os.path.join(dist.egg_info, p) for p in paths]
-                file_list = [os.path.relpath(p, dist.location) for p in paths]
-
-            if dist.has_metadata('PKG-INFO'):
-                metadata = dist.get_metadata('PKG-INFO')
-
-        if dist.has_metadata('entry_points.txt'):
-            entry_points = dist.get_metadata_lines('entry_points.txt')
-            package['entry_points'] = entry_points
-
-        if dist.has_metadata('INSTALLER'):
-            for line in dist.get_metadata_lines('INSTALLER'):
-                if line.strip():
-                    package['installer'] = line.strip()
-                    break
-
-        # @todo: Should pkg_resources.Distribution have a
-        # `get_pkg_info` method?
-        feed_parser = FeedParser()
-        feed_parser.feed(metadata)
-        pkg_info_dict = feed_parser.close()
-        for key in ('metadata-version', 'summary',
-                    'home-page', 'author', 'author-email', 'license'):
-            package[key] = pkg_info_dict.get(key)
-
-        # It looks like FeedParser cannot deal with repeated headers
-        classifiers = []
-        for line in metadata.splitlines():
-            if line.startswith('Classifier: '):
-                classifiers.append(line[len('Classifier: '):])
-        package['classifiers'] = classifiers
-
-        if file_list:
-            package['files'] = sorted(file_list)
-        yield package
-
-
-def print_results(distributions, list_files=False, verbose=False):
-    # type: (Iterator[Dict[str, str]], bool, bool) -> bool
+            files = sorted(files_iter)
+
+        metadata = dist.metadata
+
+        yield _PackageInfo(
+            name=dist.raw_name,
+            version=str(dist.version),
+            location=dist.location or "",
+            editable_project_location=dist.editable_project_location,
+            requires=requires,
+            required_by=required_by,
+            installer=dist.installer,
+            metadata_version=dist.metadata_version or "",
+            classifiers=metadata.get_all("Classifier", []),
+            summary=metadata.get("Summary", ""),
+            homepage=metadata.get("Home-page", ""),
+            project_urls=metadata.get_all("Project-URL", []),
+            author=metadata.get("Author", ""),
+            author_email=metadata.get("Author-email", ""),
+            license=metadata.get("License", ""),
+            entry_points=entry_points,
+            files=files,
+        )
+
+
+def print_results(
+    distributions: Iterable[_PackageInfo],
+    list_files: bool,
+    verbose: bool,
+) -> bool:
     """
     Print the information from installed distributions found.
     """
@@ -151,31 +152,38 @@ def print_results(distributions, list_files=False, verbose=False):
         if i > 0:
             write_output("---")
 
-        write_output("Name: %s", dist.get('name', ''))
-        write_output("Version: %s", dist.get('version', ''))
-        write_output("Summary: %s", dist.get('summary', ''))
-        write_output("Home-page: %s", dist.get('home-page', ''))
-        write_output("Author: %s", dist.get('author', ''))
-        write_output("Author-email: %s", dist.get('author-email', ''))
-        write_output("License: %s", dist.get('license', ''))
-        write_output("Location: %s", dist.get('location', ''))
-        write_output("Requires: %s", ', '.join(dist.get('requires', [])))
-        write_output("Required-by: %s", ', '.join(dist.get('required_by', [])))
+        write_output("Name: %s", dist.name)
+        write_output("Version: %s", dist.version)
+        write_output("Summary: %s", dist.summary)
+        write_output("Home-page: %s", dist.homepage)
+        write_output("Author: %s", dist.author)
+        write_output("Author-email: %s", dist.author_email)
+        write_output("License: %s", dist.license)
+        write_output("Location: %s", dist.location)
+        if dist.editable_project_location is not None:
+            write_output(
+                "Editable project location: %s", dist.editable_project_location
+            )
+        write_output("Requires: %s", ", ".join(dist.requires))
+        write_output("Required-by: %s", ", ".join(dist.required_by))
 
         if verbose:
-            write_output("Metadata-Version: %s",
-                         dist.get('metadata-version', ''))
-            write_output("Installer: %s", dist.get('installer', ''))
+            write_output("Metadata-Version: %s", dist.metadata_version)
+            write_output("Installer: %s", dist.installer)
             write_output("Classifiers:")
-            for classifier in dist.get('classifiers', []):
+            for classifier in dist.classifiers:
                 write_output("  %s", classifier)
             write_output("Entry-points:")
-            for entry in dist.get('entry_points', []):
+            for entry in dist.entry_points:
                 write_output("  %s", entry.strip())
+            write_output("Project-URLs:")
+            for project_url in dist.project_urls:
+                write_output("  %s", project_url)
         if list_files:
             write_output("Files:")
-            for line in dist.get('files', []):
-                write_output("  %s", line.strip())
-            if "files" not in dist:
-                write_output("Cannot locate installed-files.txt")
+            if dist.files is None:
+                write_output("Cannot locate RECORD or installed-files.txt")
+            else:
+                for line in dist.files:
+                    write_output("  %s", line.strip())
     return results_printed
diff --git a/env/Lib/site-packages/pip/_internal/commands/uninstall.py b/env/Lib/site-packages/pip/_internal/commands/uninstall.py
index 9a3c9f88..f198fc31 100644
--- a/env/Lib/site-packages/pip/_internal/commands/uninstall.py
+++ b/env/Lib/site-packages/pip/_internal/commands/uninstall.py
@@ -1,8 +1,10 @@
+import logging
 from optparse import Values
 from typing import List
 
 from pip._vendor.packaging.utils import canonicalize_name
 
+from pip._internal.cli import cmdoptions
 from pip._internal.cli.base_command import Command
 from pip._internal.cli.req_command import SessionCommandMixin, warn_if_run_as_root
 from pip._internal.cli.status_codes import SUCCESS
@@ -12,7 +14,12 @@ from pip._internal.req.constructors import (
     install_req_from_line,
     install_req_from_parsed_requirement,
 )
-from pip._internal.utils.misc import protect_pip_from_modification_on_windows
+from pip._internal.utils.misc import (
+    check_externally_managed,
+    protect_pip_from_modification_on_windows,
+)
+
+logger = logging.getLogger(__name__)
 
 
 class UninstallCommand(Command, SessionCommandMixin):
@@ -30,63 +37,77 @@ class UninstallCommand(Command, SessionCommandMixin):
       %prog [options] <package> ...
       %prog [options] -r <requirements file> ..."""
 
-    def add_options(self):
-        # type: () -> None
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-r', '--requirement',
-            dest='requirements',
-            action='append',
+            "-r",
+            "--requirement",
+            dest="requirements",
+            action="append",
             default=[],
-            metavar='file',
-            help='Uninstall all the packages listed in the given requirements '
-                 'file.  This option can be used multiple times.',
+            metavar="file",
+            help=(
+                "Uninstall all the packages listed in the given requirements "
+                "file.  This option can be used multiple times."
+            ),
         )
         self.cmd_opts.add_option(
-            '-y', '--yes',
-            dest='yes',
-            action='store_true',
-            help="Don't ask for confirmation of uninstall deletions.")
-
+            "-y",
+            "--yes",
+            dest="yes",
+            action="store_true",
+            help="Don't ask for confirmation of uninstall deletions.",
+        )
+        self.cmd_opts.add_option(cmdoptions.root_user_action())
+        self.cmd_opts.add_option(cmdoptions.override_externally_managed())
         self.parser.insert_option_group(0, self.cmd_opts)
 
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
+    def run(self, options: Values, args: List[str]) -> int:
         session = self.get_default_session(options)
 
         reqs_to_uninstall = {}
         for name in args:
             req = install_req_from_line(
-                name, isolated=options.isolated_mode,
+                name,
+                isolated=options.isolated_mode,
             )
             if req.name:
                 reqs_to_uninstall[canonicalize_name(req.name)] = req
+            else:
+                logger.warning(
+                    "Invalid requirement: %r ignored -"
+                    " the uninstall command expects named"
+                    " requirements.",
+                    name,
+                )
         for filename in options.requirements:
             for parsed_req in parse_requirements(
-                    filename,
-                    options=options,
-                    session=session):
+                filename, options=options, session=session
+            ):
                 req = install_req_from_parsed_requirement(
-                    parsed_req,
-                    isolated=options.isolated_mode
+                    parsed_req, isolated=options.isolated_mode
                 )
                 if req.name:
                     reqs_to_uninstall[canonicalize_name(req.name)] = req
         if not reqs_to_uninstall:
             raise InstallationError(
-                f'You must give at least one requirement to {self.name} (see '
+                f"You must give at least one requirement to {self.name} (see "
                 f'"pip help {self.name}")'
             )
 
+        if not options.override_externally_managed:
+            check_externally_managed()
+
         protect_pip_from_modification_on_windows(
             modifying_pip="pip" in reqs_to_uninstall
         )
 
         for req in reqs_to_uninstall.values():
             uninstall_pathset = req.uninstall(
-                auto_confirm=options.yes, verbose=self.verbosity > 0,
+                auto_confirm=options.yes,
+                verbose=self.verbosity > 0,
             )
             if uninstall_pathset:
                 uninstall_pathset.commit()
-
-        warn_if_run_as_root()
+        if options.root_user_action == "warn":
+            warn_if_run_as_root()
         return SUCCESS
diff --git a/env/Lib/site-packages/pip/_internal/commands/wheel.py b/env/Lib/site-packages/pip/_internal/commands/wheel.py
index ff47dbac..ed578aa2 100644
--- a/env/Lib/site-packages/pip/_internal/commands/wheel.py
+++ b/env/Lib/site-packages/pip/_internal/commands/wheel.py
@@ -9,8 +9,11 @@ from pip._internal.cli import cmdoptions
 from pip._internal.cli.req_command import RequirementCommand, with_cleanup
 from pip._internal.cli.status_codes import SUCCESS
 from pip._internal.exceptions import CommandError
-from pip._internal.req.req_install import InstallRequirement
-from pip._internal.req.req_tracker import get_requirement_tracker
+from pip._internal.operations.build.build_tracker import get_build_tracker
+from pip._internal.req.req_install import (
+    InstallRequirement,
+    check_legacy_setup_py_options,
+)
 from pip._internal.utils.misc import ensure_dir, normalize_path
 from pip._internal.utils.temp_dir import TempDirectory
 from pip._internal.wheel_builder import build, should_build_for_wheel_command
@@ -26,10 +29,8 @@ class WheelCommand(RequirementCommand):
     recompiling your software during every install. For more details, see the
     wheel docs: https://wheel.readthedocs.io/en/latest/
 
-    Requirements: setuptools>=0.8, and wheel.
-
-    'pip wheel' uses the bdist_wheel setuptools extension from the wheel
-    package to build individual wheels.
+    'pip wheel' uses the build system interface as described here:
+    https://pip.pypa.io/en/stable/reference/build-system/
 
     """
 
@@ -40,16 +41,17 @@ class WheelCommand(RequirementCommand):
       %prog [options] [-e] <local project path> ...
       %prog [options] <archive url/path> ..."""
 
-    def add_options(self):
-        # type: () -> None
-
+    def add_options(self) -> None:
         self.cmd_opts.add_option(
-            '-w', '--wheel-dir',
-            dest='wheel_dir',
-            metavar='dir',
+            "-w",
+            "--wheel-dir",
+            dest="wheel_dir",
+            metavar="dir",
             default=os.curdir,
-            help=("Build wheels into <dir>, where the default is the "
-                  "current working directory."),
+            help=(
+                "Build wheels into <dir>, where the default is the "
+                "current working directory."
+            ),
         )
         self.cmd_opts.add_option(cmdoptions.no_binary())
         self.cmd_opts.add_option(cmdoptions.only_binary())
@@ -57,32 +59,35 @@ class WheelCommand(RequirementCommand):
         self.cmd_opts.add_option(cmdoptions.no_build_isolation())
         self.cmd_opts.add_option(cmdoptions.use_pep517())
         self.cmd_opts.add_option(cmdoptions.no_use_pep517())
+        self.cmd_opts.add_option(cmdoptions.check_build_deps())
         self.cmd_opts.add_option(cmdoptions.constraints())
         self.cmd_opts.add_option(cmdoptions.editable())
         self.cmd_opts.add_option(cmdoptions.requirements())
         self.cmd_opts.add_option(cmdoptions.src())
         self.cmd_opts.add_option(cmdoptions.ignore_requires_python())
         self.cmd_opts.add_option(cmdoptions.no_deps())
-        self.cmd_opts.add_option(cmdoptions.build_dir())
         self.cmd_opts.add_option(cmdoptions.progress_bar())
 
         self.cmd_opts.add_option(
-            '--no-verify',
-            dest='no_verify',
-            action='store_true',
+            "--no-verify",
+            dest="no_verify",
+            action="store_true",
             default=False,
             help="Don't verify if built wheel is valid.",
         )
 
+        self.cmd_opts.add_option(cmdoptions.config_settings())
         self.cmd_opts.add_option(cmdoptions.build_options())
         self.cmd_opts.add_option(cmdoptions.global_options())
 
         self.cmd_opts.add_option(
-            '--pre',
-            action='store_true',
+            "--pre",
+            action="store_true",
             default=False,
-            help=("Include pre-release and development versions. By default, "
-                  "pip only finds stable versions."),
+            help=(
+                "Include pre-release and development versions. By default, "
+                "pip only finds stable versions."
+            ),
         )
 
         self.cmd_opts.add_option(cmdoptions.require_hashes())
@@ -96,19 +101,15 @@ class WheelCommand(RequirementCommand):
         self.parser.insert_option_group(0, self.cmd_opts)
 
     @with_cleanup
-    def run(self, options, args):
-        # type: (Values, List[str]) -> int
-        cmdoptions.check_install_build_global(options)
-
+    def run(self, options: Values, args: List[str]) -> int:
         session = self.get_default_session(options)
 
         finder = self._build_package_finder(options, session)
-        wheel_cache = WheelCache(options.cache_dir, options.format_control)
 
         options.wheel_dir = normalize_path(options.wheel_dir)
         ensure_dir(options.wheel_dir)
 
-        req_tracker = self.enter_context(get_requirement_tracker())
+        build_tracker = self.enter_context(get_build_tracker())
 
         directory = TempDirectory(
             delete=not options.no_clean,
@@ -117,15 +118,19 @@ class WheelCommand(RequirementCommand):
         )
 
         reqs = self.get_requirements(args, options, finder, session)
+        check_legacy_setup_py_options(options, reqs)
+
+        wheel_cache = WheelCache(options.cache_dir)
 
         preparer = self.make_requirement_preparer(
             temp_build_dir=directory,
             options=options,
-            req_tracker=req_tracker,
+            build_tracker=build_tracker,
             session=session,
             finder=finder,
             download_dir=options.wheel_dir,
             use_user_site=False,
+            verbosity=self.verbosity,
         )
 
         resolver = self.make_resolver(
@@ -139,17 +144,18 @@ class WheelCommand(RequirementCommand):
 
         self.trace_basic_info(finder)
 
-        requirement_set = resolver.resolve(
-            reqs, check_supported_wheels=True
-        )
+        requirement_set = resolver.resolve(reqs, check_supported_wheels=True)
 
-        reqs_to_build = []  # type: List[InstallRequirement]
+        reqs_to_build: List[InstallRequirement] = []
         for req in requirement_set.requirements.values():
             if req.is_wheel:
                 preparer.save_linked_requirement(req)
             elif should_build_for_wheel_command(req):
                 reqs_to_build.append(req)
 
+        preparer.prepare_linked_requirements_more(requirement_set.requirements.values())
+        requirement_set.warn_legacy_versions_and_specifiers()
+
         # build wheels
         build_successes, build_failures = build(
             reqs_to_build,
@@ -167,12 +173,11 @@ class WheelCommand(RequirementCommand):
             except OSError as e:
                 logger.warning(
                     "Building wheel for %s failed: %s",
-                    req.name, e,
+                    req.name,
+                    e,
                 )
                 build_failures.append(req)
         if len(build_failures) != 0:
-            raise CommandError(
-                "Failed to build one or more wheels"
-            )
+            raise CommandError("Failed to build one or more wheels")
 
         return SUCCESS
diff --git a/env/Lib/site-packages/pip/_internal/configuration.py b/env/Lib/site-packages/pip/_internal/configuration.py
index a4698ec1..96f82495 100644
--- a/env/Lib/site-packages/pip/_internal/configuration.py
+++ b/env/Lib/site-packages/pip/_internal/configuration.py
@@ -13,7 +13,6 @@ Some terminology:
 
 import configparser
 import locale
-import logging
 import os
 import sys
 from typing import Any, Dict, Iterable, List, NewType, Optional, Tuple
@@ -24,41 +23,39 @@ from pip._internal.exceptions import (
 )
 from pip._internal.utils import appdirs
 from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.logging import getLogger
 from pip._internal.utils.misc import ensure_dir, enum
 
 RawConfigParser = configparser.RawConfigParser  # Shorthand
 Kind = NewType("Kind", str)
 
-CONFIG_BASENAME = 'pip.ini' if WINDOWS else 'pip.conf'
+CONFIG_BASENAME = "pip.ini" if WINDOWS else "pip.conf"
 ENV_NAMES_IGNORED = "version", "help"
 
 # The kinds of configurations there are.
 kinds = enum(
-    USER="user",        # User Specific
-    GLOBAL="global",    # System Wide
-    SITE="site",        # [Virtual] Environment Specific
-    ENV="env",          # from PIP_CONFIG_FILE
+    USER="user",  # User Specific
+    GLOBAL="global",  # System Wide
+    SITE="site",  # [Virtual] Environment Specific
+    ENV="env",  # from PIP_CONFIG_FILE
     ENV_VAR="env-var",  # from Environment Variables
 )
 OVERRIDE_ORDER = kinds.GLOBAL, kinds.USER, kinds.SITE, kinds.ENV, kinds.ENV_VAR
 VALID_LOAD_ONLY = kinds.USER, kinds.GLOBAL, kinds.SITE
 
-logger = logging.getLogger(__name__)
+logger = getLogger(__name__)
 
 
 # NOTE: Maybe use the optionx attribute to normalize keynames.
-def _normalize_name(name):
-    # type: (str) -> str
-    """Make a name consistent regardless of source (environment or file)
-    """
-    name = name.lower().replace('_', '-')
-    if name.startswith('--'):
+def _normalize_name(name: str) -> str:
+    """Make a name consistent regardless of source (environment or file)"""
+    name = name.lower().replace("_", "-")
+    if name.startswith("--"):
         name = name[2:]  # only prefer long opts
     return name
 
 
-def _disassemble_key(name):
-    # type: (str) -> List[str]
+def _disassemble_key(name: str) -> List[str]:
     if "." not in name:
         error_message = (
             "Key does not contain dot separated section and key. "
@@ -68,22 +65,18 @@ def _disassemble_key(name):
     return name.split(".", 1)
 
 
-def get_configuration_files():
-    # type: () -> Dict[Kind, List[str]]
+def get_configuration_files() -> Dict[Kind, List[str]]:
     global_config_files = [
-        os.path.join(path, CONFIG_BASENAME)
-        for path in appdirs.site_config_dirs('pip')
+        os.path.join(path, CONFIG_BASENAME) for path in appdirs.site_config_dirs("pip")
     ]
 
     site_config_file = os.path.join(sys.prefix, CONFIG_BASENAME)
     legacy_config_file = os.path.join(
-        os.path.expanduser('~'),
-        'pip' if WINDOWS else '.pip',
+        os.path.expanduser("~"),
+        "pip" if WINDOWS else ".pip",
         CONFIG_BASENAME,
     )
-    new_config_file = os.path.join(
-        appdirs.user_config_dir("pip"), CONFIG_BASENAME
-    )
+    new_config_file = os.path.join(appdirs.user_config_dir("pip"), CONFIG_BASENAME)
     return {
         kinds.GLOBAL: global_config_files,
         kinds.SITE: [site_config_file],
@@ -105,8 +98,7 @@ class Configuration:
     and the data stored is also nice.
     """
 
-    def __init__(self, isolated, load_only=None):
-        # type: (bool, Optional[Kind]) -> None
+    def __init__(self, isolated: bool, load_only: Optional[Kind] = None) -> None:
         super().__init__()
 
         if load_only is not None and load_only not in VALID_LOAD_ONLY:
@@ -119,54 +111,50 @@ class Configuration:
         self.load_only = load_only
 
         # Because we keep track of where we got the data from
-        self._parsers = {
+        self._parsers: Dict[Kind, List[Tuple[str, RawConfigParser]]] = {
             variant: [] for variant in OVERRIDE_ORDER
-        }  # type: Dict[Kind, List[Tuple[str, RawConfigParser]]]
-        self._config = {
+        }
+        self._config: Dict[Kind, Dict[str, Any]] = {
             variant: {} for variant in OVERRIDE_ORDER
-        }  # type: Dict[Kind, Dict[str, Any]]
-        self._modified_parsers = []  # type: List[Tuple[str, RawConfigParser]]
+        }
+        self._modified_parsers: List[Tuple[str, RawConfigParser]] = []
 
-    def load(self):
-        # type: () -> None
-        """Loads configuration from configuration files and environment
-        """
+    def load(self) -> None:
+        """Loads configuration from configuration files and environment"""
         self._load_config_files()
         if not self.isolated:
             self._load_environment_vars()
 
-    def get_file_to_edit(self):
-        # type: () -> Optional[str]
-        """Returns the file with highest priority in configuration
-        """
-        assert self.load_only is not None, \
-            "Need to be specified a file to be editing"
+    def get_file_to_edit(self) -> Optional[str]:
+        """Returns the file with highest priority in configuration"""
+        assert self.load_only is not None, "Need to be specified a file to be editing"
 
         try:
             return self._get_parser_to_modify()[0]
         except IndexError:
             return None
 
-    def items(self):
-        # type: () -> Iterable[Tuple[str, Any]]
+    def items(self) -> Iterable[Tuple[str, Any]]:
         """Returns key-value pairs like dict.items() representing the loaded
         configuration
         """
         return self._dictionary.items()
 
-    def get_value(self, key):
-        # type: (str) -> Any
-        """Get a value from the configuration.
-        """
+    def get_value(self, key: str) -> Any:
+        """Get a value from the configuration."""
+        orig_key = key
+        key = _normalize_name(key)
         try:
             return self._dictionary[key]
         except KeyError:
-            raise ConfigurationError(f"No such key - {key}")
-
-    def set_value(self, key, value):
-        # type: (str, Any) -> None
-        """Modify a value in the configuration.
-        """
+            # disassembling triggers a more useful error message than simply
+            # "No such key" in the case that the key isn't in the form command.option
+            _disassemble_key(key)
+            raise ConfigurationError(f"No such key - {orig_key}")
+
+    def set_value(self, key: str, value: Any) -> None:
+        """Modify a value in the configuration."""
+        key = _normalize_name(key)
         self._ensure_have_load_only()
 
         assert self.load_only
@@ -183,21 +171,23 @@ class Configuration:
         self._config[self.load_only][key] = value
         self._mark_as_modified(fname, parser)
 
-    def unset_value(self, key):
-        # type: (str) -> None
+    def unset_value(self, key: str) -> None:
         """Unset a value in the configuration."""
+        orig_key = key
+        key = _normalize_name(key)
         self._ensure_have_load_only()
 
         assert self.load_only
         if key not in self._config[self.load_only]:
-            raise ConfigurationError(f"No such key - {key}")
+            raise ConfigurationError(f"No such key - {orig_key}")
 
         fname, parser = self._get_parser_to_modify()
 
         if parser is not None:
             section, name = _disassemble_key(key)
-            if not (parser.has_section(section)
-                    and parser.remove_option(section, name)):
+            if not (
+                parser.has_section(section) and parser.remove_option(section, name)
+            ):
                 # The option was not removed.
                 raise ConfigurationError(
                     "Fatal Internal error [id=1]. Please report as a bug."
@@ -210,10 +200,8 @@ class Configuration:
 
         del self._config[self.load_only][key]
 
-    def save(self):
-        # type: () -> None
-        """Save the current in-memory state.
-        """
+    def save(self) -> None:
+        """Save the current in-memory state."""
         self._ensure_have_load_only()
 
         for fname, parser in self._modified_parsers:
@@ -222,24 +210,28 @@ class Configuration:
             # Ensure directory exists.
             ensure_dir(os.path.dirname(fname))
 
-            with open(fname, "w") as f:
-                parser.write(f)
+            # Ensure directory's permission(need to be writeable)
+            try:
+                with open(fname, "w") as f:
+                    parser.write(f)
+            except OSError as error:
+                raise ConfigurationError(
+                    f"An error occurred while writing to the configuration file "
+                    f"{fname}: {error}"
+                )
 
     #
     # Private routines
     #
 
-    def _ensure_have_load_only(self):
-        # type: () -> None
+    def _ensure_have_load_only(self) -> None:
         if self.load_only is None:
             raise ConfigurationError("Needed a specific file to be modifying.")
         logger.debug("Will be working with %s variant only", self.load_only)
 
     @property
-    def _dictionary(self):
-        # type: () -> Dict[str, Any]
-        """A dictionary representing the loaded configuration.
-        """
+    def _dictionary(self) -> Dict[str, Any]:
+        """A dictionary representing the loaded configuration."""
         # NOTE: Dictionaries are not populated if not loaded. So, conditionals
         #       are not needed here.
         retval = {}
@@ -249,10 +241,8 @@ class Configuration:
 
         return retval
 
-    def _load_config_files(self):
-        # type: () -> None
-        """Loads configuration from configuration files
-        """
+    def _load_config_files(self) -> None:
+        """Loads configuration from configuration files"""
         config_files = dict(self.iter_config_files())
         if config_files[kinds.ENV][0:1] == [os.devnull]:
             logger.debug(
@@ -266,9 +256,7 @@ class Configuration:
                 # If there's specific variant set in `load_only`, load only
                 # that variant, not the others.
                 if self.load_only is not None and variant != self.load_only:
-                    logger.debug(
-                        "Skipping file '%s' (variant: %s)", fname, variant
-                    )
+                    logger.debug("Skipping file '%s' (variant: %s)", fname, variant)
                     continue
 
                 parser = self._load_file(variant, fname)
@@ -276,9 +264,8 @@ class Configuration:
                 # Keeping track of the parsers used
                 self._parsers[variant].append((fname, parser))
 
-    def _load_file(self, variant, fname):
-        # type: (Kind, str) -> RawConfigParser
-        logger.debug("For variant '%s', will try loading '%s'", variant, fname)
+    def _load_file(self, variant: Kind, fname: str) -> RawConfigParser:
+        logger.verbose("For variant '%s', will try loading '%s'", variant, fname)
         parser = self._construct_parser(fname)
 
         for section in parser.sections():
@@ -287,22 +274,20 @@ class Configuration:
 
         return parser
 
-    def _construct_parser(self, fname):
-        # type: (str) -> RawConfigParser
+    def _construct_parser(self, fname: str) -> RawConfigParser:
         parser = configparser.RawConfigParser()
         # If there is no such file, don't bother reading it but create the
         # parser anyway, to hold the data.
         # Doing this is useful when modifying and saving files, where we don't
         # need to construct a parser.
         if os.path.exists(fname):
+            locale_encoding = locale.getpreferredencoding(False)
             try:
-                parser.read(fname)
+                parser.read(fname, encoding=locale_encoding)
             except UnicodeDecodeError:
                 # See https://github.com/pypa/pip/issues/4963
                 raise ConfigurationFileCouldNotBeLoaded(
-                    reason="contains invalid {} characters".format(
-                        locale.getpreferredencoding(False)
-                    ),
+                    reason=f"contains invalid {locale_encoding} characters",
                     fname=fname,
                 )
             except configparser.Error as error:
@@ -310,16 +295,15 @@ class Configuration:
                 raise ConfigurationFileCouldNotBeLoaded(error=error)
         return parser
 
-    def _load_environment_vars(self):
-        # type: () -> None
-        """Loads configuration from environment variables
-        """
+    def _load_environment_vars(self) -> None:
+        """Loads configuration from environment variables"""
         self._config[kinds.ENV_VAR].update(
             self._normalized_keys(":env:", self.get_environ_vars())
         )
 
-    def _normalized_keys(self, section, items):
-        # type: (str, Iterable[Tuple[str, Any]]) -> Dict[str, Any]
+    def _normalized_keys(
+        self, section: str, items: Iterable[Tuple[str, Any]]
+    ) -> Dict[str, Any]:
         """Normalizes items to construct a dictionary with normalized keys.
 
         This routine is where the names become keys and are made the same
@@ -331,8 +315,7 @@ class Configuration:
             normalized[key] = val
         return normalized
 
-    def get_environ_vars(self):
-        # type: () -> Iterable[Tuple[str, str]]
+    def get_environ_vars(self) -> Iterable[Tuple[str, str]]:
         """Returns a generator with all environmental vars with prefix PIP_"""
         for key, val in os.environ.items():
             if key.startswith("PIP_"):
@@ -341,8 +324,7 @@ class Configuration:
                     yield name, val
 
     # XXX: This is patched in the tests.
-    def iter_config_files(self):
-        # type: () -> Iterable[Tuple[Kind, List[str]]]
+    def iter_config_files(self) -> Iterable[Tuple[Kind, List[str]]]:
         """Yields variant and configuration files associated with it.
 
         This should be treated like items of a dictionary.
@@ -350,7 +332,7 @@ class Configuration:
         # SMELL: Move the conditions out of this function
 
         # environment variables have the lowest priority
-        config_file = os.environ.get('PIP_CONFIG_FILE', None)
+        config_file = os.environ.get("PIP_CONFIG_FILE", None)
         if config_file is not None:
             yield kinds.ENV, [config_file]
         else:
@@ -372,13 +354,11 @@ class Configuration:
         # finally virtualenv configuration first trumping others
         yield kinds.SITE, config_files[kinds.SITE]
 
-    def get_values_in_config(self, variant):
-        # type: (Kind) -> Dict[str, Any]
+    def get_values_in_config(self, variant: Kind) -> Dict[str, Any]:
         """Get values present in a config file"""
         return self._config[variant]
 
-    def _get_parser_to_modify(self):
-        # type: () -> Tuple[str, RawConfigParser]
+    def _get_parser_to_modify(self) -> Tuple[str, RawConfigParser]:
         # Determine which parser to modify
         assert self.load_only
         parsers = self._parsers[self.load_only]
@@ -392,12 +372,10 @@ class Configuration:
         return parsers[-1]
 
     # XXX: This is patched in the tests.
-    def _mark_as_modified(self, fname, parser):
-        # type: (str, RawConfigParser) -> None
+    def _mark_as_modified(self, fname: str, parser: RawConfigParser) -> None:
         file_parser_tuple = (fname, parser)
         if file_parser_tuple not in self._modified_parsers:
             self._modified_parsers.append(file_parser_tuple)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return f"{self.__class__.__name__}({self._dictionary!r})"
diff --git a/env/Lib/site-packages/pip/_internal/distributions/__init__.py b/env/Lib/site-packages/pip/_internal/distributions/__init__.py
index a222f248..9a89a838 100644
--- a/env/Lib/site-packages/pip/_internal/distributions/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/distributions/__init__.py
@@ -4,8 +4,9 @@ from pip._internal.distributions.wheel import WheelDistribution
 from pip._internal.req.req_install import InstallRequirement
 
 
-def make_distribution_for_install_requirement(install_req):
-    # type: (InstallRequirement) -> AbstractDistribution
+def make_distribution_for_install_requirement(
+    install_req: InstallRequirement,
+) -> AbstractDistribution:
     """Returns a Distribution for the given InstallRequirement"""
     # Editable requirements will always be source distributions. They use the
     # legacy logic until we create a modern standard for them.
diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 22cfea607a2612213cf9fd6af0869fe66f430c81..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 796
zcmYe~<>g{vU|^UdaWFN3nStRkh=Yuo7#J8F7#J9eZ5S9BQW#Pga~N_NqZk=MY^EHh
zT;?cdFq=7tC6_gd70hPIVasKYVrOJXVNGFcVTj^LVGm}|<ah}(SCjFUh+|T5Nl{{Q
ziA!d2Nl|7}X-Q^&o+jfhq2T<|qU2OGQNi$x)YKd_K_Sn);*!LioS@Xg(#)dN+|<01
zWJZwjPz+*&T<#2Vxe5aVLk&X~LlIvIV+}(yV=#!vR3uZv4B^2<H5seSgHlUMi}H#U
z5*3hbR7lG&QYgttRY=b)OU+Zjv|N+r7DsAIW=UdFPHGV|0|Ub?j?Cita*)f5SQr=>
zG#PJkXF{ADUzA$7lA(x`fq~&yhqF~oXmM&$aZGAXN@h`ve_pCfQD#}Hg04cSpJ$kB
zP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~
zab`)XZb4#lc4B&JaZEvGfqr~uUP)?EUSf`Z3Q~X<>&M4u=4F<|$LkeT-qOrX%ubC*
zmXA-%FN#NUb15{O*+D@HPBW}*j2z4$T*S@5z~HCJc}t-nvp^4SogT7r#d=AJ#i>Q0
zNV%nmPgyZo7dQ;@szU^Blq{-wMX7~)MX7}_#}~0OFff3f2o7{40_2NZ95%W6DWy57
RcAzv<%)!9Gz{3cJ%m9p)=PCdI

diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index ca1348f8b68113bf2f0bcdd08af1f0b2a626cbfe..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1852
zcmYe~<>g{vU|^UdaWM5R3j@Pr5C<8vGB7YWFfcF_2QV-&q%fo~<}gHoXr>&-T&5@{
zMi84hhdGxeiUrJO$zjc9i(&(_S##KPIiffi8Qd9C*izVA7*g0%8L~K2IC`0*xKbE{
z88kUxg6#6sWW2@UUr>^npO=`U$#{#$C9}AsC^M-PB%;Z9i#H%KIXf{u)h#nGCACPC
z@s^NhUU5lcPEJs2VQFSjYHn&?NixVFWXufZ6x%Q`Fr+d>F{Us?F{Lm@F}E|MF{Uu3
zFt>0-v81wQv8Ax2u(mKXGe)t4d0>Y&Ge&W=Gq5m3aRxJJa@-PeOe!uZN=z<6c32`W
z69a>zLQ-OJszP#3VsWuTT7Hp2Mq*w{PG(-ZLMFtCiAg!B3W-G}nQ4j1CB=GNTnY*b
z3LzP(3PlLFLv$wQRhDF6>P%Hg1j*;*<d+v)L9{FADwL-x<dznfC?usSfNdzrS4c@M
zNiE9F%u7`$K{Z|>FEKY2Y_EcXf<}H3NON*xo_dKwa(+=!YH~?VCB)efoq73rx}^o_
zMTse?3dxDZshUtnE9infSOAHOVukX|k_?67)RNKy6u;<zj0d|dF{d~m=0KSB=<duc
zLeUI1G{3Y27J8uINK8q|1SN#T9GD?+Cuo2|9OT>L#9UB_CKl)Cfr6{3G*7oAGdEQs
zCAA<mFC{fEIWx6b6JOvZ7o{eaq$(sTAjhymeo|Iya*0A}ML~Ws$SEZm@Ni5_$}dY*
z$W1LtOi3(B)B`&$nF*TaKop1#!k~0mEW*IRP{Pp6uz+zP10zEXV+}(*Qwl>c!%9X!
zP3Bvy#ia$QMYlNO<1_OzOXA~iF&Cv4YBJqoDNfBvD+1-um5jGI<Kw}pEIxiE!><-+
ztC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ
z5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2lz-(8d&G7U;)k=9Q!t<t66m
zryym>Vtr7O*DI(j;$&c8kOGwrEMO0FF;>Z9%P4v<e<d@5)Il+b4Z_YK13-QRg-;VB
zC{&8r85kH=GTsvQ%P;ZFEyw|9@YEF7qN4mFO~xW_1_p*AJ~+Y8z`$@zE<Lp*z92h2
zz9_XgzqBYhwKyKx&GH~iK(WEVTxE>ajrjE^gJKcta0U<?pUaB`7#J8dnZfS7#g+yx
zv~KYym1gFo#Ag=g=OltsGr9+43yM+;5{pt%oE;BKUn)rMH^S<EyxKLnK#2=f48+IZ
z;);*Y%}*)KNsW)c#S<T2Selpvm0^#MPsvY?j|WHWE#}0e<Xe1+(2_4VwIm}yrAP=A
z?4qC$=Y^)n<kXy;_;@7m@PL$nBBh9pfq?-Ov&A4G4n`J!9#$4cE*2I>u#6_-El!aC
zz^Pi3y9kt$Zn2eA7G&n77lGpHmSjO@fnI!BYF<iykseCq7J=g6mJ(PVmPqwL0bQX7
zO~LVya4!NS&0B(~3X4(;i$L|-Ep|sIXW!J4M6i31yZ}yIATQkFuz`e?9Vo(!L7w4Y
N<YD4r;$h@r1_02P5MKZQ

diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/installed.cpython-39.pyc
deleted file mode 100644
index bf4c62f802ccbd67d548592d650a465dacbe934c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1197
zcmYe~<>g{vU|^UdaWHi@69dCz5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U~%pAp$!XC_^$?+0oz9!=>
z4*!CZ%>2B>98JbsJT95VB}JJ@r63Va##<teNyQ~aiOD5s;=BQg$=QkNscxBhDXB%t
zAd`?W6U?;=3=9mZ3{i|J3{gxej8V)fOexGQ3{fm8EGeul3{k8pY{3kg?6*Wc^NLFn
zb8=EsknO4J2udv|N-a*!D=Ah;%u~pODN-na*sjOLrJ$go5R#EutdNqQTC9+lU!stg
znwp}Jm{+M#P?TDbSd<9zi9%wrLP<udLQ!gAX=YJsib7^yT7FS3L@pz-SRpZ|C^a#q
z5^P*jYHFTBa(-?>X-R5|9#|-u5y^KTHV8X|qJx8hfuV*Wiy@0Km|-QOpC;2S=AzWX
zTRg>yC7H!(nW-u9NtK$6w^)i(bJA8a6mc^!F#PItwu%WYPAw{qNzF;gEQ;~ZOLZyA
zEK60;RS5O-408<%_6%_hR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy<
z%#KOTD~s{TOo}PaEJ@Xc21{{FL1uw|d}dxrYEfQdj(!SKoEGcDLs74w@|IkBYDs)S
zc6xkKYH@yPQF3Z=JhEy5kQYIb$-q=)f;Eox@EefKj1+JnHay@!2|9%#n4yTBfdLXO
zn#@I@JaCIG4V<WM@h6pL=A^`D7U$=HBMKaN5Q2w+f#H@cB!W{>TpXX9T9TNOSdu7$
z<aA@~PRFa?Pm}EyM|^x<Vs2`D{4K8d_}u)I(i{+*CqBNgG%*J%!yX@>lAjzOU&IUY
z2PnWGP6Wj?gavYJ5gP*o11HEyAO;5`3mXRuSj<n8^A=l4WkF_MdJ!m~Z%Gzp7U;#7
zrRJsN7wMtIOc5yjZYhA}VR5U699zYDNr}a&MWB$qrG%;s6rvS+(DV@x3E(1Dkc&a?
efw&XZ#kV+YAU?JOMOiT@o%1m9F!3<*FarQ;3{gk`

diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/sdist.cpython-39.pyc
deleted file mode 100644
index 4444383634cc4cff58b6e2d53db64ccce1a260e7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/distributions/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index 04dee280ffb115c30d1eebd36b931e88e6cc71bd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1541
zcmYe~<>g{vU|^UdaWHi&3j@Pr5C<8vFfcGUFfcF_2QV-&q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#SUh(=5XY4MsYGSxHF`%rLea!q_C&5HZw<YrEml@
zXmY*;*`>*Ni#;l{z%4T;Rg>`+k4t88Nl|7}X-Q^&o+jfh5yzzBlA^@q5;Sq%fW+kN
z#Pn3R%)FG;B2C6yDh1i;@kOb{`K3k4sm1XrNXEpc<rl@5XQZa)B!etO#!N5|DljlG
zq%uS?rZ7Y?r7%V@r!b{3w=hJpq_Cv0wlGAormzJwXtLiD3<nv5?3Sv+pwxn*)Z)~<
zl46BK1+X;=$hPZoaVaP$D1>BW7AvIWrxq*Z<(DYrrKYARB<58r6cnWvBo-xte5;UH
z4AEY!keryOkd&&Bl3A3RT#{3%P?}een4F!Oq6aoAnGwkgARllrFfcfSqA7uafuV*W
ziy@1#n8%Bui4n|ZDwY7TOPIkt#uUaBre3Cgm0HFUmKvxEh)gqcI0F+y3Ns4>3qvzA
zBSSEQAwzMH0Rtl#Mlvumq%a3FXtGo-^2tw3DOM=SNL9#9ElEsCEJ;*IE6UFWi$Fpk
zEi)%oAv3QeUm-U&H@~P-Au%sSp(wSav?#AwArb5iP^ch>q(VtXVu?a&acZ$bW{D0s
zn2J(!Dl_xa74q}Yjm|HEn^BZnSejXsnwy$e0tp|G!6BNAx405>a`MZgG7HR1{4`l_
zF&Cv4-r~>6PfpB<2RSdkAh9Il7E4}YZfX%I6pPpx7#K8}Zm|@n=A_+XtXj!X#K*wE
z@T=9?DkiizwWv5IH76yrD8@f8)ukx2ELA~QA=J+^%rz+3GsH1i!PC#h-_JGJ(=jI4
z)z>vR#5G94EG8hpCnnKEHzz+mv$!NPJ0>-+EXF4@DW*8HBvls_r-|vQ#W4k$1^V%s
zc_pbud5Jmt$cd*|9~_)|1(mnt(o;*~aVK&CQ2g_N5(YaD6AzORBNHRv|0)BF^s0y7
zm}F*<5l{?bgVGu}ZGp;y6oz01O-4U(xM(sLfvmg5mIls(xA>DvGjmenGmG<cz{we`
z2tx2PFfiPbg(US<)T{|lKOpCWVu69FN*~kFc=h^evfbi{j|W9$eEco0`1suXl+v8k
z`1o5q@$rSFi8)Xi_W1ae{N(ufB2ZWr2{SN2A{gREP*fLz99qQAz`y`17K=gYfrF8S
zl|uk5=BLShi@hqd0F-vX3Fek$L1uwod|7H<N`8?ZO4JmAg6@_ASRNL!dMFXAmy}qX
zS_BHzTS}<PK*3p|2TdIDkkBn+1qC6*KDc?MC7C(Jdf)^CPP<@NBKZdHrCS^}kRY)G
S#bz<cbD%WB!^p$P!wdl2K(i|V

diff --git a/env/Lib/site-packages/pip/_internal/distributions/base.py b/env/Lib/site-packages/pip/_internal/distributions/base.py
index 78ee91e7..75ce2dc9 100644
--- a/env/Lib/site-packages/pip/_internal/distributions/base.py
+++ b/env/Lib/site-packages/pip/_internal/distributions/base.py
@@ -1,9 +1,7 @@
 import abc
-from typing import Optional
-
-from pip._vendor.pkg_resources import Distribution
 
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata.base import BaseDistribution
 from pip._internal.req import InstallRequirement
 
 
@@ -23,17 +21,19 @@ class AbstractDistribution(metaclass=abc.ABCMeta):
        above metadata.
     """
 
-    def __init__(self, req):
-        # type: (InstallRequirement) -> None
+    def __init__(self, req: InstallRequirement) -> None:
         super().__init__()
         self.req = req
 
     @abc.abstractmethod
-    def get_pkg_resources_distribution(self):
-        # type: () -> Optional[Distribution]
+    def get_metadata_distribution(self) -> BaseDistribution:
         raise NotImplementedError()
 
     @abc.abstractmethod
-    def prepare_distribution_metadata(self, finder, build_isolation):
-        # type: (PackageFinder, bool) -> None
+    def prepare_distribution_metadata(
+        self,
+        finder: PackageFinder,
+        build_isolation: bool,
+        check_build_deps: bool,
+    ) -> None:
         raise NotImplementedError()
diff --git a/env/Lib/site-packages/pip/_internal/distributions/installed.py b/env/Lib/site-packages/pip/_internal/distributions/installed.py
index b19dfacb..edb38aa1 100644
--- a/env/Lib/site-packages/pip/_internal/distributions/installed.py
+++ b/env/Lib/site-packages/pip/_internal/distributions/installed.py
@@ -1,9 +1,6 @@
-from typing import Optional
-
-from pip._vendor.pkg_resources import Distribution
-
 from pip._internal.distributions.base import AbstractDistribution
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata import BaseDistribution
 
 
 class InstalledDistribution(AbstractDistribution):
@@ -13,10 +10,14 @@ class InstalledDistribution(AbstractDistribution):
     been computed.
     """
 
-    def get_pkg_resources_distribution(self):
-        # type: () -> Optional[Distribution]
+    def get_metadata_distribution(self) -> BaseDistribution:
+        assert self.req.satisfied_by is not None, "not actually installed"
         return self.req.satisfied_by
 
-    def prepare_distribution_metadata(self, finder, build_isolation):
-        # type: (PackageFinder, bool) -> None
+    def prepare_distribution_metadata(
+        self,
+        finder: PackageFinder,
+        build_isolation: bool,
+        check_build_deps: bool,
+    ) -> None:
         pass
diff --git a/env/Lib/site-packages/pip/_internal/distributions/sdist.py b/env/Lib/site-packages/pip/_internal/distributions/sdist.py
index c873a9f1..4c256479 100644
--- a/env/Lib/site-packages/pip/_internal/distributions/sdist.py
+++ b/env/Lib/site-packages/pip/_internal/distributions/sdist.py
@@ -1,12 +1,11 @@
 import logging
-from typing import Set, Tuple
-
-from pip._vendor.pkg_resources import Distribution
+from typing import Iterable, Set, Tuple
 
 from pip._internal.build_env import BuildEnvironment
 from pip._internal.distributions.base import AbstractDistribution
 from pip._internal.exceptions import InstallationError
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata import BaseDistribution
 from pip._internal.utils.subprocess import runner_with_spinner_message
 
 logger = logging.getLogger(__name__)
@@ -19,40 +18,49 @@ class SourceDistribution(AbstractDistribution):
     generated, either using PEP 517 or using the legacy `setup.py egg_info`.
     """
 
-    def get_pkg_resources_distribution(self):
-        # type: () -> Distribution
+    def get_metadata_distribution(self) -> BaseDistribution:
         return self.req.get_dist()
 
-    def prepare_distribution_metadata(self, finder, build_isolation):
-        # type: (PackageFinder, bool) -> None
+    def prepare_distribution_metadata(
+        self,
+        finder: PackageFinder,
+        build_isolation: bool,
+        check_build_deps: bool,
+    ) -> None:
         # Load pyproject.toml, to determine whether PEP 517 is to be used
         self.req.load_pyproject_toml()
 
         # Set up the build isolation, if this requirement should be isolated
         should_isolate = self.req.use_pep517 and build_isolation
         if should_isolate:
-            self._setup_isolation(finder)
-
-        self.req.prepare_metadata()
-
-    def _setup_isolation(self, finder):
-        # type: (PackageFinder) -> None
-        def _raise_conflicts(conflicting_with, conflicting_reqs):
-            # type: (str, Set[Tuple[str, str]]) -> None
-            format_string = (
-                "Some build dependencies for {requirement} "
-                "conflict with {conflicting_with}: {description}."
+            # Setup an isolated environment and install the build backend static
+            # requirements in it.
+            self._prepare_build_backend(finder)
+            # Check that if the requirement is editable, it either supports PEP 660 or
+            # has a setup.py or a setup.cfg. This cannot be done earlier because we need
+            # to setup the build backend to verify it supports build_editable, nor can
+            # it be done later, because we want to avoid installing build requirements
+            # needlessly. Doing it here also works around setuptools generating
+            # UNKNOWN.egg-info when running get_requires_for_build_wheel on a directory
+            # without setup.py nor setup.cfg.
+            self.req.isolated_editable_sanity_check()
+            # Install the dynamic build requirements.
+            self._install_build_reqs(finder)
+        # Check if the current environment provides build dependencies
+        should_check_deps = self.req.use_pep517 and check_build_deps
+        if should_check_deps:
+            pyproject_requires = self.req.pyproject_requires
+            assert pyproject_requires is not None
+            conflicting, missing = self.req.build_env.check_requirements(
+                pyproject_requires
             )
-            error_message = format_string.format(
-                requirement=self.req,
-                conflicting_with=conflicting_with,
-                description=", ".join(
-                    f"{installed} is incompatible with {wanted}"
-                    for installed, wanted in sorted(conflicting)
-                ),
-            )
-            raise InstallationError(error_message)
+            if conflicting:
+                self._raise_conflicts("the backend dependencies", conflicting)
+            if missing:
+                self._raise_missing_reqs(missing)
+        self.req.prepare_metadata()
 
+    def _prepare_build_backend(self, finder: PackageFinder) -> None:
         # Isolate in a BuildEnvironment and install the build-time
         # requirements.
         pyproject_requires = self.req.pyproject_requires
@@ -60,13 +68,13 @@ class SourceDistribution(AbstractDistribution):
 
         self.req.build_env = BuildEnvironment()
         self.req.build_env.install_requirements(
-            finder, pyproject_requires, "overlay", "Installing build dependencies"
+            finder, pyproject_requires, "overlay", kind="build dependencies"
         )
         conflicting, missing = self.req.build_env.check_requirements(
             self.req.requirements_to_check
         )
         if conflicting:
-            _raise_conflicts("PEP 517/518 supported requirements", conflicting)
+            self._raise_conflicts("PEP 517/518 supported requirements", conflicting)
         if missing:
             logger.warning(
                 "Missing build requirements in pyproject.toml for %s.",
@@ -77,19 +85,66 @@ class SourceDistribution(AbstractDistribution):
                 "pip cannot fall back to setuptools without %s.",
                 " and ".join(map(repr, sorted(missing))),
             )
-        # Install any extra build dependencies that the backend requests.
-        # This must be done in a second pass, as the pyproject.toml
-        # dependencies must be installed before we can call the backend.
+
+    def _get_build_requires_wheel(self) -> Iterable[str]:
         with self.req.build_env:
             runner = runner_with_spinner_message("Getting requirements to build wheel")
             backend = self.req.pep517_backend
             assert backend is not None
             with backend.subprocess_runner(runner):
-                reqs = backend.get_requires_for_build_wheel()
+                return backend.get_requires_for_build_wheel()
 
-        conflicting, missing = self.req.build_env.check_requirements(reqs)
+    def _get_build_requires_editable(self) -> Iterable[str]:
+        with self.req.build_env:
+            runner = runner_with_spinner_message(
+                "Getting requirements to build editable"
+            )
+            backend = self.req.pep517_backend
+            assert backend is not None
+            with backend.subprocess_runner(runner):
+                return backend.get_requires_for_build_editable()
+
+    def _install_build_reqs(self, finder: PackageFinder) -> None:
+        # Install any extra build dependencies that the backend requests.
+        # This must be done in a second pass, as the pyproject.toml
+        # dependencies must be installed before we can call the backend.
+        if (
+            self.req.editable
+            and self.req.permit_editable_wheels
+            and self.req.supports_pyproject_editable()
+        ):
+            build_reqs = self._get_build_requires_editable()
+        else:
+            build_reqs = self._get_build_requires_wheel()
+        conflicting, missing = self.req.build_env.check_requirements(build_reqs)
         if conflicting:
-            _raise_conflicts("the backend dependencies", conflicting)
+            self._raise_conflicts("the backend dependencies", conflicting)
         self.req.build_env.install_requirements(
-            finder, missing, "normal", "Installing backend dependencies"
+            finder, missing, "normal", kind="backend dependencies"
+        )
+
+    def _raise_conflicts(
+        self, conflicting_with: str, conflicting_reqs: Set[Tuple[str, str]]
+    ) -> None:
+        format_string = (
+            "Some build dependencies for {requirement} "
+            "conflict with {conflicting_with}: {description}."
+        )
+        error_message = format_string.format(
+            requirement=self.req,
+            conflicting_with=conflicting_with,
+            description=", ".join(
+                f"{installed} is incompatible with {wanted}"
+                for installed, wanted in sorted(conflicting_reqs)
+            ),
+        )
+        raise InstallationError(error_message)
+
+    def _raise_missing_reqs(self, missing: Set[str]) -> None:
+        format_string = (
+            "Some build dependencies for {requirement} are missing: {missing}."
+        )
+        error_message = format_string.format(
+            requirement=self.req, missing=", ".join(map(repr, sorted(missing)))
         )
+        raise InstallationError(error_message)
diff --git a/env/Lib/site-packages/pip/_internal/distributions/wheel.py b/env/Lib/site-packages/pip/_internal/distributions/wheel.py
index d0384797..03aac775 100644
--- a/env/Lib/site-packages/pip/_internal/distributions/wheel.py
+++ b/env/Lib/site-packages/pip/_internal/distributions/wheel.py
@@ -1,10 +1,12 @@
-from zipfile import ZipFile
-
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.packaging.utils import canonicalize_name
 
 from pip._internal.distributions.base import AbstractDistribution
 from pip._internal.index.package_finder import PackageFinder
-from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel
+from pip._internal.metadata import (
+    BaseDistribution,
+    FilesystemWheel,
+    get_wheel_distribution,
+)
 
 
 class WheelDistribution(AbstractDistribution):
@@ -13,22 +15,20 @@ class WheelDistribution(AbstractDistribution):
     This does not need any preparation as wheels can be directly unpacked.
     """
 
-    def get_pkg_resources_distribution(self):
-        # type: () -> Distribution
+    def get_metadata_distribution(self) -> BaseDistribution:
         """Loads the metadata from the wheel file into memory and returns a
         Distribution that uses it, not relying on the wheel file or
         requirement.
         """
-        # Set as part of preparation during download.
-        assert self.req.local_file_path
-        # Wheels are never unnamed.
-        assert self.req.name
-
-        with ZipFile(self.req.local_file_path, allowZip64=True) as z:
-            return pkg_resources_distribution_for_wheel(
-                z, self.req.name, self.req.local_file_path
-            )
-
-    def prepare_distribution_metadata(self, finder, build_isolation):
-        # type: (PackageFinder, bool) -> None
+        assert self.req.local_file_path, "Set as part of preparation during download"
+        assert self.req.name, "Wheels are never unnamed"
+        wheel = FilesystemWheel(self.req.local_file_path)
+        return get_wheel_distribution(wheel, canonicalize_name(self.req.name))
+
+    def prepare_distribution_metadata(
+        self,
+        finder: PackageFinder,
+        build_isolation: bool,
+        check_build_deps: bool,
+    ) -> None:
         pass
diff --git a/env/Lib/site-packages/pip/_internal/exceptions.py b/env/Lib/site-packages/pip/_internal/exceptions.py
index 8aacf812..d95fe44b 100644
--- a/env/Lib/site-packages/pip/_internal/exceptions.py
+++ b/env/Lib/site-packages/pip/_internal/exceptions.py
@@ -1,22 +1,181 @@
-"""Exceptions used throughout package"""
+"""Exceptions used throughout package.
+
+This module MUST NOT try to import from anything within `pip._internal` to
+operate. This is expected to be importable from any/all files within the
+subpackage and, thus, should not depend on them.
+"""
 
 import configparser
+import contextlib
+import locale
+import logging
+import pathlib
+import re
+import sys
 from itertools import chain, groupby, repeat
-from typing import TYPE_CHECKING, Dict, List, Optional
+from typing import TYPE_CHECKING, Dict, Iterator, List, Optional, Union
 
-from pip._vendor.pkg_resources import Distribution
 from pip._vendor.requests.models import Request, Response
+from pip._vendor.rich.console import Console, ConsoleOptions, RenderResult
+from pip._vendor.rich.markup import escape
+from pip._vendor.rich.text import Text
 
 if TYPE_CHECKING:
     from hashlib import _Hash
+    from typing import Literal
 
+    from pip._internal.metadata import BaseDistribution
     from pip._internal.req.req_install import InstallRequirement
 
+logger = logging.getLogger(__name__)
+
+
+#
+# Scaffolding
+#
+def _is_kebab_case(s: str) -> bool:
+    return re.match(r"^[a-z]+(-[a-z]+)*$", s) is not None
+
+
+def _prefix_with_indent(
+    s: Union[Text, str],
+    console: Console,
+    *,
+    prefix: str,
+    indent: str,
+) -> Text:
+    if isinstance(s, Text):
+        text = s
+    else:
+        text = console.render_str(s)
+
+    return console.render_str(prefix, overflow="ignore") + console.render_str(
+        f"\n{indent}", overflow="ignore"
+    ).join(text.split(allow_blank=True))
+
 
 class PipError(Exception):
-    """Base pip exception"""
+    """The base pip error."""
+
+
+class DiagnosticPipError(PipError):
+    """An error, that presents diagnostic information to the user.
+
+    This contains a bunch of logic, to enable pretty presentation of our error
+    messages. Each error gets a unique reference. Each error can also include
+    additional context, a hint and/or a note -- which are presented with the
+    main error message in a consistent style.
+
+    This is adapted from the error output styling in `sphinx-theme-builder`.
+    """
+
+    reference: str
+
+    def __init__(
+        self,
+        *,
+        kind: 'Literal["error", "warning"]' = "error",
+        reference: Optional[str] = None,
+        message: Union[str, Text],
+        context: Optional[Union[str, Text]],
+        hint_stmt: Optional[Union[str, Text]],
+        note_stmt: Optional[Union[str, Text]] = None,
+        link: Optional[str] = None,
+    ) -> None:
+        # Ensure a proper reference is provided.
+        if reference is None:
+            assert hasattr(self, "reference"), "error reference not provided!"
+            reference = self.reference
+        assert _is_kebab_case(reference), "error reference must be kebab-case!"
+
+        self.kind = kind
+        self.reference = reference
+
+        self.message = message
+        self.context = context
+
+        self.note_stmt = note_stmt
+        self.hint_stmt = hint_stmt
+
+        self.link = link
+
+        super().__init__(f"<{self.__class__.__name__}: {self.reference}>")
+
+    def __repr__(self) -> str:
+        return (
+            f"<{self.__class__.__name__}("
+            f"reference={self.reference!r}, "
+            f"message={self.message!r}, "
+            f"context={self.context!r}, "
+            f"note_stmt={self.note_stmt!r}, "
+            f"hint_stmt={self.hint_stmt!r}"
+            ")>"
+        )
+
+    def __rich_console__(
+        self,
+        console: Console,
+        options: ConsoleOptions,
+    ) -> RenderResult:
+        colour = "red" if self.kind == "error" else "yellow"
+
+        yield f"[{colour} bold]{self.kind}[/]: [bold]{self.reference}[/]"
+        yield ""
+
+        if not options.ascii_only:
+            # Present the main message, with relevant context indented.
+            if self.context is not None:
+                yield _prefix_with_indent(
+                    self.message,
+                    console,
+                    prefix=f"[{colour}]×[/] ",
+                    indent=f"[{colour}]│[/] ",
+                )
+                yield _prefix_with_indent(
+                    self.context,
+                    console,
+                    prefix=f"[{colour}]╰─>[/] ",
+                    indent=f"[{colour}]   [/] ",
+                )
+            else:
+                yield _prefix_with_indent(
+                    self.message,
+                    console,
+                    prefix="[red]×[/] ",
+                    indent="  ",
+                )
+        else:
+            yield self.message
+            if self.context is not None:
+                yield ""
+                yield self.context
+
+        if self.note_stmt is not None or self.hint_stmt is not None:
+            yield ""
+
+        if self.note_stmt is not None:
+            yield _prefix_with_indent(
+                self.note_stmt,
+                console,
+                prefix="[magenta bold]note[/]: ",
+                indent="      ",
+            )
+        if self.hint_stmt is not None:
+            yield _prefix_with_indent(
+                self.hint_stmt,
+                console,
+                prefix="[cyan bold]hint[/]: ",
+                indent="      ",
+            )
+
+        if self.link is not None:
+            yield ""
+            yield f"Link: {self.link}"
 
 
+#
+# Actual Errors
+#
 class ConfigurationError(PipError):
     """General exception in configuration"""
 
@@ -29,17 +188,54 @@ class UninstallationError(PipError):
     """General exception during uninstallation"""
 
 
+class MissingPyProjectBuildRequires(DiagnosticPipError):
+    """Raised when pyproject.toml has `build-system`, but no `build-system.requires`."""
+
+    reference = "missing-pyproject-build-system-requires"
+
+    def __init__(self, *, package: str) -> None:
+        super().__init__(
+            message=f"Can not process {escape(package)}",
+            context=Text(
+                "This package has an invalid pyproject.toml file.\n"
+                "The [build-system] table is missing the mandatory `requires` key."
+            ),
+            note_stmt="This is an issue with the package mentioned above, not pip.",
+            hint_stmt=Text("See PEP 518 for the detailed specification."),
+        )
+
+
+class InvalidPyProjectBuildRequires(DiagnosticPipError):
+    """Raised when pyproject.toml an invalid `build-system.requires`."""
+
+    reference = "invalid-pyproject-build-system-requires"
+
+    def __init__(self, *, package: str, reason: str) -> None:
+        super().__init__(
+            message=f"Can not process {escape(package)}",
+            context=Text(
+                "This package has an invalid `build-system.requires` key in "
+                f"pyproject.toml.\n{reason}"
+            ),
+            note_stmt="This is an issue with the package mentioned above, not pip.",
+            hint_stmt=Text("See PEP 518 for the detailed specification."),
+        )
+
+
 class NoneMetadataError(PipError):
-    """
-    Raised when accessing "METADATA" or "PKG-INFO" metadata for a
-    pip._vendor.pkg_resources.Distribution object and
-    `dist.has_metadata('METADATA')` returns True but
-    `dist.get_metadata('METADATA')` returns None (and similarly for
-    "PKG-INFO").
+    """Raised when accessing a Distribution's "METADATA" or "PKG-INFO".
+
+    This signifies an inconsistency, when the Distribution claims to have
+    the metadata file (if not, raise ``FileNotFoundError`` instead), but is
+    not actually able to produce its content. This may be due to permission
+    errors.
     """
 
-    def __init__(self, dist, metadata_name):
-        # type: (Distribution, str) -> None
+    def __init__(
+        self,
+        dist: "BaseDistribution",
+        metadata_name: str,
+    ) -> None:
         """
         :param dist: A Distribution object.
         :param metadata_name: The name of the metadata being accessed
@@ -48,28 +244,24 @@ class NoneMetadataError(PipError):
         self.dist = dist
         self.metadata_name = metadata_name
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         # Use `dist` in the error message because its stringification
         # includes more information, like the version and location.
-        return (
-            'None {} metadata found for distribution: {}'.format(
-                self.metadata_name, self.dist,
-            )
+        return "None {} metadata found for distribution: {}".format(
+            self.metadata_name,
+            self.dist,
         )
 
 
 class UserInstallationInvalid(InstallationError):
     """A --user install is requested on an environment without user site."""
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return "User base directory is not specified"
 
 
 class InvalidSchemeCombination(InstallationError):
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         before = ", ".join(str(a) for a in self.args[:-1])
         return f"Cannot set {before} and {self.args[-1]} together"
 
@@ -102,8 +294,12 @@ class PreviousBuildDirError(PipError):
 class NetworkConnectionError(PipError):
     """HTTP connection error"""
 
-    def __init__(self, error_msg, response=None, request=None):
-        # type: (str, Response, Request) -> None
+    def __init__(
+        self,
+        error_msg: str,
+        response: Optional[Response] = None,
+        request: Optional[Request] = None,
+    ) -> None:
         """
         Initialize NetworkConnectionError with  `request` and `response`
         objects.
@@ -111,13 +307,15 @@ class NetworkConnectionError(PipError):
         self.response = response
         self.request = request
         self.error_msg = error_msg
-        if (self.response is not None and not self.request and
-                hasattr(response, 'request')):
+        if (
+            self.response is not None
+            and not self.request
+            and hasattr(response, "request")
+        ):
             self.request = self.response.request
         super().__init__(error_msg, response, request)
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return str(self.error_msg)
 
 
@@ -129,74 +327,122 @@ class UnsupportedWheel(InstallationError):
     """Unsupported wheel."""
 
 
+class InvalidWheel(InstallationError):
+    """Invalid (e.g. corrupt) wheel."""
+
+    def __init__(self, location: str, name: str):
+        self.location = location
+        self.name = name
+
+    def __str__(self) -> str:
+        return f"Wheel '{self.name}' located at {self.location} is invalid."
+
+
 class MetadataInconsistent(InstallationError):
     """Built metadata contains inconsistent information.
 
     This is raised when the metadata contains values (e.g. name and version)
-    that do not match the information previously obtained from sdist filename
-    or user-supplied ``#egg=`` value.
+    that do not match the information previously obtained from sdist filename,
+    user-supplied ``#egg=`` value, or an install requirement name.
     """
-    def __init__(self, ireq, field, f_val, m_val):
-        # type: (InstallRequirement, str, str, str) -> None
+
+    def __init__(
+        self, ireq: "InstallRequirement", field: str, f_val: str, m_val: str
+    ) -> None:
         self.ireq = ireq
         self.field = field
         self.f_val = f_val
         self.m_val = m_val
 
-    def __str__(self):
-        # type: () -> str
-        template = (
-            "Requested {} has inconsistent {}: "
-            "filename has {!r}, but metadata has {!r}"
+    def __str__(self) -> str:
+        return (
+            f"Requested {self.ireq} has inconsistent {self.field}: "
+            f"expected {self.f_val!r}, but metadata has {self.m_val!r}"
         )
-        return template.format(self.ireq, self.field, self.f_val, self.m_val)
 
 
-class InstallationSubprocessError(InstallationError):
-    """A subprocess call failed during installation."""
-    def __init__(self, returncode, description):
-        # type: (int, str) -> None
-        self.returncode = returncode
-        self.description = description
+class InstallationSubprocessError(DiagnosticPipError, InstallationError):
+    """A subprocess call failed."""
 
-    def __str__(self):
-        # type: () -> str
-        return (
-            "Command errored out with exit status {}: {} "
-            "Check the logs for full command output."
-        ).format(self.returncode, self.description)
+    reference = "subprocess-exited-with-error"
+
+    def __init__(
+        self,
+        *,
+        command_description: str,
+        exit_code: int,
+        output_lines: Optional[List[str]],
+    ) -> None:
+        if output_lines is None:
+            output_prompt = Text("See above for output.")
+        else:
+            output_prompt = (
+                Text.from_markup(f"[red][{len(output_lines)} lines of output][/]\n")
+                + Text("".join(output_lines))
+                + Text.from_markup(R"[red]\[end of output][/]")
+            )
+
+        super().__init__(
+            message=(
+                f"[green]{escape(command_description)}[/] did not run successfully.\n"
+                f"exit code: {exit_code}"
+            ),
+            context=output_prompt,
+            hint_stmt=None,
+            note_stmt=(
+                "This error originates from a subprocess, and is likely not a "
+                "problem with pip."
+            ),
+        )
+
+        self.command_description = command_description
+        self.exit_code = exit_code
+
+    def __str__(self) -> str:
+        return f"{self.command_description} exited with {self.exit_code}"
+
+
+class MetadataGenerationFailed(InstallationSubprocessError, InstallationError):
+    reference = "metadata-generation-failed"
+
+    def __init__(
+        self,
+        *,
+        package_details: str,
+    ) -> None:
+        super(InstallationSubprocessError, self).__init__(
+            message="Encountered error while generating package metadata.",
+            context=escape(package_details),
+            hint_stmt="See above for details.",
+            note_stmt="This is an issue with the package mentioned above, not pip.",
+        )
+
+    def __str__(self) -> str:
+        return "metadata generation failed"
 
 
 class HashErrors(InstallationError):
     """Multiple HashError instances rolled into one for reporting"""
 
-    def __init__(self):
-        # type: () -> None
-        self.errors = []  # type: List[HashError]
+    def __init__(self) -> None:
+        self.errors: List["HashError"] = []
 
-    def append(self, error):
-        # type: (HashError) -> None
+    def append(self, error: "HashError") -> None:
         self.errors.append(error)
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         lines = []
         self.errors.sort(key=lambda e: e.order)
         for cls, errors_of_cls in groupby(self.errors, lambda e: e.__class__):
             lines.append(cls.head)
             lines.extend(e.body() for e in errors_of_cls)
         if lines:
-            return '\n'.join(lines)
-        return ''
+            return "\n".join(lines)
+        return ""
 
-    def __nonzero__(self):
-        # type: () -> bool
+    def __bool__(self) -> bool:
         return bool(self.errors)
 
-    def __bool__(self):
-        # type: () -> bool
-        return self.__nonzero__()
-
 
 class HashError(InstallationError):
     """
@@ -214,12 +460,12 @@ class HashError(InstallationError):
         typically available earlier.
 
     """
-    req = None  # type: Optional[InstallRequirement]
-    head = ''
-    order = -1  # type: int
 
-    def body(self):
-        # type: () -> str
+    req: Optional["InstallRequirement"] = None
+    head = ""
+    order: int = -1
+
+    def body(self) -> str:
         """Return a summary of me for display under the heading.
 
         This default implementation simply prints a description of the
@@ -229,21 +475,19 @@ class HashError(InstallationError):
             its link already populated by the resolver's _populate_link().
 
         """
-        return f'    {self._requirement_name()}'
+        return f"    {self._requirement_name()}"
 
-    def __str__(self):
-        # type: () -> str
-        return f'{self.head}\n{self.body()}'
+    def __str__(self) -> str:
+        return f"{self.head}\n{self.body()}"
 
-    def _requirement_name(self):
-        # type: () -> str
+    def _requirement_name(self) -> str:
         """Return a description of the requirement that triggered me.
 
         This default implementation returns long description of the req, with
         line numbers
 
         """
-        return str(self.req) if self.req else 'unknown package'
+        return str(self.req) if self.req else "unknown package"
 
 
 class VcsHashUnsupported(HashError):
@@ -251,8 +495,10 @@ class VcsHashUnsupported(HashError):
     we don't have a method for hashing those."""
 
     order = 0
-    head = ("Can't verify hashes for these requirements because we don't "
-            "have a way to hash version control repositories:")
+    head = (
+        "Can't verify hashes for these requirements because we don't "
+        "have a way to hash version control repositories:"
+    )
 
 
 class DirectoryUrlHashUnsupported(HashError):
@@ -260,32 +506,34 @@ class DirectoryUrlHashUnsupported(HashError):
     we don't have a method for hashing those."""
 
     order = 1
-    head = ("Can't verify hashes for these file:// requirements because they "
-            "point to directories:")
+    head = (
+        "Can't verify hashes for these file:// requirements because they "
+        "point to directories:"
+    )
 
 
 class HashMissing(HashError):
     """A hash was needed for a requirement but is absent."""
 
     order = 2
-    head = ('Hashes are required in --require-hashes mode, but they are '
-            'missing from some requirements. Here is a list of those '
-            'requirements along with the hashes their downloaded archives '
-            'actually had. Add lines like these to your requirements files to '
-            'prevent tampering. (If you did not enable --require-hashes '
-            'manually, note that it turns on automatically when any package '
-            'has a hash.)')
-
-    def __init__(self, gotten_hash):
-        # type: (str) -> None
+    head = (
+        "Hashes are required in --require-hashes mode, but they are "
+        "missing from some requirements. Here is a list of those "
+        "requirements along with the hashes their downloaded archives "
+        "actually had. Add lines like these to your requirements files to "
+        "prevent tampering. (If you did not enable --require-hashes "
+        "manually, note that it turns on automatically when any package "
+        "has a hash.)"
+    )
+
+    def __init__(self, gotten_hash: str) -> None:
         """
         :param gotten_hash: The hash of the (possibly malicious) archive we
             just downloaded
         """
         self.gotten_hash = gotten_hash
 
-    def body(self):
-        # type: () -> str
+    def body(self) -> str:
         # Dodge circular import.
         from pip._internal.utils.hashes import FAVORITE_HASH
 
@@ -294,13 +542,16 @@ class HashMissing(HashError):
             # In the case of URL-based requirements, display the original URL
             # seen in the requirements file rather than the package name,
             # so the output can be directly copied into the requirements file.
-            package = (self.req.original_link if self.req.original_link
-                       # In case someone feeds something downright stupid
-                       # to InstallRequirement's constructor.
-                       else getattr(self.req, 'req', None))
-        return '    {} --hash={}:{}'.format(package or 'unknown package',
-                                            FAVORITE_HASH,
-                                            self.gotten_hash)
+            package = (
+                self.req.original_link
+                if self.req.is_direct
+                # In case someone feeds something downright stupid
+                # to InstallRequirement's constructor.
+                else getattr(self.req, "req", None)
+            )
+        return "    {} --hash={}:{}".format(
+            package or "unknown package", FAVORITE_HASH, self.gotten_hash
+        )
 
 
 class HashUnpinned(HashError):
@@ -308,8 +559,10 @@ class HashUnpinned(HashError):
     version."""
 
     order = 3
-    head = ('In --require-hashes mode, all requirements must have their '
-            'versions pinned with ==. These do not:')
+    head = (
+        "In --require-hashes mode, all requirements must have their "
+        "versions pinned with ==. These do not:"
+    )
 
 
 class HashMismatch(HashError):
@@ -321,14 +574,16 @@ class HashMismatch(HashError):
         improve its error message.
 
     """
-    order = 4
-    head = ('THESE PACKAGES DO NOT MATCH THE HASHES FROM THE REQUIREMENTS '
-            'FILE. If you have updated the package versions, please update '
-            'the hashes. Otherwise, examine the package contents carefully; '
-            'someone may have tampered with them.')
 
-    def __init__(self, allowed, gots):
-        # type: (Dict[str, List[str]], Dict[str, _Hash]) -> None
+    order = 4
+    head = (
+        "THESE PACKAGES DO NOT MATCH THE HASHES FROM THE REQUIREMENTS "
+        "FILE. If you have updated the package versions, please update "
+        "the hashes. Otherwise, examine the package contents carefully; "
+        "someone may have tampered with them."
+    )
+
+    def __init__(self, allowed: Dict[str, List[str]], gots: Dict[str, "_Hash"]) -> None:
         """
         :param allowed: A dict of algorithm names pointing to lists of allowed
             hex digests
@@ -338,13 +593,10 @@ class HashMismatch(HashError):
         self.allowed = allowed
         self.gots = gots
 
-    def body(self):
-        # type: () -> str
-        return '    {}:\n{}'.format(self._requirement_name(),
-                                    self._hash_comparison())
+    def body(self) -> str:
+        return "    {}:\n{}".format(self._requirement_name(), self._hash_comparison())
 
-    def _hash_comparison(self):
-        # type: () -> str
+    def _hash_comparison(self) -> str:
         """
         Return a comparison of actual and expected hash values.
 
@@ -355,20 +607,22 @@ class HashMismatch(HashError):
                     Got        bcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdefbcdef
 
         """
-        def hash_then_or(hash_name):
-            # type: (str) -> chain[str]
+
+        def hash_then_or(hash_name: str) -> "chain[str]":
             # For now, all the decent hashes have 6-char names, so we can get
             # away with hard-coding space literals.
-            return chain([hash_name], repeat('    or'))
+            return chain([hash_name], repeat("    or"))
 
-        lines = []  # type: List[str]
+        lines: List[str] = []
         for hash_name, expecteds in self.allowed.items():
             prefix = hash_then_or(hash_name)
-            lines.extend(('        Expected {} {}'.format(next(prefix), e))
-                         for e in expecteds)
-            lines.append('             Got        {}\n'.format(
-                         self.gots[hash_name].hexdigest()))
-        return '\n'.join(lines)
+            lines.extend(
+                ("        Expected {} {}".format(next(prefix), e)) for e in expecteds
+            )
+            lines.append(
+                "             Got        {}\n".format(self.gots[hash_name].hexdigest())
+            )
+        return "\n".join(lines)
 
 
 class UnsupportedPythonVersion(InstallationError):
@@ -377,21 +631,103 @@ class UnsupportedPythonVersion(InstallationError):
 
 
 class ConfigurationFileCouldNotBeLoaded(ConfigurationError):
-    """When there are errors while loading a configuration file
-    """
-
-    def __init__(self, reason="could not be loaded", fname=None, error=None):
-        # type: (str, Optional[str], Optional[configparser.Error]) -> None
+    """When there are errors while loading a configuration file"""
+
+    def __init__(
+        self,
+        reason: str = "could not be loaded",
+        fname: Optional[str] = None,
+        error: Optional[configparser.Error] = None,
+    ) -> None:
         super().__init__(error)
         self.reason = reason
         self.fname = fname
         self.error = error
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         if self.fname is not None:
             message_part = f" in {self.fname}."
         else:
             assert self.error is not None
             message_part = f".\n{self.error}\n"
         return f"Configuration file {self.reason}{message_part}"
+
+
+_DEFAULT_EXTERNALLY_MANAGED_ERROR = f"""\
+The Python environment under {sys.prefix} is managed externally, and may not be
+manipulated by the user. Please use specific tooling from the distributor of
+the Python installation to interact with this environment instead.
+"""
+
+
+class ExternallyManagedEnvironment(DiagnosticPipError):
+    """The current environment is externally managed.
+
+    This is raised when the current environment is externally managed, as
+    defined by `PEP 668`_. The ``EXTERNALLY-MANAGED`` configuration is checked
+    and displayed when the error is bubbled up to the user.
+
+    :param error: The error message read from ``EXTERNALLY-MANAGED``.
+    """
+
+    reference = "externally-managed-environment"
+
+    def __init__(self, error: Optional[str]) -> None:
+        if error is None:
+            context = Text(_DEFAULT_EXTERNALLY_MANAGED_ERROR)
+        else:
+            context = Text(error)
+        super().__init__(
+            message="This environment is externally managed",
+            context=context,
+            note_stmt=(
+                "If you believe this is a mistake, please contact your "
+                "Python installation or OS distribution provider. "
+                "You can override this, at the risk of breaking your Python "
+                "installation or OS, by passing --break-system-packages."
+            ),
+            hint_stmt=Text("See PEP 668 for the detailed specification."),
+        )
+
+    @staticmethod
+    def _iter_externally_managed_error_keys() -> Iterator[str]:
+        # LC_MESSAGES is in POSIX, but not the C standard. The most common
+        # platform that does not implement this category is Windows, where
+        # using other categories for console message localization is equally
+        # unreliable, so we fall back to the locale-less vendor message. This
+        # can always be re-evaluated when a vendor proposes a new alternative.
+        try:
+            category = locale.LC_MESSAGES
+        except AttributeError:
+            lang: Optional[str] = None
+        else:
+            lang, _ = locale.getlocale(category)
+        if lang is not None:
+            yield f"Error-{lang}"
+            for sep in ("-", "_"):
+                before, found, _ = lang.partition(sep)
+                if not found:
+                    continue
+                yield f"Error-{before}"
+        yield "Error"
+
+    @classmethod
+    def from_config(
+        cls,
+        config: Union[pathlib.Path, str],
+    ) -> "ExternallyManagedEnvironment":
+        parser = configparser.ConfigParser(interpolation=None)
+        try:
+            parser.read(config, encoding="utf-8")
+            section = parser["externally-managed"]
+            for key in cls._iter_externally_managed_error_keys():
+                with contextlib.suppress(KeyError):
+                    return cls(section[key])
+        except KeyError:
+            pass
+        except (OSError, UnicodeDecodeError, configparser.ParsingError):
+            from pip._internal.utils._log import VERBOSE
+
+            exc_info = logger.isEnabledFor(VERBOSE)
+            logger.warning("Failed to read %s", config, exc_info=exc_info)
+        return cls(None)
diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 939ce339da6f6dd46dc49dfe7dc6f01388fc675d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 254
zcmYe~<>g{vU|^UdaWGYmfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}WzJ@Zmh
zD-<&GN>YmwlS?x5^AwWvQ&PG7G#PKP$H%ASC&$OHWGG@{V1N+68l0_SLW@(2iepl9
zQZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u
z5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-cvlG)(i(?8h3-sf`4$4c+(a!|APd`3B
dGcU6wK3=b&@)n0pZhlH>PO2TqPoF`a1OUECN7DcR

diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/collector.cpython-39.pyc
deleted file mode 100644
index 27d81be3d6ba5610338b7779be4547135d610ef2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/package_finder.cpython-39.pyc
deleted file mode 100644
index 5dfc01e38d37202e7a989098e24e25fbc388311d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 26637
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
Ikds3i0Kkl>UH||9

diff --git a/env/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/index/__pycache__/sources.cpython-39.pyc
deleted file mode 100644
index 95716c84af0063ff8579f014fe617974883333f9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7219
zcmYe~<>g{vU|^UdaWHkRBm=`^5C<7^GB7YWFfcF_8!$33q%fo~<}gG-XvQc;FrO)k
z2~0CbF{d!3Fy*l1vPQAyvPH4wvPZG!azt@3g48qTaOQGFae>(^Io!ECQ9NKaYYuNN
zUld<1e-uBM&z2*QD;Oon$dJmgKqyssA!C$CDqAX-Btw*FDqAX#Btw)~Dr+iFIwM3h
zjY*OrN*pR80p>}%Go-MmaI`R_a5OVTNu^4sN~CbkVM^gj;cj7xl5uB9;Ys0bVMyUk
zm1<^=l67ZD;Y;CfVMyTz^X1$bQUp>2TNqLV!F+jlh7_R`;TDDzVK84IRXSBXRWel~
zRU(xml|5Bjk|C8nRZ5ZpWOs_l9JUnE6tNbTD8&@UU<OU`m!Pop(`32D;hdP0lbDo~
zdW*xeB((^_@-HaK%+E{Axy2e%T9A{f$#_fDGq1P=q!J|IoS2uAnUYunl3?-4%*)nf
zy2V|PSdtN6k{@4Mlyi%_v?vF}28n4h-eSuv1_>vF>_o;ausF11U|>jP0L5DrQz~;R
zODd}*Lki;@#uTO$<`$M_#wfN_b}*kMg|&qxiX)X1%wtPoZ()hzO5q4*(B!<u1#(Gn
zerZv1>Pp62Y(=RhrA2wkj7S!O*dXi-N;jb7Rl?BB(8LH15vD4gAh3>Ng_4X^h0?r~
z)S{fq%)E4koXosz9fiy^ka$t5da*)&UaFqoO2%8le)%Pyxdl0?xv6<2sVS~SMfpW5
z8E>%^r{<)sWGE71U|{%F?`#zlTAW%`9Fv-pl35hvpO@-Vlv$RlpsNt-=NaZ26zmz|
z7_8vw=i=|@8tmy96YT2i8XV#pq+k{k5a1J&Xrh~wpPpG<l9?TonpYO%lbIA#oLQ2p
zTacKXotU0l98-{4pdX)^SCU$kmzblUnU|7Up<fIRg<`#e%3CZT=Zk_o%mfMv<|=+f
zFzJEhNC+WIc*GYgq~(|9r6?p-DikCZ6@!8)F;5|}C^-Y<w;Ygr^U@VOLVSG`(lT>W
z_56zX7#J9e1V98RT)=@-B+S6TaErenF+DXt8J47qrQmL5s**x-E1EJAoUH>g1<A$5
z1*yrIY2dhpy0};&C9^0sxg@6&pG&zwUWo^VS+N|FBSk^RL(-idLWQ3u_brb2_`Jm2
z)cE*YT=DU_`6;D2AU02Yd|_!~4pfGtpeVl}wWy@B2$UO&*g+vA0uC29PzWPJya*JD
zx46KfARCK|#6W5hp$TSzg0zU6fq?;JMllBi0|N&m6Qc+V9}8Gilj#-**o~z{IYqn-
z3=9~-2yz8De}GIcVaQ^vVMt+2Vd`Z{VU}b_Vaa9+X3%8ya|7k-;*z4w<dPy#j;i7;
zNv$Z+&nU^w(PX;CnVXrLT2fh%T6~Kuy)?DBI3C2&WGs?Jbuq}Xw|L_-i{n8W<3SEn
zh6gNTks`=_phSy|LGA;W`yohWMhasTxYPiZ7ju|XAf*IbDtjtNDyJkv3fmk;aLEfQ
zNw`wE!F<jXt`?Rko>X2ik2{5@g(ZqF1>`&4TO#ppIf*4M;3Sb>R0)aOs^6ecSAb+K
z1xOmoOa*6wgalpPw9LE|U2xj4wE-1-x+VF#DVarf2?=^!TnY*b3LzPp#R@t3`Pq;H
zCOJQ^BsH%@As<|>C_vI*eo>{4LSkNu0;KRNwt{HYQb<TZOa2K7Rtg~Z6f1x-TWX3z
zex5>VVsZu|&naZ)fl4fd$$DUCfXo5~G*XTOndJz{y2Utj`DrrW5<%qA__U(@+<1_a
zZn1zo3rR}MNbv+>vobI+fRhp^x70A!FvK&IFfL#!Va{S%z*@t!kZ~bMj4g#Bm|-QO
zpC<b)Q6xtpS-}pnA}2HH7E3^4NyaUv{Nf@NP!8cJN=?iG$=za&2T_{LMS`FN21-L<
z6_8Q}o-aW8F*7f-BtG5%l*&LUiGh`ku}T(ObnC^(L(~@WfRZ67k;A+PVuLW)Zy-}Z
zJ}6QJSq-)eODR_b%8nKwTfwC;Q<WrEJ3;9OB}c-75ma>+gKEhdhAf5!j0+iD7-IEm
z8B3T-m}?lD8JihvnMzn{n3@@jRSLOk7#6UWuz`3B8C@At7(5sl849`Jj?`o?(gp<|
zduB;$QA%b}5vY{7#avuc1kQ0qY9Nn*%Au9e@B{}oGpNJ>dk;*2vM#tpvH^JtRF^U^
z@-gx-axgM6R;gh194NUUMKFdxK_LnDrwIcC1Cl>gu=%q{rI4$H739Y-G~cm-eOIIl
z@&(9eMS36>s4RgLuKFM@*biU=>=95|2aZiNkH};72srzIqN-SvzepTpoCJuF1P5w-
zd`f<DeEcmTM9J+|l%E@rn4Su8i4I6DsFFh~@Qb8D5}-o9NCw0Lxd|x&BOI&5z`&pm
z3U!bW2O|p?6C)EN(;prVCPoovKK3GzJSZGt$rVh40+*Cx6Vw1hE;cz+xxfV_q}b$6
z<pJ{`#U?Mb*c6EO$xlwqam&m}g%p{I&WsEUSPRGeBHhxW9J_=Bh5RA~kc#Nkijty4
z-B@t@1tbS8Md1perKo3`LZU)wkdH!Uu|jcaK|xMtYKo3RW{E;>X>o}{QmR6tLP7#4
zf~*n}K<e}qz&b$11F{x{l6-J!2x{u(gB!bGLo$mMlJoP*Qj1DbQxr<_p;o1378RH1
zK?-oP3g*N-M6ryw6b{KqRmjWF(?v9#z^?RL$y@|3)Ig;O_OcdKtbkK6sPKW5wKYsN
z4DpQcY`>BToU?DSf?F`Kyp1pxl$s#v4V)!F$uty{%0MXxTue%$M=!BOBpWn82Qz>R
z$(4*nW}pNPaw)_@u+?B&K^}|+*$VOx15=eKhMk~%hf;KaN@7qk2}<(Cpt7q3RCq9E
zfeJ$bknd|47BJT^WHBNNLy#!gDVi*hA`k2yP^AD4B5ci6a9NiKav8`s42(RCER0nO
z7_P%t#(^9P@)p>kpe&AXXc5$*S&X344B<Rxbmw6UGf+X1hUPM943~lO1UTl4SMs41
zT1AGS=r95ipkluW6!k@j5(*S2L>ErR3=9n3Ajg2>l!K9l8>Mh!Edt4d0sven!3a=8
z0bDqRVQJH)vVmK5EYMaRxJ{SJMn<bnFg_?XH@_qmQ9f1e02MvREjNON5<~&CFakH}
z2Bt*NWC525xA?#*t}HPJ)F00;0=F|DB?LI%LPHqD1|>ak2?0tk$R$J#a}7g06LO*h
z<)T~s;PzcS!e~$?(PTktVp)Sy3^;XwA{&yG!MPZefJ#A$0GwCY*cjOutE4bOpUmQ;
z2-J+inngiQsRvmL@+t#Ul^CX#giDVah6UjAV<BTPG*d2M!c}@O7lB$okkSkkW>{SX
zs?nQ4t^x-Jq~K7*bQw4v5iM+tA`Vn~fHF=os5uI19ifyIxB~?g+Z`b5!GXe9C4*@-
zqG-Tq&mfA1TfCqqOc*?&QCw13F)%RXfE)&jHh43Jk?A)N7q}tAS_D!7@-j3LLnu&E
z2A35?_W#If$cV;!f`(DhJAm6krA0K3h6<#+mzrFXUsQ?K>B}ruC@D%!1hpx0GP6NV
zlp=6J1ZtmHD<mW!Vja=xNk{;-L`o7f^FW=(^vq;%Lm(}`NTCGOk4&mmNGvEw%}W7|
zyd)%mTTObPPIN*7sNDi;)_{^aq_N>w1Zq(ygDOc#7&0(`*q{UfE)YPK3UYw}FA9oG
zK{?zUL}1C`lR=ROiVkq=Kn`n|(Ik)023ZVpJp)sf6n1Mtp2x^SAWwtRQ!yw{Ao4k^
zi-hKFP^du4G_c>n1sf<Y&xhO2Sfz^Hc4G1}IOIX02N`|zL$V5+%^)W)Lb6!_yUmEK
zTx5wFZ3s_*x{*B~qd-C&j4T`|RWx%ENM4ie7DrBgaw2H77hKU4feQOuT&WcWiFqmU
zDVasLgpw1JGg84#ig@T4Af(~}l~kZ~2J##y0|Nu7qyYQ&9|LHlzLqtGp_UCavIHtv
z7cv$pl`z*ZG&9z+)iBhu=Bd;$EMQ4tT*z2tRRdDT3YKHd<0)YSv5MS4qBU$O45bW3
zNhwUV>?Q0AIBM8y7#1=yGNdpEGt{tx<vL0@YZz;oO1Ns+YFJWOdYMvKdzouFYS?Nx
z(wKr7N*J;j7jW0GE@Uh^RKr}ftc0hAv4%B;t(U2mBTuA+w}uf(Cp$<KMJFFv=c^Ka
zJnGmNaHMcR+y!zk$W~2GzbaNx99dO`f%;0I;8jppEmjBhO)}H-@{3YatU$e)%wmPq
z%#w`MB85b7haj~AI;0Bj$mAC(<Rm6%7b_&f#-WlGijy-^b5r#+nf&}T8H*el7#K96
zod!_Mf!hU|OpvGq_2*%1P~lr;PslBKaL0fguaK7yau<BaN>5XuNE4LWKnCAp1G}{t
zGOEB;T#{H+Qe2){l2HUo3q_y~_AR!Y{PgtHqFe0ciA8ytdFkMi9^5;>#hO_R8j=9@
zVZjLzG<N{96Wnmr<SeoW*#qvhfV~B(3BaC(jQ4<=@VA(Ai_>qhLB{Ejaup~8-{MIs
z&CE%Ohe$31Wr7G$Qsrb}WC0IeurYEmvM_Qnaxk(maWFCcXJX+2u|OScMkYqCzig}=
zOrWMeILrLwU<J`!|JYbK7<s^IAZ!*8`yUHSkryZ$ly0$u{0s7@JjnInpaON^Z?TnB
z7J!67WmyrZbb<^CfSSX%<O(ti^x)(Adb#;2sX4`Z@T#H+)S9>@iB%D(@PmY=1gd;#
zNoG#5UTIMdBzC|ta!U|ZO<8g=B$7DOQ%iin@dW8ExPaUa9-{#DU5Y^6g<C91`T03T
zwjdeMm@{O613c6MjzCaj9}>5qG6ftOND%@mejrl-95%V&!ErlK(NPSltT-4UP=bkv
nk%v)$k%x(k2_z!K$j8jbFTf(8BA_UsARx`e1d0I=7WxSQdVW<V

diff --git a/env/Lib/site-packages/pip/_internal/index/collector.py b/env/Lib/site-packages/pip/_internal/index/collector.py
index 0721e368..b3e293ea 100644
--- a/env/Lib/site-packages/pip/_internal/index/collector.py
+++ b/env/Lib/site-packages/pip/_internal/index/collector.py
@@ -2,30 +2,32 @@
 The main purpose of this module is to expose LinkCollector.collect_sources().
 """
 
-import cgi
 import collections
+import email.message
 import functools
-import html
 import itertools
+import json
 import logging
 import os
-import re
 import urllib.parse
 import urllib.request
-import xml.etree.ElementTree
+from html.parser import HTMLParser
 from optparse import Values
 from typing import (
+    TYPE_CHECKING,
     Callable,
+    Dict,
     Iterable,
     List,
     MutableMapping,
     NamedTuple,
     Optional,
     Sequence,
+    Tuple,
     Union,
 )
 
-from pip._vendor import html5lib, requests
+from pip._vendor import requests
 from pip._vendor.requests import Response
 from pip._vendor.requests.exceptions import RetryError, SSLError
 
@@ -35,92 +37,111 @@ from pip._internal.models.search_scope import SearchScope
 from pip._internal.network.session import PipSession
 from pip._internal.network.utils import raise_for_status
 from pip._internal.utils.filetypes import is_archive_file
-from pip._internal.utils.misc import pairwise, redact_auth_from_url
+from pip._internal.utils.misc import redact_auth_from_url
 from pip._internal.vcs import vcs
 
 from .sources import CandidatesFromPage, LinkSource, build_source
 
+if TYPE_CHECKING:
+    from typing import Protocol
+else:
+    Protocol = object
+
 logger = logging.getLogger(__name__)
 
-HTMLElement = xml.etree.ElementTree.Element
 ResponseHeaders = MutableMapping[str, str]
 
 
-def _match_vcs_scheme(url):
-    # type: (str) -> Optional[str]
+def _match_vcs_scheme(url: str) -> Optional[str]:
     """Look for VCS schemes in the URL.
 
     Returns the matched VCS scheme, or None if there's no match.
     """
     for scheme in vcs.schemes:
-        if url.lower().startswith(scheme) and url[len(scheme)] in '+:':
+        if url.lower().startswith(scheme) and url[len(scheme)] in "+:":
             return scheme
     return None
 
 
-class _NotHTML(Exception):
-    def __init__(self, content_type, request_desc):
-        # type: (str, str) -> None
+class _NotAPIContent(Exception):
+    def __init__(self, content_type: str, request_desc: str) -> None:
         super().__init__(content_type, request_desc)
         self.content_type = content_type
         self.request_desc = request_desc
 
 
-def _ensure_html_header(response):
-    # type: (Response) -> None
-    """Check the Content-Type header to ensure the response contains HTML.
+def _ensure_api_header(response: Response) -> None:
+    """
+    Check the Content-Type header to ensure the response contains a Simple
+    API Response.
 
-    Raises `_NotHTML` if the content type is not text/html.
+    Raises `_NotAPIContent` if the content type is not a valid content-type.
     """
-    content_type = response.headers.get("Content-Type", "")
-    if not content_type.lower().startswith("text/html"):
-        raise _NotHTML(content_type, response.request.method)
+    content_type = response.headers.get("Content-Type", "Unknown")
+
+    content_type_l = content_type.lower()
+    if content_type_l.startswith(
+        (
+            "text/html",
+            "application/vnd.pypi.simple.v1+html",
+            "application/vnd.pypi.simple.v1+json",
+        )
+    ):
+        return
+
+    raise _NotAPIContent(content_type, response.request.method)
 
 
 class _NotHTTP(Exception):
     pass
 
 
-def _ensure_html_response(url, session):
-    # type: (str, PipSession) -> None
-    """Send a HEAD request to the URL, and ensure the response contains HTML.
+def _ensure_api_response(url: str, session: PipSession) -> None:
+    """
+    Send a HEAD request to the URL, and ensure the response contains a simple
+    API Response.
 
     Raises `_NotHTTP` if the URL is not available for a HEAD request, or
-    `_NotHTML` if the content type is not text/html.
+    `_NotAPIContent` if the content type is not a valid content type.
     """
     scheme, netloc, path, query, fragment = urllib.parse.urlsplit(url)
-    if scheme not in {'http', 'https'}:
+    if scheme not in {"http", "https"}:
         raise _NotHTTP()
 
     resp = session.head(url, allow_redirects=True)
     raise_for_status(resp)
 
-    _ensure_html_header(resp)
+    _ensure_api_header(resp)
 
 
-def _get_html_response(url, session):
-    # type: (str, PipSession) -> Response
-    """Access an HTML page with GET, and return the response.
+def _get_simple_response(url: str, session: PipSession) -> Response:
+    """Access an Simple API response with GET, and return the response.
 
     This consists of three parts:
 
     1. If the URL looks suspiciously like an archive, send a HEAD first to
-       check the Content-Type is HTML, to avoid downloading a large file.
-       Raise `_NotHTTP` if the content type cannot be determined, or
-       `_NotHTML` if it is not HTML.
+       check the Content-Type is HTML or Simple API, to avoid downloading a
+       large file. Raise `_NotHTTP` if the content type cannot be determined, or
+       `_NotAPIContent` if it is not HTML or a Simple API.
     2. Actually perform the request. Raise HTTP exceptions on network failures.
-    3. Check the Content-Type header to make sure we got HTML, and raise
-       `_NotHTML` otherwise.
+    3. Check the Content-Type header to make sure we got a Simple API response,
+       and raise `_NotAPIContent` otherwise.
     """
     if is_archive_file(Link(url).filename):
-        _ensure_html_response(url, session=session)
+        _ensure_api_response(url, session=session)
 
-    logger.debug('Getting page %s', redact_auth_from_url(url))
+    logger.debug("Getting page %s", redact_auth_from_url(url))
 
     resp = session.get(
         url,
         headers={
-            "Accept": "text/html",
+            "Accept": ", ".join(
+                [
+                    "application/vnd.pypi.simple.v1+json",
+                    "application/vnd.pypi.simple.v1+html; q=0.1",
+                    "text/html; q=0.01",
+                ]
+            ),
             # We don't want to blindly returned cached data for
             # /simple/, because authors generally expecting that
             # twine upload && pip install will function, but if
@@ -142,175 +163,61 @@ def _get_html_response(url, session):
     # The check for archives above only works if the url ends with
     # something that looks like an archive. However that is not a
     # requirement of an url. Unless we issue a HEAD request on every
-    # url we cannot know ahead of time for sure if something is HTML
-    # or not. However we can check after we've downloaded it.
-    _ensure_html_header(resp)
+    # url we cannot know ahead of time for sure if something is a
+    # Simple API response or not. However we can check after we've
+    # downloaded it.
+    _ensure_api_header(resp)
+
+    logger.debug(
+        "Fetched page %s as %s",
+        redact_auth_from_url(url),
+        resp.headers.get("Content-Type", "Unknown"),
+    )
 
     return resp
 
 
-def _get_encoding_from_headers(headers):
-    # type: (ResponseHeaders) -> Optional[str]
-    """Determine if we have any encoding information in our headers.
-    """
+def _get_encoding_from_headers(headers: ResponseHeaders) -> Optional[str]:
+    """Determine if we have any encoding information in our headers."""
     if headers and "Content-Type" in headers:
-        content_type, params = cgi.parse_header(headers["Content-Type"])
-        if "charset" in params:
-            return params['charset']
+        m = email.message.Message()
+        m["content-type"] = headers["Content-Type"]
+        charset = m.get_param("charset")
+        if charset:
+            return str(charset)
     return None
 
 
-def _determine_base_url(document, page_url):
-    # type: (HTMLElement, str) -> str
-    """Determine the HTML document's base URL.
-
-    This looks for a ``<base>`` tag in the HTML document. If present, its href
-    attribute denotes the base URL of anchor tags in the document. If there is
-    no such tag (or if it does not have a valid href attribute), the HTML
-    file's URL is used as the base URL.
-
-    :param document: An HTML document representation. The current
-        implementation expects the result of ``html5lib.parse()``.
-    :param page_url: The URL of the HTML document.
-    """
-    for base in document.findall(".//base"):
-        href = base.get("href")
-        if href is not None:
-            return href
-    return page_url
-
-
-def _clean_url_path_part(part):
-    # type: (str) -> str
-    """
-    Clean a "part" of a URL path (i.e. after splitting on "@" characters).
-    """
-    # We unquote prior to quoting to make sure nothing is double quoted.
-    return urllib.parse.quote(urllib.parse.unquote(part))
-
-
-def _clean_file_url_path(part):
-    # type: (str) -> str
-    """
-    Clean the first part of a URL path that corresponds to a local
-    filesystem path (i.e. the first part after splitting on "@" characters).
-    """
-    # We unquote prior to quoting to make sure nothing is double quoted.
-    # Also, on Windows the path part might contain a drive letter which
-    # should not be quoted. On Linux where drive letters do not
-    # exist, the colon should be quoted. We rely on urllib.request
-    # to do the right thing here.
-    return urllib.request.pathname2url(urllib.request.url2pathname(part))
-
-
-# percent-encoded:                   /
-_reserved_chars_re = re.compile('(@|%2F)', re.IGNORECASE)
-
-
-def _clean_url_path(path, is_local_path):
-    # type: (str, bool) -> str
-    """
-    Clean the path portion of a URL.
-    """
-    if is_local_path:
-        clean_func = _clean_file_url_path
-    else:
-        clean_func = _clean_url_path_part
-
-    # Split on the reserved characters prior to cleaning so that
-    # revision strings in VCS URLs are properly preserved.
-    parts = _reserved_chars_re.split(path)
-
-    cleaned_parts = []
-    for to_clean, reserved in pairwise(itertools.chain(parts, [''])):
-        cleaned_parts.append(clean_func(to_clean))
-        # Normalize %xx escapes (e.g. %2f -> %2F)
-        cleaned_parts.append(reserved.upper())
-
-    return ''.join(cleaned_parts)
-
-
-def _clean_link(url):
-    # type: (str) -> str
-    """
-    Make sure a link is fully quoted.
-    For example, if ' ' occurs in the URL, it will be replaced with "%20",
-    and without double-quoting other characters.
-    """
-    # Split the URL into parts according to the general structure
-    # `scheme://netloc/path;parameters?query#fragment`.
-    result = urllib.parse.urlparse(url)
-    # If the netloc is empty, then the URL refers to a local filesystem path.
-    is_local_path = not result.netloc
-    path = _clean_url_path(result.path, is_local_path=is_local_path)
-    return urllib.parse.urlunparse(result._replace(path=path))
-
-
-def _create_link_from_element(
-    anchor,    # type: HTMLElement
-    page_url,  # type: str
-    base_url,  # type: str
-):
-    # type: (...) -> Optional[Link]
-    """
-    Convert an anchor element in a simple repository page to a Link.
-    """
-    href = anchor.get("href")
-    if not href:
-        return None
-
-    url = _clean_link(urllib.parse.urljoin(base_url, href))
-    pyrequire = anchor.get('data-requires-python')
-    pyrequire = html.unescape(pyrequire) if pyrequire else None
-
-    yanked_reason = anchor.get('data-yanked')
-    if yanked_reason:
-        yanked_reason = html.unescape(yanked_reason)
-
-    link = Link(
-        url,
-        comes_from=page_url,
-        requires_python=pyrequire,
-        yanked_reason=yanked_reason,
-    )
-
-    return link
-
-
 class CacheablePageContent:
-    def __init__(self, page):
-        # type: (HTMLPage) -> None
+    def __init__(self, page: "IndexContent") -> None:
         assert page.cache_link_parsing
         self.page = page
 
-    def __eq__(self, other):
-        # type: (object) -> bool
-        return (isinstance(other, type(self)) and
-                self.page.url == other.page.url)
+    def __eq__(self, other: object) -> bool:
+        return isinstance(other, type(self)) and self.page.url == other.page.url
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(self.page.url)
 
 
-def with_cached_html_pages(
-    fn,    # type: Callable[[HTMLPage], Iterable[Link]]
-):
-    # type: (...) -> Callable[[HTMLPage], List[Link]]
+class ParseLinks(Protocol):
+    def __call__(self, page: "IndexContent") -> Iterable[Link]:
+        ...
+
+
+def with_cached_index_content(fn: ParseLinks) -> ParseLinks:
     """
-    Given a function that parses an Iterable[Link] from an HTMLPage, cache the
-    function's result (keyed by CacheablePageContent), unless the HTMLPage
+    Given a function that parses an Iterable[Link] from an IndexContent, cache the
+    function's result (keyed by CacheablePageContent), unless the IndexContent
     `page` has `page.cache_link_parsing == False`.
     """
 
     @functools.lru_cache(maxsize=None)
-    def wrapper(cacheable_page):
-        # type: (CacheablePageContent) -> List[Link]
+    def wrapper(cacheable_page: CacheablePageContent) -> List[Link]:
         return list(fn(cacheable_page.page))
 
     @functools.wraps(fn)
-    def wrapper_wrapper(page):
-        # type: (HTMLPage) -> List[Link]
+    def wrapper_wrapper(page: "IndexContent") -> List[Link]:
         if page.cache_link_parsing:
             return wrapper(CacheablePageContent(page))
         return list(fn(page))
@@ -318,42 +225,46 @@ def with_cached_html_pages(
     return wrapper_wrapper
 
 
-@with_cached_html_pages
-def parse_links(page):
-    # type: (HTMLPage) -> Iterable[Link]
+@with_cached_index_content
+def parse_links(page: "IndexContent") -> Iterable[Link]:
     """
-    Parse an HTML document, and yield its anchor elements as Link objects.
+    Parse a Simple API's Index Content, and yield its anchor elements as Link objects.
     """
-    document = html5lib.parse(
-        page.content,
-        transport_encoding=page.encoding,
-        namespaceHTMLElements=False,
-    )
+
+    content_type_l = page.content_type.lower()
+    if content_type_l.startswith("application/vnd.pypi.simple.v1+json"):
+        data = json.loads(page.content)
+        for file in data.get("files", []):
+            link = Link.from_json(file, page.url)
+            if link is None:
+                continue
+            yield link
+        return
+
+    parser = HTMLLinkParser(page.url)
+    encoding = page.encoding or "utf-8"
+    parser.feed(page.content.decode(encoding))
 
     url = page.url
-    base_url = _determine_base_url(document, url)
-    for anchor in document.findall(".//a"):
-        link = _create_link_from_element(
-            anchor,
-            page_url=url,
-            base_url=base_url,
-        )
+    base_url = parser.base_url or url
+    for anchor in parser.anchors:
+        link = Link.from_element(anchor, page_url=url, base_url=base_url)
         if link is None:
             continue
         yield link
 
 
-class HTMLPage:
-    """Represents one page, along with its URL"""
+class IndexContent:
+    """Represents one response (or page), along with its URL"""
 
     def __init__(
         self,
-        content,                  # type: bytes
-        encoding,                 # type: Optional[str]
-        url,                      # type: str
-        cache_link_parsing=True,  # type: bool
-    ):
-        # type: (...) -> None
+        content: bytes,
+        content_type: str,
+        encoding: Optional[str],
+        url: str,
+        cache_link_parsing: bool = True,
+    ) -> None:
         """
         :param encoding: the encoding to decode the given content.
         :param url: the URL from which the HTML was downloaded.
@@ -362,90 +273,124 @@ class HTMLPage:
                                    have this set to False, for example.
         """
         self.content = content
+        self.content_type = content_type
         self.encoding = encoding
         self.url = url
         self.cache_link_parsing = cache_link_parsing
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return redact_auth_from_url(self.url)
 
 
-def _handle_get_page_fail(
-    link,  # type: Link
-    reason,  # type: Union[str, Exception]
-    meth=None  # type: Optional[Callable[..., None]]
-):
-    # type: (...) -> None
+class HTMLLinkParser(HTMLParser):
+    """
+    HTMLParser that keeps the first base HREF and a list of all anchor
+    elements' attributes.
+    """
+
+    def __init__(self, url: str) -> None:
+        super().__init__(convert_charrefs=True)
+
+        self.url: str = url
+        self.base_url: Optional[str] = None
+        self.anchors: List[Dict[str, Optional[str]]] = []
+
+    def handle_starttag(self, tag: str, attrs: List[Tuple[str, Optional[str]]]) -> None:
+        if tag == "base" and self.base_url is None:
+            href = self.get_href(attrs)
+            if href is not None:
+                self.base_url = href
+        elif tag == "a":
+            self.anchors.append(dict(attrs))
+
+    def get_href(self, attrs: List[Tuple[str, Optional[str]]]) -> Optional[str]:
+        for name, value in attrs:
+            if name == "href":
+                return value
+        return None
+
+
+def _handle_get_simple_fail(
+    link: Link,
+    reason: Union[str, Exception],
+    meth: Optional[Callable[..., None]] = None,
+) -> None:
     if meth is None:
         meth = logger.debug
     meth("Could not fetch URL %s: %s - skipping", link, reason)
 
 
-def _make_html_page(response, cache_link_parsing=True):
-    # type: (Response, bool) -> HTMLPage
+def _make_index_content(
+    response: Response, cache_link_parsing: bool = True
+) -> IndexContent:
     encoding = _get_encoding_from_headers(response.headers)
-    return HTMLPage(
+    return IndexContent(
         response.content,
+        response.headers["Content-Type"],
         encoding=encoding,
         url=response.url,
-        cache_link_parsing=cache_link_parsing)
-
+        cache_link_parsing=cache_link_parsing,
+    )
 
-def _get_html_page(link, session=None):
-    # type: (Link, Optional[PipSession]) -> Optional[HTMLPage]
-    if session is None:
-        raise TypeError(
-            "_get_html_page() missing 1 required keyword argument: 'session'"
-        )
 
-    url = link.url.split('#', 1)[0]
+def _get_index_content(link: Link, *, session: PipSession) -> Optional["IndexContent"]:
+    url = link.url.split("#", 1)[0]
 
     # Check for VCS schemes that do not support lookup as web pages.
     vcs_scheme = _match_vcs_scheme(url)
     if vcs_scheme:
-        logger.warning('Cannot look at %s URL %s because it does not support '
-                       'lookup as web pages.', vcs_scheme, link)
+        logger.warning(
+            "Cannot look at %s URL %s because it does not support lookup as web pages.",
+            vcs_scheme,
+            link,
+        )
         return None
 
     # Tack index.html onto file:// URLs that point to directories
     scheme, _, path, _, _, _ = urllib.parse.urlparse(url)
-    if (scheme == 'file' and os.path.isdir(urllib.request.url2pathname(path))):
+    if scheme == "file" and os.path.isdir(urllib.request.url2pathname(path)):
         # add trailing slash if not present so urljoin doesn't trim
         # final segment
-        if not url.endswith('/'):
-            url += '/'
-        url = urllib.parse.urljoin(url, 'index.html')
-        logger.debug(' file: URL is directory, getting %s', url)
+        if not url.endswith("/"):
+            url += "/"
+        # TODO: In the future, it would be nice if pip supported PEP 691
+        #       style responses in the file:// URLs, however there's no
+        #       standard file extension for application/vnd.pypi.simple.v1+json
+        #       so we'll need to come up with something on our own.
+        url = urllib.parse.urljoin(url, "index.html")
+        logger.debug(" file: URL is directory, getting %s", url)
 
     try:
-        resp = _get_html_response(url, session=session)
+        resp = _get_simple_response(url, session=session)
     except _NotHTTP:
         logger.warning(
-            'Skipping page %s because it looks like an archive, and cannot '
-            'be checked by a HTTP HEAD request.', link,
+            "Skipping page %s because it looks like an archive, and cannot "
+            "be checked by a HTTP HEAD request.",
+            link,
         )
-    except _NotHTML as exc:
+    except _NotAPIContent as exc:
         logger.warning(
-            'Skipping page %s because the %s request got Content-Type: %s.'
-            'The only supported Content-Type is text/html',
-            link, exc.request_desc, exc.content_type,
+            "Skipping page %s because the %s request got Content-Type: %s. "
+            "The only supported Content-Types are application/vnd.pypi.simple.v1+json, "
+            "application/vnd.pypi.simple.v1+html, and text/html",
+            link,
+            exc.request_desc,
+            exc.content_type,
         )
     except NetworkConnectionError as exc:
-        _handle_get_page_fail(link, exc)
+        _handle_get_simple_fail(link, exc)
     except RetryError as exc:
-        _handle_get_page_fail(link, exc)
+        _handle_get_simple_fail(link, exc)
     except SSLError as exc:
         reason = "There was a problem confirming the ssl certificate: "
         reason += str(exc)
-        _handle_get_page_fail(link, reason, meth=logger.info)
+        _handle_get_simple_fail(link, reason, meth=logger.info)
     except requests.ConnectionError as exc:
-        _handle_get_page_fail(link, f"connection error: {exc}")
+        _handle_get_simple_fail(link, f"connection error: {exc}")
     except requests.Timeout:
-        _handle_get_page_fail(link, "timed out")
+        _handle_get_simple_fail(link, "timed out")
     else:
-        return _make_html_page(resp,
-                               cache_link_parsing=link.cache_link_parsing)
+        return _make_index_content(resp, cache_link_parsing=link.cache_link_parsing)
     return None
 
 
@@ -465,16 +410,19 @@ class LinkCollector:
 
     def __init__(
         self,
-        session,       # type: PipSession
-        search_scope,  # type: SearchScope
-    ):
-        # type: (...) -> None
+        session: PipSession,
+        search_scope: SearchScope,
+    ) -> None:
         self.search_scope = search_scope
         self.session = session
 
     @classmethod
-    def create(cls, session, options, suppress_no_index=False):
-        # type: (PipSession, Values, bool) -> LinkCollector
+    def create(
+        cls,
+        session: PipSession,
+        options: Values,
+        suppress_no_index: bool = False,
+    ) -> "LinkCollector":
         """
         :param session: The Session to use to make requests.
         :param suppress_no_index: Whether to ignore the --no-index option
@@ -483,8 +431,8 @@ class LinkCollector:
         index_urls = [options.index_url] + options.extra_index_urls
         if options.no_index and not suppress_no_index:
             logger.debug(
-                'Ignoring indexes: %s',
-                ','.join(redact_auth_from_url(url) for url in index_urls),
+                "Ignoring indexes: %s",
+                ",".join(redact_auth_from_url(url) for url in index_urls),
             )
             index_urls = []
 
@@ -492,24 +440,25 @@ class LinkCollector:
         find_links = options.find_links or []
 
         search_scope = SearchScope.create(
-            find_links=find_links, index_urls=index_urls,
+            find_links=find_links,
+            index_urls=index_urls,
+            no_index=options.no_index,
         )
         link_collector = LinkCollector(
-            session=session, search_scope=search_scope,
+            session=session,
+            search_scope=search_scope,
         )
         return link_collector
 
     @property
-    def find_links(self):
-        # type: () -> List[str]
+    def find_links(self) -> List[str]:
         return self.search_scope.find_links
 
-    def fetch_page(self, location):
-        # type: (Link) -> Optional[HTMLPage]
+    def fetch_response(self, location: Link) -> Optional[IndexContent]:
         """
         Fetch an HTML page containing package links.
         """
-        return _get_html_page(location, session=self.session)
+        return _get_index_content(location, session=self.session)
 
     def collect_sources(
         self,
diff --git a/env/Lib/site-packages/pip/_internal/index/package_finder.py b/env/Lib/site-packages/pip/_internal/index/package_finder.py
index 7f2e04e7..b6f8d57e 100644
--- a/env/Lib/site-packages/pip/_internal/index/package_finder.py
+++ b/env/Lib/site-packages/pip/_internal/index/package_finder.py
@@ -1,13 +1,11 @@
 """Routines related to PyPI, indexes"""
 
-# The following comment should be removed at some point in the future.
-# mypy: strict-optional=False
-
+import enum
 import functools
 import itertools
 import logging
 import re
-from typing import FrozenSet, Iterable, List, Optional, Set, Tuple, Union
+from typing import TYPE_CHECKING, FrozenSet, Iterable, List, Optional, Set, Tuple, Union
 
 from pip._vendor.packaging import specifiers
 from pip._vendor.packaging.tags import Tag
@@ -30,31 +28,31 @@ from pip._internal.models.selection_prefs import SelectionPreferences
 from pip._internal.models.target_python import TargetPython
 from pip._internal.models.wheel import Wheel
 from pip._internal.req import InstallRequirement
+from pip._internal.utils._log import getLogger
 from pip._internal.utils.filetypes import WHEEL_EXTENSION
 from pip._internal.utils.hashes import Hashes
 from pip._internal.utils.logging import indent_log
 from pip._internal.utils.misc import build_netloc
 from pip._internal.utils.packaging import check_requires_python
 from pip._internal.utils.unpacking import SUPPORTED_EXTENSIONS
-from pip._internal.utils.urls import url_to_path
 
-__all__ = ['FormatControl', 'BestCandidateResult', 'PackageFinder']
+if TYPE_CHECKING:
+    from pip._vendor.typing_extensions import TypeGuard
+
+__all__ = ["FormatControl", "BestCandidateResult", "PackageFinder"]
 
 
-logger = logging.getLogger(__name__)
+logger = getLogger(__name__)
 
 BuildTag = Union[Tuple[()], Tuple[int, str]]
-CandidateSortingKey = (
-    Tuple[int, int, int, _BaseVersion, Optional[int], BuildTag]
-)
+CandidateSortingKey = Tuple[int, int, int, _BaseVersion, Optional[int], BuildTag]
 
 
 def _check_link_requires_python(
-    link,  # type: Link
-    version_info,  # type: Tuple[int, int, int]
-    ignore_requires_python=False,  # type: bool
-):
-    # type: (...) -> bool
+    link: Link,
+    version_info: Tuple[int, int, int],
+    ignore_requires_python: bool = False,
+) -> bool:
     """
     Return whether the given Python version is compatible with a link's
     "Requires-Python" value.
@@ -66,39 +64,54 @@ def _check_link_requires_python(
     """
     try:
         is_compatible = check_requires_python(
-            link.requires_python, version_info=version_info,
+            link.requires_python,
+            version_info=version_info,
         )
     except specifiers.InvalidSpecifier:
         logger.debug(
             "Ignoring invalid Requires-Python (%r) for link: %s",
-            link.requires_python, link,
+            link.requires_python,
+            link,
         )
     else:
         if not is_compatible:
-            version = '.'.join(map(str, version_info))
+            version = ".".join(map(str, version_info))
             if not ignore_requires_python:
-                logger.debug(
-                    'Link requires a different Python (%s not in: %r): %s',
-                    version, link.requires_python, link,
+                logger.verbose(
+                    "Link requires a different Python (%s not in: %r): %s",
+                    version,
+                    link.requires_python,
+                    link,
                 )
                 return False
 
             logger.debug(
-                'Ignoring failed Requires-Python check (%s not in: %r) '
-                'for link: %s',
-                version, link.requires_python, link,
+                "Ignoring failed Requires-Python check (%s not in: %r) for link: %s",
+                version,
+                link.requires_python,
+                link,
             )
 
     return True
 
 
+class LinkType(enum.Enum):
+    candidate = enum.auto()
+    different_project = enum.auto()
+    yanked = enum.auto()
+    format_unsupported = enum.auto()
+    format_invalid = enum.auto()
+    platform_mismatch = enum.auto()
+    requires_python_mismatch = enum.auto()
+
+
 class LinkEvaluator:
 
     """
     Responsible for evaluating links for a particular project.
     """
 
-    _py_version_re = re.compile(r'-py([123]\.?[0-9]?)$')
+    _py_version_re = re.compile(r"-py([123]\.?[0-9]?)$")
 
     # Don't include an allow_yanked default value to make sure each call
     # site considers whether yanked releases are allowed. This also causes
@@ -106,14 +119,13 @@ class LinkEvaluator:
     # people when reading the code.
     def __init__(
         self,
-        project_name,    # type: str
-        canonical_name,  # type: str
-        formats,         # type: FrozenSet[str]
-        target_python,   # type: TargetPython
-        allow_yanked,    # type: bool
-        ignore_requires_python=None,  # type: Optional[bool]
-    ):
-        # type: (...) -> None
+        project_name: str,
+        canonical_name: str,
+        formats: FrozenSet[str],
+        target_python: TargetPython,
+        allow_yanked: bool,
+        ignore_requires_python: Optional[bool] = None,
+    ) -> None:
         """
         :param project_name: The user supplied package name.
         :param canonical_name: The canonical package name.
@@ -142,20 +154,20 @@ class LinkEvaluator:
 
         self.project_name = project_name
 
-    def evaluate_link(self, link):
-        # type: (Link) -> Tuple[bool, Optional[str]]
+    def evaluate_link(self, link: Link) -> Tuple[LinkType, str]:
         """
         Determine whether a link is a candidate for installation.
 
-        :return: A tuple (is_candidate, result), where `result` is (1) a
-            version string if `is_candidate` is True, and (2) if
-            `is_candidate` is False, an optional string to log the reason
-            the link fails to qualify.
+        :return: A tuple (result, detail), where *result* is an enum
+            representing whether the evaluation found a candidate, or the reason
+            why one is not found. If a candidate is found, *detail* will be the
+            candidate's version string; if one is not found, it contains the
+            reason the link fails to qualify.
         """
         version = None
         if link.is_yanked and not self._allow_yanked:
-            reason = link.yanked_reason or '<none given>'
-            return (False, f'yanked for reason: {reason}')
+            reason = link.yanked_reason or "<none given>"
+            return (LinkType.yanked, f"yanked for reason: {reason}")
 
         if link.egg_fragment:
             egg_info = link.egg_fragment
@@ -163,80 +175,85 @@ class LinkEvaluator:
         else:
             egg_info, ext = link.splitext()
             if not ext:
-                return (False, 'not a file')
+                return (LinkType.format_unsupported, "not a file")
             if ext not in SUPPORTED_EXTENSIONS:
-                return (False, f'unsupported archive format: {ext}')
+                return (
+                    LinkType.format_unsupported,
+                    f"unsupported archive format: {ext}",
+                )
             if "binary" not in self._formats and ext == WHEEL_EXTENSION:
-                reason = 'No binaries permitted for {}'.format(
-                    self.project_name)
-                return (False, reason)
-            if "macosx10" in link.path and ext == '.zip':
-                return (False, 'macosx10 one')
+                reason = f"No binaries permitted for {self.project_name}"
+                return (LinkType.format_unsupported, reason)
+            if "macosx10" in link.path and ext == ".zip":
+                return (LinkType.format_unsupported, "macosx10 one")
             if ext == WHEEL_EXTENSION:
                 try:
                     wheel = Wheel(link.filename)
                 except InvalidWheelFilename:
-                    return (False, 'invalid wheel filename')
+                    return (
+                        LinkType.format_invalid,
+                        "invalid wheel filename",
+                    )
                 if canonicalize_name(wheel.name) != self._canonical_name:
-                    reason = 'wrong project name (not {})'.format(
-                        self.project_name)
-                    return (False, reason)
+                    reason = f"wrong project name (not {self.project_name})"
+                    return (LinkType.different_project, reason)
 
                 supported_tags = self._target_python.get_tags()
                 if not wheel.supported(supported_tags):
                     # Include the wheel's tags in the reason string to
                     # simplify troubleshooting compatibility issues.
-                    file_tags = wheel.get_formatted_file_tags()
+                    file_tags = ", ".join(wheel.get_formatted_file_tags())
                     reason = (
-                        "none of the wheel's tags ({}) are compatible "
-                        "(run pip debug --verbose to show compatible tags)".format(
-                            ', '.join(file_tags)
-                        )
+                        f"none of the wheel's tags ({file_tags}) are compatible "
+                        f"(run pip debug --verbose to show compatible tags)"
                     )
-                    return (False, reason)
+                    return (LinkType.platform_mismatch, reason)
 
                 version = wheel.version
 
         # This should be up by the self.ok_binary check, but see issue 2700.
         if "source" not in self._formats and ext != WHEEL_EXTENSION:
-            reason = f'No sources permitted for {self.project_name}'
-            return (False, reason)
+            reason = f"No sources permitted for {self.project_name}"
+            return (LinkType.format_unsupported, reason)
 
         if not version:
             version = _extract_version_from_fragment(
-                egg_info, self._canonical_name,
+                egg_info,
+                self._canonical_name,
             )
         if not version:
-            reason = f'Missing project version for {self.project_name}'
-            return (False, reason)
+            reason = f"Missing project version for {self.project_name}"
+            return (LinkType.format_invalid, reason)
 
         match = self._py_version_re.search(version)
         if match:
-            version = version[:match.start()]
+            version = version[: match.start()]
             py_version = match.group(1)
             if py_version != self._target_python.py_version:
-                return (False, 'Python version is incorrect')
+                return (
+                    LinkType.platform_mismatch,
+                    "Python version is incorrect",
+                )
 
         supports_python = _check_link_requires_python(
-            link, version_info=self._target_python.py_version_info,
+            link,
+            version_info=self._target_python.py_version_info,
             ignore_requires_python=self._ignore_requires_python,
         )
         if not supports_python:
-            # Return None for the reason text to suppress calling
-            # _log_skipped_link().
-            return (False, None)
+            reason = f"{version} Requires-Python {link.requires_python}"
+            return (LinkType.requires_python_mismatch, reason)
 
-        logger.debug('Found link %s, version: %s', link, version)
+        logger.debug("Found link %s, version: %s", link, version)
 
-        return (True, version)
+        return (LinkType.candidate, version)
 
 
 def filter_unallowed_hashes(
-    candidates,    # type: List[InstallationCandidate]
-    hashes,        # type: Hashes
-    project_name,  # type: str
-):
-    # type: (...) -> List[InstallationCandidate]
+    candidates: List[InstallationCandidate],
+    hashes: Optional[Hashes],
+    project_name: str,
+) -> List[InstallationCandidate]:
     """
     Filter out candidates whose hashes aren't allowed, and return a new
     list of candidates.
@@ -254,8 +271,8 @@ def filter_unallowed_hashes(
     """
     if not hashes:
         logger.debug(
-            'Given no hashes to check %s links for project %r: '
-            'discarding no candidates',
+            "Given no hashes to check %s links for project %r: "
+            "discarding no candidates",
             len(candidates),
             project_name,
         )
@@ -285,22 +302,22 @@ def filter_unallowed_hashes(
         filtered = list(candidates)
 
     if len(filtered) == len(candidates):
-        discard_message = 'discarding no candidates'
+        discard_message = "discarding no candidates"
     else:
-        discard_message = 'discarding {} non-matches:\n  {}'.format(
+        discard_message = "discarding {} non-matches:\n  {}".format(
             len(non_matches),
-            '\n  '.join(str(candidate.link) for candidate in non_matches)
+            "\n  ".join(str(candidate.link) for candidate in non_matches),
         )
 
     logger.debug(
-        'Checked %s links for project %r against %s hashes '
-        '(%s matches, %s no digest): %s',
+        "Checked %s links for project %r against %s hashes "
+        "(%s matches, %s no digest): %s",
         len(candidates),
         project_name,
         hashes.digest_count,
         match_count,
         len(matches_or_no_digest) - match_count,
-        discard_message
+        discard_message,
     )
 
     return filtered
@@ -315,10 +332,9 @@ class CandidatePreferences:
 
     def __init__(
         self,
-        prefer_binary=False,  # type: bool
-        allow_all_prereleases=False,  # type: bool
-    ):
-        # type: (...) -> None
+        prefer_binary: bool = False,
+        allow_all_prereleases: bool = False,
+    ) -> None:
         """
         :param allow_all_prereleases: Whether to allow all pre-releases.
         """
@@ -335,11 +351,10 @@ class BestCandidateResult:
 
     def __init__(
         self,
-        candidates,             # type: List[InstallationCandidate]
-        applicable_candidates,  # type: List[InstallationCandidate]
-        best_candidate,         # type: Optional[InstallationCandidate]
-    ):
-        # type: (...) -> None
+        candidates: List[InstallationCandidate],
+        applicable_candidates: List[InstallationCandidate],
+        best_candidate: Optional[InstallationCandidate],
+    ) -> None:
         """
         :param candidates: A sequence of all available candidates found.
         :param applicable_candidates: The applicable candidates.
@@ -358,16 +373,12 @@ class BestCandidateResult:
 
         self.best_candidate = best_candidate
 
-    def iter_all(self):
-        # type: () -> Iterable[InstallationCandidate]
-        """Iterate through all candidates.
-        """
+    def iter_all(self) -> Iterable[InstallationCandidate]:
+        """Iterate through all candidates."""
         return iter(self._candidates)
 
-    def iter_applicable(self):
-        # type: () -> Iterable[InstallationCandidate]
-        """Iterate through the applicable candidates.
-        """
+    def iter_applicable(self) -> Iterable[InstallationCandidate]:
+        """Iterate through the applicable candidates."""
         return iter(self._applicable_candidates)
 
 
@@ -381,14 +392,13 @@ class CandidateEvaluator:
     @classmethod
     def create(
         cls,
-        project_name,         # type: str
-        target_python=None,   # type: Optional[TargetPython]
-        prefer_binary=False,  # type: bool
-        allow_all_prereleases=False,  # type: bool
-        specifier=None,       # type: Optional[specifiers.BaseSpecifier]
-        hashes=None,          # type: Optional[Hashes]
-    ):
-        # type: (...) -> CandidateEvaluator
+        project_name: str,
+        target_python: Optional[TargetPython] = None,
+        prefer_binary: bool = False,
+        allow_all_prereleases: bool = False,
+        specifier: Optional[specifiers.BaseSpecifier] = None,
+        hashes: Optional[Hashes] = None,
+    ) -> "CandidateEvaluator":
         """Create a CandidateEvaluator object.
 
         :param target_python: The target Python interpreter to use when
@@ -417,14 +427,13 @@ class CandidateEvaluator:
 
     def __init__(
         self,
-        project_name,         # type: str
-        supported_tags,       # type: List[Tag]
-        specifier,            # type: specifiers.BaseSpecifier
-        prefer_binary=False,  # type: bool
-        allow_all_prereleases=False,  # type: bool
-        hashes=None,                  # type: Optional[Hashes]
-    ):
-        # type: (...) -> None
+        project_name: str,
+        supported_tags: List[Tag],
+        specifier: specifiers.BaseSpecifier,
+        prefer_binary: bool = False,
+        allow_all_prereleases: bool = False,
+        hashes: Optional[Hashes] = None,
+    ) -> None:
         """
         :param supported_tags: The PEP 425 tags supported by the target
             Python in order of preference (most preferred first).
@@ -444,9 +453,8 @@ class CandidateEvaluator:
 
     def get_applicable_candidates(
         self,
-        candidates,  # type: List[InstallationCandidate]
-    ):
-        # type: (...) -> List[InstallationCandidate]
+        candidates: List[InstallationCandidate],
+    ) -> List[InstallationCandidate]:
         """
         Return the applicable candidates from a list of candidates.
         """
@@ -454,7 +462,8 @@ class CandidateEvaluator:
         allow_prereleases = self._allow_all_prereleases or None
         specifier = self._specifier
         versions = {
-            str(v) for v in specifier.filter(
+            str(v)
+            for v in specifier.filter(
                 # We turn the version object into a str here because otherwise
                 # when we're debundled but setuptools isn't, Python will see
                 # packaging.version.Version and
@@ -468,9 +477,7 @@ class CandidateEvaluator:
         }
 
         # Again, converting version to str to deal with debundling.
-        applicable_candidates = [
-            c for c in candidates if str(c.version) in versions
-        ]
+        applicable_candidates = [c for c in candidates if str(c.version) in versions]
 
         filtered_applicable_candidates = filter_unallowed_hashes(
             candidates=applicable_candidates,
@@ -480,8 +487,7 @@ class CandidateEvaluator:
 
         return sorted(filtered_applicable_candidates, key=self._sort_key)
 
-    def _sort_key(self, candidate):
-        # type: (InstallationCandidate) -> CandidateSortingKey
+    def _sort_key(self, candidate: InstallationCandidate) -> CandidateSortingKey:
         """
         Function to pass as the `key` argument to a call to sorted() to sort
         InstallationCandidates by preference.
@@ -513,16 +519,18 @@ class CandidateEvaluator:
         """
         valid_tags = self._supported_tags
         support_num = len(valid_tags)
-        build_tag = ()  # type: BuildTag
+        build_tag: BuildTag = ()
         binary_preference = 0
         link = candidate.link
         if link.is_wheel:
             # can raise InvalidWheelFilename
             wheel = Wheel(link.filename)
             try:
-                pri = -(wheel.find_most_preferred_tag(
-                    valid_tags, self._wheel_tag_preferences
-                ))
+                pri = -(
+                    wheel.find_most_preferred_tag(
+                        valid_tags, self._wheel_tag_preferences
+                    )
+                )
             except ValueError:
                 raise UnsupportedWheel(
                     "{} is not a supported wheel for this platform. It "
@@ -531,7 +539,8 @@ class CandidateEvaluator:
             if self._prefer_binary:
                 binary_preference = 1
             if wheel.build_tag is not None:
-                match = re.match(r'^(\d+)(.*)$', wheel.build_tag)
+                match = re.match(r"^(\d+)(.*)$", wheel.build_tag)
+                assert match is not None, "guaranteed by filename validation"
                 build_tag_groups = match.groups()
                 build_tag = (int(build_tag_groups[0]), build_tag_groups[1])
         else:  # sdist
@@ -539,15 +548,18 @@ class CandidateEvaluator:
         has_allowed_hash = int(link.is_hash_allowed(self._hashes))
         yank_value = -1 * int(link.is_yanked)  # -1 for yanked.
         return (
-            has_allowed_hash, yank_value, binary_preference, candidate.version,
-            pri, build_tag,
+            has_allowed_hash,
+            yank_value,
+            binary_preference,
+            candidate.version,
+            pri,
+            build_tag,
         )
 
     def sort_best_candidate(
         self,
-        candidates,    # type: List[InstallationCandidate]
-    ):
-        # type: (...) -> Optional[InstallationCandidate]
+        candidates: List[InstallationCandidate],
+    ) -> Optional[InstallationCandidate]:
         """
         Return the best candidate per the instance's sort order, or None if
         no candidate is acceptable.
@@ -559,9 +571,8 @@ class CandidateEvaluator:
 
     def compute_best_candidate(
         self,
-        candidates,      # type: List[InstallationCandidate]
-    ):
-        # type: (...) -> BestCandidateResult
+        candidates: List[InstallationCandidate],
+    ) -> BestCandidateResult:
         """
         Compute and return a `BestCandidateResult` instance.
         """
@@ -585,14 +596,13 @@ class PackageFinder:
 
     def __init__(
         self,
-        link_collector,       # type: LinkCollector
-        target_python,        # type: TargetPython
-        allow_yanked,         # type: bool
-        format_control=None,  # type: Optional[FormatControl]
-        candidate_prefs=None,         # type: CandidatePreferences
-        ignore_requires_python=None,  # type: Optional[bool]
-    ):
-        # type: (...) -> None
+        link_collector: LinkCollector,
+        target_python: TargetPython,
+        allow_yanked: bool,
+        format_control: Optional[FormatControl] = None,
+        candidate_prefs: Optional[CandidatePreferences] = None,
+        ignore_requires_python: Optional[bool] = None,
+    ) -> None:
         """
         This constructor is primarily meant to be used by the create() class
         method and from tests.
@@ -617,7 +627,7 @@ class PackageFinder:
         self.format_control = format_control
 
         # These are boring links that have already been logged somehow.
-        self._logged_links = set()  # type: Set[Link]
+        self._logged_links: Set[Tuple[Link, LinkType, str]] = set()
 
     # Don't include an allow_yanked default value to make sure each call
     # site considers whether yanked releases are allowed. This also causes
@@ -626,11 +636,10 @@ class PackageFinder:
     @classmethod
     def create(
         cls,
-        link_collector,      # type: LinkCollector
-        selection_prefs,     # type: SelectionPreferences
-        target_python=None,  # type: Optional[TargetPython]
-    ):
-        # type: (...) -> PackageFinder
+        link_collector: LinkCollector,
+        selection_prefs: SelectionPreferences,
+        target_python: Optional[TargetPython] = None,
+    ) -> "PackageFinder":
         """Create a PackageFinder.
 
         :param selection_prefs: The candidate selection preferences, as a
@@ -657,56 +666,53 @@ class PackageFinder:
         )
 
     @property
-    def target_python(self):
-        # type: () -> TargetPython
+    def target_python(self) -> TargetPython:
         return self._target_python
 
     @property
-    def search_scope(self):
-        # type: () -> SearchScope
+    def search_scope(self) -> SearchScope:
         return self._link_collector.search_scope
 
     @search_scope.setter
-    def search_scope(self, search_scope):
-        # type: (SearchScope) -> None
+    def search_scope(self, search_scope: SearchScope) -> None:
         self._link_collector.search_scope = search_scope
 
     @property
-    def find_links(self):
-        # type: () -> List[str]
+    def find_links(self) -> List[str]:
         return self._link_collector.find_links
 
     @property
-    def index_urls(self):
-        # type: () -> List[str]
+    def index_urls(self) -> List[str]:
         return self.search_scope.index_urls
 
     @property
-    def trusted_hosts(self):
-        # type: () -> Iterable[str]
+    def trusted_hosts(self) -> Iterable[str]:
         for host_port in self._link_collector.session.pip_trusted_origins:
             yield build_netloc(*host_port)
 
     @property
-    def allow_all_prereleases(self):
-        # type: () -> bool
+    def allow_all_prereleases(self) -> bool:
         return self._candidate_prefs.allow_all_prereleases
 
-    def set_allow_all_prereleases(self):
-        # type: () -> None
+    def set_allow_all_prereleases(self) -> None:
         self._candidate_prefs.allow_all_prereleases = True
 
     @property
-    def prefer_binary(self):
-        # type: () -> bool
+    def prefer_binary(self) -> bool:
         return self._candidate_prefs.prefer_binary
 
-    def set_prefer_binary(self):
-        # type: () -> None
+    def set_prefer_binary(self) -> None:
         self._candidate_prefs.prefer_binary = True
 
-    def make_link_evaluator(self, project_name):
-        # type: (str) -> LinkEvaluator
+    def requires_python_skipped_reasons(self) -> List[str]:
+        reasons = {
+            detail
+            for _, result, detail in self._logged_links
+            if result == LinkType.requires_python_mismatch
+        }
+        return sorted(reasons)
+
+    def make_link_evaluator(self, project_name: str) -> LinkEvaluator:
         canonical_name = canonicalize_name(project_name)
         formats = self.format_control.get_allowed_formats(canonical_name)
 
@@ -719,14 +725,13 @@ class PackageFinder:
             ignore_requires_python=self._ignore_requires_python,
         )
 
-    def _sort_links(self, links):
-        # type: (Iterable[Link]) -> List[Link]
+    def _sort_links(self, links: Iterable[Link]) -> List[Link]:
         """
         Returns elements of links in order, non-egg links first, egg links
         second, while eliminating duplicates
         """
         eggs, no_eggs = [], []
-        seen = set()  # type: Set[Link]
+        seen: Set[Link] = set()
         for link in links:
             if link not in seen:
                 seen.add(link)
@@ -736,34 +741,35 @@ class PackageFinder:
                     no_eggs.append(link)
         return no_eggs + eggs
 
-    def _log_skipped_link(self, link, reason):
-        # type: (Link, str) -> None
-        if link not in self._logged_links:
+    def _log_skipped_link(self, link: Link, result: LinkType, detail: str) -> None:
+        entry = (link, result, detail)
+        if entry not in self._logged_links:
             # Put the link at the end so the reason is more visible and because
             # the link string is usually very long.
-            logger.debug('Skipping link: %s: %s', reason, link)
-            self._logged_links.add(link)
+            logger.debug("Skipping link: %s: %s", detail, link)
+            self._logged_links.add(entry)
 
-    def get_install_candidate(self, link_evaluator, link):
-        # type: (LinkEvaluator, Link) -> Optional[InstallationCandidate]
+    def get_install_candidate(
+        self, link_evaluator: LinkEvaluator, link: Link
+    ) -> Optional[InstallationCandidate]:
         """
         If the link is a candidate for install, convert it to an
         InstallationCandidate and return it. Otherwise, return None.
         """
-        is_candidate, result = link_evaluator.evaluate_link(link)
-        if not is_candidate:
-            if result:
-                self._log_skipped_link(link, reason=result)
+        result, detail = link_evaluator.evaluate_link(link)
+        if result != LinkType.candidate:
+            self._log_skipped_link(link, result, detail)
             return None
 
         return InstallationCandidate(
             name=link_evaluator.project_name,
             link=link,
-            version=result,
+            version=detail,
         )
 
-    def evaluate_links(self, link_evaluator, links):
-        # type: (LinkEvaluator, Iterable[Link]) -> List[InstallationCandidate]
+    def evaluate_links(
+        self, link_evaluator: LinkEvaluator, links: Iterable[Link]
+    ) -> List[InstallationCandidate]:
         """
         Convert links that are candidates to InstallationCandidate objects.
         """
@@ -775,16 +781,18 @@ class PackageFinder:
 
         return candidates
 
-    def process_project_url(self, project_url, link_evaluator):
-        # type: (Link, LinkEvaluator) -> List[InstallationCandidate]
+    def process_project_url(
+        self, project_url: Link, link_evaluator: LinkEvaluator
+    ) -> List[InstallationCandidate]:
         logger.debug(
-            'Fetching project page and analyzing links: %s', project_url,
+            "Fetching project page and analyzing links: %s",
+            project_url,
         )
-        html_page = self._link_collector.fetch_page(project_url)
-        if html_page is None:
+        index_response = self._link_collector.fetch_response(project_url)
+        if index_response is None:
             return []
 
-        page_links = list(parse_links(html_page))
+        page_links = list(parse_links(index_response))
 
         with indent_log():
             package_links = self.evaluate_links(
@@ -795,8 +803,7 @@ class PackageFinder:
         return package_links
 
     @functools.lru_cache(maxsize=None)
-    def find_all_candidates(self, project_name):
-        # type: (str) -> List[InstallationCandidate]
+    def find_all_candidates(self, project_name: str) -> List[InstallationCandidate]:
         """Find all available InstallationCandidate for project_name
 
         This checks index_urls and find_links.
@@ -835,7 +842,14 @@ class PackageFinder:
         )
 
         if logger.isEnabledFor(logging.DEBUG) and file_candidates:
-            paths = [url_to_path(c.link.url) for c in file_candidates]
+            paths = []
+            for candidate in file_candidates:
+                assert candidate.link.url  # we need to have a URL
+                try:
+                    paths.append(candidate.link.file_path)
+                except Exception:
+                    paths.append(candidate.link.url)  # it's not a local file
+
             logger.debug("Local files found: %s", ", ".join(paths))
 
         # This is an intentional priority ordering
@@ -843,13 +857,11 @@ class PackageFinder:
 
     def make_candidate_evaluator(
         self,
-        project_name,    # type: str
-        specifier=None,  # type: Optional[specifiers.BaseSpecifier]
-        hashes=None,     # type: Optional[Hashes]
-    ):
-        # type: (...) -> CandidateEvaluator
-        """Create a CandidateEvaluator object to use.
-        """
+        project_name: str,
+        specifier: Optional[specifiers.BaseSpecifier] = None,
+        hashes: Optional[Hashes] = None,
+    ) -> CandidateEvaluator:
+        """Create a CandidateEvaluator object to use."""
         candidate_prefs = self._candidate_prefs
         return CandidateEvaluator.create(
             project_name=project_name,
@@ -863,11 +875,10 @@ class PackageFinder:
     @functools.lru_cache(maxsize=None)
     def find_best_candidate(
         self,
-        project_name,       # type: str
-        specifier=None,     # type: Optional[specifiers.BaseSpecifier]
-        hashes=None,        # type: Optional[Hashes]
-    ):
-        # type: (...) -> BestCandidateResult
+        project_name: str,
+        specifier: Optional[specifiers.BaseSpecifier] = None,
+        hashes: Optional[Hashes] = None,
+    ) -> BestCandidateResult:
         """Find matches for the given project and specifier.
 
         :param specifier: An optional object implementing `filter`
@@ -884,8 +895,9 @@ class PackageFinder:
         )
         return candidate_evaluator.compute_best_candidate(candidates)
 
-    def find_requirement(self, req, upgrade):
-        # type: (InstallRequirement, bool) -> Optional[InstallationCandidate]
+    def find_requirement(
+        self, req: InstallRequirement, upgrade: bool
+    ) -> Optional[InstallationCandidate]:
         """Try to find a Link matching req
 
         Expects req, an InstallRequirement and upgrade, a boolean
@@ -894,80 +906,86 @@ class PackageFinder:
         """
         hashes = req.hashes(trust_internet=False)
         best_candidate_result = self.find_best_candidate(
-            req.name, specifier=req.specifier, hashes=hashes,
+            req.name,
+            specifier=req.specifier,
+            hashes=hashes,
         )
         best_candidate = best_candidate_result.best_candidate
 
-        installed_version = None    # type: Optional[_BaseVersion]
+        installed_version: Optional[_BaseVersion] = None
         if req.satisfied_by is not None:
-            installed_version = parse_version(req.satisfied_by.version)
+            installed_version = req.satisfied_by.version
 
-        def _format_versions(cand_iter):
-            # type: (Iterable[InstallationCandidate]) -> str
+        def _format_versions(cand_iter: Iterable[InstallationCandidate]) -> str:
             # This repeated parse_version and str() conversion is needed to
             # handle different vendoring sources from pip and pkg_resources.
             # If we stop using the pkg_resources provided specifier and start
             # using our own, we can drop the cast to str().
-            return ", ".join(sorted(
-                {str(c.version) for c in cand_iter},
-                key=parse_version,
-            )) or "none"
+            return (
+                ", ".join(
+                    sorted(
+                        {str(c.version) for c in cand_iter},
+                        key=parse_version,
+                    )
+                )
+                or "none"
+            )
 
         if installed_version is None and best_candidate is None:
             logger.critical(
-                'Could not find a version that satisfies the requirement %s '
-                '(from versions: %s)',
+                "Could not find a version that satisfies the requirement %s "
+                "(from versions: %s)",
                 req,
                 _format_versions(best_candidate_result.iter_all()),
             )
 
             raise DistributionNotFound(
-                'No matching distribution found for {}'.format(
-                    req)
+                "No matching distribution found for {}".format(req)
             )
 
-        best_installed = False
-        if installed_version and (
-                best_candidate is None or
-                best_candidate.version <= installed_version):
-            best_installed = True
+        def _should_install_candidate(
+            candidate: Optional[InstallationCandidate],
+        ) -> "TypeGuard[InstallationCandidate]":
+            if installed_version is None:
+                return True
+            if best_candidate is None:
+                return False
+            return best_candidate.version > installed_version
 
         if not upgrade and installed_version is not None:
-            if best_installed:
+            if _should_install_candidate(best_candidate):
                 logger.debug(
-                    'Existing installed version (%s) is most up-to-date and '
-                    'satisfies requirement',
+                    "Existing installed version (%s) satisfies requirement "
+                    "(most up-to-date version is %s)",
                     installed_version,
+                    best_candidate.version,
                 )
             else:
                 logger.debug(
-                    'Existing installed version (%s) satisfies requirement '
-                    '(most up-to-date version is %s)',
+                    "Existing installed version (%s) is most up-to-date and "
+                    "satisfies requirement",
                     installed_version,
-                    best_candidate.version,
                 )
             return None
 
-        if best_installed:
-            # We have an existing version, and its the best version
+        if _should_install_candidate(best_candidate):
             logger.debug(
-                'Installed version (%s) is most up-to-date (past versions: '
-                '%s)',
-                installed_version,
+                "Using version %s (newest of versions: %s)",
+                best_candidate.version,
                 _format_versions(best_candidate_result.iter_applicable()),
             )
-            raise BestVersionAlreadyInstalled
+            return best_candidate
 
+        # We have an existing version, and its the best version
         logger.debug(
-            'Using version %s (newest of versions: %s)',
-            best_candidate.version,
+            "Installed version (%s) is most up-to-date (past versions: %s)",
+            installed_version,
             _format_versions(best_candidate_result.iter_applicable()),
         )
-        return best_candidate
+        raise BestVersionAlreadyInstalled
 
 
-def _find_name_version_sep(fragment, canonical_name):
-    # type: (str, str) -> int
+def _find_name_version_sep(fragment: str, canonical_name: str) -> int:
     """Find the separator's index based on the package's canonical name.
 
     :param fragment: A <package>+<version> filename "fragment" (stem) or
@@ -993,8 +1011,7 @@ def _find_name_version_sep(fragment, canonical_name):
     raise ValueError(f"{fragment} does not match {canonical_name}")
 
 
-def _extract_version_from_fragment(fragment, canonical_name):
-    # type: (str, str) -> Optional[str]
+def _extract_version_from_fragment(fragment: str, canonical_name: str) -> Optional[str]:
     """Parse the version string from a <package>+<version> filename
     "fragment" (stem) or egg fragment.
 
diff --git a/env/Lib/site-packages/pip/_internal/index/sources.py b/env/Lib/site-packages/pip/_internal/index/sources.py
index eec3f12f..cd9cb8d4 100644
--- a/env/Lib/site-packages/pip/_internal/index/sources.py
+++ b/env/Lib/site-packages/pip/_internal/index/sources.py
@@ -171,7 +171,6 @@ def build_source(
     expand_dir: bool,
     cache_link_parsing: bool,
 ) -> Tuple[Optional[str], Optional[LinkSource]]:
-
     path: Optional[str] = None
     url: Optional[str] = None
     if os.path.exists(location):  # Is a local path.
diff --git a/env/Lib/site-packages/pip/_internal/locations/__init__.py b/env/Lib/site-packages/pip/_internal/locations/__init__.py
index 3acb51bc..d54bc63e 100644
--- a/env/Lib/site-packages/pip/_internal/locations/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/locations/__init__.py
@@ -1,16 +1,22 @@
+import functools
 import logging
+import os
 import pathlib
 import sys
 import sysconfig
-from typing import List, Optional
+from typing import Any, Dict, Generator, Optional, Tuple
 
 from pip._internal.models.scheme import SCHEME_KEYS, Scheme
+from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.deprecation import deprecated
+from pip._internal.utils.virtualenv import running_under_virtualenv
 
-from . import _distutils, _sysconfig
+from . import _sysconfig
 from .base import (
     USER_CACHE_DIR,
     get_major_minor_version,
     get_src_prefix,
+    is_osx_framework,
     site_packages,
     user_site,
 )
@@ -21,7 +27,6 @@ __all__ = [
     "get_bin_user",
     "get_major_minor_version",
     "get_platlib",
-    "get_prefixed_libs",
     "get_purelib",
     "get_scheme",
     "get_src_prefix",
@@ -33,28 +38,177 @@ __all__ = [
 logger = logging.getLogger(__name__)
 
 
-def _default_base(*, user: bool) -> str:
-    if user:
-        base = sysconfig.get_config_var("userbase")
-    else:
-        base = sysconfig.get_config_var("base")
-    assert base is not None
-    return base
+_PLATLIBDIR: str = getattr(sys, "platlibdir", "lib")
 
+_USE_SYSCONFIG_DEFAULT = sys.version_info >= (3, 10)
 
-def _warn_if_mismatch(old: pathlib.Path, new: pathlib.Path, *, key: str) -> bool:
-    if old == new:
+
+def _should_use_sysconfig() -> bool:
+    """This function determines the value of _USE_SYSCONFIG.
+
+    By default, pip uses sysconfig on Python 3.10+.
+    But Python distributors can override this decision by setting:
+        sysconfig._PIP_USE_SYSCONFIG = True / False
+    Rationale in https://github.com/pypa/pip/issues/10647
+
+    This is a function for testability, but should be constant during any one
+    run.
+    """
+    return bool(getattr(sysconfig, "_PIP_USE_SYSCONFIG", _USE_SYSCONFIG_DEFAULT))
+
+
+_USE_SYSCONFIG = _should_use_sysconfig()
+
+if not _USE_SYSCONFIG:
+    # Import distutils lazily to avoid deprecation warnings,
+    # but import it soon enough that it is in memory and available during
+    # a pip reinstall.
+    from . import _distutils
+
+# Be noisy about incompatibilities if this platforms "should" be using
+# sysconfig, but is explicitly opting out and using distutils instead.
+if _USE_SYSCONFIG_DEFAULT and not _USE_SYSCONFIG:
+    _MISMATCH_LEVEL = logging.WARNING
+else:
+    _MISMATCH_LEVEL = logging.DEBUG
+
+
+def _looks_like_bpo_44860() -> bool:
+    """The resolution to bpo-44860 will change this incorrect platlib.
+
+    See <https://bugs.python.org/issue44860>.
+    """
+    from distutils.command.install import INSTALL_SCHEMES
+
+    try:
+        unix_user_platlib = INSTALL_SCHEMES["unix_user"]["platlib"]
+    except KeyError:
+        return False
+    return unix_user_platlib == "$usersite"
+
+
+def _looks_like_red_hat_patched_platlib_purelib(scheme: Dict[str, str]) -> bool:
+    platlib = scheme["platlib"]
+    if "/$platlibdir/" in platlib:
+        platlib = platlib.replace("/$platlibdir/", f"/{_PLATLIBDIR}/")
+    if "/lib64/" not in platlib:
+        return False
+    unpatched = platlib.replace("/lib64/", "/lib/")
+    return unpatched.replace("$platbase/", "$base/") == scheme["purelib"]
+
+
+@functools.lru_cache(maxsize=None)
+def _looks_like_red_hat_lib() -> bool:
+    """Red Hat patches platlib in unix_prefix and unix_home, but not purelib.
+
+    This is the only way I can see to tell a Red Hat-patched Python.
+    """
+    from distutils.command.install import INSTALL_SCHEMES
+
+    return all(
+        k in INSTALL_SCHEMES
+        and _looks_like_red_hat_patched_platlib_purelib(INSTALL_SCHEMES[k])
+        for k in ("unix_prefix", "unix_home")
+    )
+
+
+@functools.lru_cache(maxsize=None)
+def _looks_like_debian_scheme() -> bool:
+    """Debian adds two additional schemes."""
+    from distutils.command.install import INSTALL_SCHEMES
+
+    return "deb_system" in INSTALL_SCHEMES and "unix_local" in INSTALL_SCHEMES
+
+
+@functools.lru_cache(maxsize=None)
+def _looks_like_red_hat_scheme() -> bool:
+    """Red Hat patches ``sys.prefix`` and ``sys.exec_prefix``.
+
+    Red Hat's ``00251-change-user-install-location.patch`` changes the install
+    command's ``prefix`` and ``exec_prefix`` to append ``"/local"``. This is
+    (fortunately?) done quite unconditionally, so we create a default command
+    object without any configuration to detect this.
+    """
+    from distutils.command.install import install
+    from distutils.dist import Distribution
+
+    cmd: Any = install(Distribution())
+    cmd.finalize_options()
+    return (
+        cmd.exec_prefix == f"{os.path.normpath(sys.exec_prefix)}/local"
+        and cmd.prefix == f"{os.path.normpath(sys.prefix)}/local"
+    )
+
+
+@functools.lru_cache(maxsize=None)
+def _looks_like_slackware_scheme() -> bool:
+    """Slackware patches sysconfig but fails to patch distutils and site.
+
+    Slackware changes sysconfig's user scheme to use ``"lib64"`` for the lib
+    path, but does not do the same to the site module.
+    """
+    if user_site is None:  # User-site not available.
+        return False
+    try:
+        paths = sysconfig.get_paths(scheme="posix_user", expand=False)
+    except KeyError:  # User-site not available.
         return False
-    issue_url = "https://github.com/pypa/pip/issues/9617"
+    return "/lib64/" in paths["purelib"] and "/lib64/" not in user_site
+
+
+@functools.lru_cache(maxsize=None)
+def _looks_like_msys2_mingw_scheme() -> bool:
+    """MSYS2 patches distutils and sysconfig to use a UNIX-like scheme.
+
+    However, MSYS2 incorrectly patches sysconfig ``nt`` scheme. The fix is
+    likely going to be included in their 3.10 release, so we ignore the warning.
+    See msys2/MINGW-packages#9319.
+
+    MSYS2 MINGW's patch uses lowercase ``"lib"`` instead of the usual uppercase,
+    and is missing the final ``"site-packages"``.
+    """
+    paths = sysconfig.get_paths("nt", expand=False)
+    return all(
+        "Lib" not in p and "lib" in p and not p.endswith("site-packages")
+        for p in (paths[key] for key in ("platlib", "purelib"))
+    )
+
+
+def _fix_abiflags(parts: Tuple[str]) -> Generator[str, None, None]:
+    ldversion = sysconfig.get_config_var("LDVERSION")
+    abiflags = getattr(sys, "abiflags", None)
+
+    # LDVERSION does not end with sys.abiflags. Just return the path unchanged.
+    if not ldversion or not abiflags or not ldversion.endswith(abiflags):
+        yield from parts
+        return
+
+    # Strip sys.abiflags from LDVERSION-based path components.
+    for part in parts:
+        if part.endswith(ldversion):
+            part = part[: (0 - len(abiflags))]
+        yield part
+
+
+@functools.lru_cache(maxsize=None)
+def _warn_mismatched(old: pathlib.Path, new: pathlib.Path, *, key: str) -> None:
+    issue_url = "https://github.com/pypa/pip/issues/10151"
     message = (
         "Value for %s does not match. Please report this to <%s>"
         "\ndistutils: %s"
         "\nsysconfig: %s"
     )
-    logger.debug(message, key, issue_url, old, new)
+    logger.log(_MISMATCH_LEVEL, message, key, issue_url, old, new)
+
+
+def _warn_if_mismatch(old: pathlib.Path, new: pathlib.Path, *, key: str) -> bool:
+    if old == new:
+        return False
+    _warn_mismatched(old, new, key=key)
     return True
 
 
+@functools.lru_cache(maxsize=None)
 def _log_context(
     *,
     user: bool = False,
@@ -62,22 +216,26 @@ def _log_context(
     root: Optional[str] = None,
     prefix: Optional[str] = None,
 ) -> None:
-    message = (
-        "Additional context:" "\nuser = %r" "\nhome = %r" "\nroot = %r" "\nprefix = %r"
-    )
-    logger.debug(message, user, home, root, prefix)
+    parts = [
+        "Additional context:",
+        "user = %r",
+        "home = %r",
+        "root = %r",
+        "prefix = %r",
+    ]
+
+    logger.log(_MISMATCH_LEVEL, "\n".join(parts), user, home, root, prefix)
 
 
 def get_scheme(
-    dist_name,  # type: str
-    user=False,  # type: bool
-    home=None,  # type: Optional[str]
-    root=None,  # type: Optional[str]
-    isolated=False,  # type: bool
-    prefix=None,  # type: Optional[str]
-):
-    # type: (...) -> Scheme
-    old = _distutils.get_scheme(
+    dist_name: str,
+    user: bool = False,
+    home: Optional[str] = None,
+    root: Optional[str] = None,
+    isolated: bool = False,
+    prefix: Optional[str] = None,
+) -> Scheme:
+    new = _sysconfig.get_scheme(
         dist_name,
         user=user,
         home=home,
@@ -85,7 +243,10 @@ def get_scheme(
         isolated=isolated,
         prefix=prefix,
     )
-    new = _sysconfig.get_scheme(
+    if _USE_SYSCONFIG:
+        return new
+
+    old = _distutils.get_scheme(
         dist_name,
         user=user,
         home=home,
@@ -94,13 +255,14 @@ def get_scheme(
         prefix=prefix,
     )
 
-    base = prefix or home or _default_base(user=user)
-    warned = []
+    warning_contexts = []
     for k in SCHEME_KEYS:
-        # Extra join because distutils can return relative paths.
-        old_v = pathlib.Path(base, getattr(old, k))
+        old_v = pathlib.Path(getattr(old, k))
         new_v = pathlib.Path(getattr(new, k))
 
+        if old_v == new_v:
+            continue
+
         # distutils incorrectly put PyPy packages under ``site-packages/python``
         # in the ``posix_home`` scheme, but PyPy devs said they expect the
         # directory name to be ``pypy`` instead. So we treat this as a bug fix
@@ -110,75 +272,196 @@ def get_scheme(
             and home is not None
             and k in ("platlib", "purelib")
             and old_v.parent == new_v.parent
-            and old_v.name == "python"
-            and new_v.name == "pypy"
+            and old_v.name.startswith("python")
+            and new_v.name.startswith("pypy")
         )
         if skip_pypy_special_case:
             continue
 
-        warned.append(_warn_if_mismatch(old_v, new_v, key=f"scheme.{k}"))
+        # sysconfig's ``osx_framework_user`` does not include ``pythonX.Y`` in
+        # the ``include`` value, but distutils's ``headers`` does. We'll let
+        # CPython decide whether this is a bug or feature. See bpo-43948.
+        skip_osx_framework_user_special_case = (
+            user
+            and is_osx_framework()
+            and k == "headers"
+            and old_v.parent.parent == new_v.parent
+            and old_v.parent.name.startswith("python")
+        )
+        if skip_osx_framework_user_special_case:
+            continue
+
+        # On Red Hat and derived Linux distributions, distutils is patched to
+        # use "lib64" instead of "lib" for platlib.
+        if k == "platlib" and _looks_like_red_hat_lib():
+            continue
+
+        # On Python 3.9+, sysconfig's posix_user scheme sets platlib against
+        # sys.platlibdir, but distutils's unix_user incorrectly coninutes
+        # using the same $usersite for both platlib and purelib. This creates a
+        # mismatch when sys.platlibdir is not "lib".
+        skip_bpo_44860 = (
+            user
+            and k == "platlib"
+            and not WINDOWS
+            and sys.version_info >= (3, 9)
+            and _PLATLIBDIR != "lib"
+            and _looks_like_bpo_44860()
+        )
+        if skip_bpo_44860:
+            continue
+
+        # Slackware incorrectly patches posix_user to use lib64 instead of lib,
+        # but not usersite to match the location.
+        skip_slackware_user_scheme = (
+            user
+            and k in ("platlib", "purelib")
+            and not WINDOWS
+            and _looks_like_slackware_scheme()
+        )
+        if skip_slackware_user_scheme:
+            continue
+
+        # Both Debian and Red Hat patch Python to place the system site under
+        # /usr/local instead of /usr. Debian also places lib in dist-packages
+        # instead of site-packages, but the /usr/local check should cover it.
+        skip_linux_system_special_case = (
+            not (user or home or prefix or running_under_virtualenv())
+            and old_v.parts[1:3] == ("usr", "local")
+            and len(new_v.parts) > 1
+            and new_v.parts[1] == "usr"
+            and (len(new_v.parts) < 3 or new_v.parts[2] != "local")
+            and (_looks_like_red_hat_scheme() or _looks_like_debian_scheme())
+        )
+        if skip_linux_system_special_case:
+            continue
+
+        # On Python 3.7 and earlier, sysconfig does not include sys.abiflags in
+        # the "pythonX.Y" part of the path, but distutils does.
+        skip_sysconfig_abiflag_bug = (
+            sys.version_info < (3, 8)
+            and not WINDOWS
+            and k in ("headers", "platlib", "purelib")
+            and tuple(_fix_abiflags(old_v.parts)) == new_v.parts
+        )
+        if skip_sysconfig_abiflag_bug:
+            continue
+
+        # MSYS2 MINGW's sysconfig patch does not include the "site-packages"
+        # part of the path. This is incorrect and will be fixed in MSYS.
+        skip_msys2_mingw_bug = (
+            WINDOWS and k in ("platlib", "purelib") and _looks_like_msys2_mingw_scheme()
+        )
+        if skip_msys2_mingw_bug:
+            continue
+
+        # CPython's POSIX install script invokes pip (via ensurepip) against the
+        # interpreter located in the source tree, not the install site. This
+        # triggers special logic in sysconfig that's not present in distutils.
+        # https://github.com/python/cpython/blob/8c21941ddaf/Lib/sysconfig.py#L178-L194
+        skip_cpython_build = (
+            sysconfig.is_python_build(check_home=True)
+            and not WINDOWS
+            and k in ("headers", "include", "platinclude")
+        )
+        if skip_cpython_build:
+            continue
+
+        warning_contexts.append((old_v, new_v, f"scheme.{k}"))
+
+    if not warning_contexts:
+        return old
+
+    # Check if this path mismatch is caused by distutils config files. Those
+    # files will no longer work once we switch to sysconfig, so this raises a
+    # deprecation message for them.
+    default_old = _distutils.distutils_scheme(
+        dist_name,
+        user,
+        home,
+        root,
+        isolated,
+        prefix,
+        ignore_config_files=True,
+    )
+    if any(default_old[k] != getattr(old, k) for k in SCHEME_KEYS):
+        deprecated(
+            reason=(
+                "Configuring installation scheme with distutils config files "
+                "is deprecated and will no longer work in the near future. If you "
+                "are using a Homebrew or Linuxbrew Python, please see discussion "
+                "at https://github.com/Homebrew/homebrew-core/issues/76621"
+            ),
+            replacement=None,
+            gone_in=None,
+        )
+        return old
 
-    if any(warned):
-        _log_context(user=user, home=home, root=root, prefix=prefix)
+    # Post warnings about this mismatch so user can report them back.
+    for old_v, new_v, key in warning_contexts:
+        _warn_mismatched(old_v, new_v, key=key)
+    _log_context(user=user, home=home, root=root, prefix=prefix)
 
     return old
 
 
-def get_bin_prefix():
-    # type: () -> str
-    old = _distutils.get_bin_prefix()
+def get_bin_prefix() -> str:
     new = _sysconfig.get_bin_prefix()
+    if _USE_SYSCONFIG:
+        return new
+
+    old = _distutils.get_bin_prefix()
     if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="bin_prefix"):
         _log_context()
     return old
 
 
-def get_bin_user():
-    # type: () -> str
+def get_bin_user() -> str:
     return _sysconfig.get_scheme("", user=True).scripts
 
 
-def get_purelib():
-    # type: () -> str
+def _looks_like_deb_system_dist_packages(value: str) -> bool:
+    """Check if the value is Debian's APT-controlled dist-packages.
+
+    Debian's ``distutils.sysconfig.get_python_lib()`` implementation returns the
+    default package path controlled by APT, but does not patch ``sysconfig`` to
+    do the same. This is similar to the bug worked around in ``get_scheme()``,
+    but here the default is ``deb_system`` instead of ``unix_local``. Ultimately
+    we can't do anything about this Debian bug, and this detection allows us to
+    skip the warning when needed.
+    """
+    if not _looks_like_debian_scheme():
+        return False
+    if value == "/usr/lib/python3/dist-packages":
+        return True
+    return False
+
+
+def get_purelib() -> str:
     """Return the default pure-Python lib location."""
-    old = _distutils.get_purelib()
     new = _sysconfig.get_purelib()
+    if _USE_SYSCONFIG:
+        return new
+
+    old = _distutils.get_purelib()
+    if _looks_like_deb_system_dist_packages(old):
+        return old
     if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="purelib"):
         _log_context()
     return old
 
 
-def get_platlib():
-    # type: () -> str
+def get_platlib() -> str:
     """Return the default platform-shared lib location."""
-    old = _distutils.get_platlib()
     new = _sysconfig.get_platlib()
+    if _USE_SYSCONFIG:
+        return new
+
+    from . import _distutils
+
+    old = _distutils.get_platlib()
+    if _looks_like_deb_system_dist_packages(old):
+        return old
     if _warn_if_mismatch(pathlib.Path(old), pathlib.Path(new), key="platlib"):
         _log_context()
     return old
-
-
-def get_prefixed_libs(prefix):
-    # type: (str) -> List[str]
-    """Return the lib locations under ``prefix``."""
-    old_pure, old_plat = _distutils.get_prefixed_libs(prefix)
-    new_pure, new_plat = _sysconfig.get_prefixed_libs(prefix)
-
-    warned = [
-        _warn_if_mismatch(
-            pathlib.Path(old_pure),
-            pathlib.Path(new_pure),
-            key="prefixed-purelib",
-        ),
-        _warn_if_mismatch(
-            pathlib.Path(old_plat),
-            pathlib.Path(new_plat),
-            key="prefixed-platlib",
-        ),
-    ]
-    if any(warned):
-        _log_context(prefix=prefix)
-
-    if old_pure == old_plat:
-        return [old_pure]
-    return [old_pure, old_plat]
diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 3d19e8715c4d0408347699bbbce4e079c03c082b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/_distutils.cpython-39.pyc
deleted file mode 100644
index e13efd8ecdfb8353e2a5b63eff73d5ebe58194ce..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3907
zcmYe~<>g{vU|^UdaWFMTgn{8Ph=Yt-85kHG7#J9e&oD4Bq%cG=q%fv1<uFDuf@!8G
zrWD2$<{ai+mMB(6kQ_@6TP}MPJDAOy!<Net#R+D!<#6S4M{$GM>^VHSyivTld{KP4
z{89Y50#O3Ff>DCGLQz6sd5#?6T#+adFq<<+G*>K249w=r5zm!~l3-*=;ZEVnk<68f
zl44{?kxJo9;csD#l1`CM5l9hiVT_VV5lRtmVTh7V5lInkVTh7T5lazoVTh7Xkw}qj
zVTe*lVG3r@l&LcJ$xlu!$;{6yRw&O%ElO1=PgTgt&(Bs!%P&$$&d*EBOfS|^$jmD)
zNzBPnC@v{YOVd$EElGX}3LrmC##`*p`MJ4?c`2HVx446yJzRZV<Go!YgF!M-T`L)H
z@ujDh#1~YSWaQ_?=VT^nvfW~F$xJS}#p07$Tyl%UzX0Td#GG5KA*BU5skc}|^D^`E
zZm}dM7MEx;-eL<*&PdHo1sNIc>F44f4l-S$s5CDxGcP^9G%qE!D84MSsH8M8CpE9^
zB_jg^gC^rGagd$4iCOtY@wu6K`9<+%sYS(^`FU>1Y#_HoF&_g113Lo)gEJ_8dl(r&
z@yC?Ikjq%h#>kMuT*HvbSj%3+Qlyl^lFnGep2BLwP{UTk-pp9bQNyu-X(0n6Lke3h
zXAMUda|(M3M+#>zQ!Qr=X9`;>V{w2NLla{OO9^WYXEReRR}EuPSq*DZnHNI}R}JHA
zh7|4^*4YemS(+J}7;Bh{Ce^SOP4Z$$;i+LllVdEHRl}9VR>Kv~R>N4ltcIy*O$u)f
zS3G+SYr&Qpt}J#io2lSH4ObRN4Ocuz4RgVn8m=tP8m@TG8m<LgAXjEG)N+?_yD-Fx
z)$)|^)NrNn)$oWjG&9w3*YMad6h27dui;q0o5H@3v5a8?W0719_X55W{u-_<0T50R
z=w({S$jDG4*bI{GC=tpMULXRpJ4Fzb(n>^|8D=xgWvXFV$XdglB4Wc(!wd?835-P$
zwPIi$;vhLmhJ}m^8B;_h8ESdKq9QfSHM}XJDQvAwk_-!(Kx%9lYPf?LG{vg4xfB!>
z6oOJqN{jLo5*1Q1i%UvNGINR%NfMkkz^aO%G0)?YSzJ<-nN$i&Rkv935_40lcy)F2
z@^wp#Q;T$y)6#Eo7bh2G7L>#%7Nr;a6|pcdFob{-T5?fpVo7QhD@dJf6^BAWQEFOd
zg>4mUMt*Lp?Jb5|9MCi!e~TN&0;OlBTkHj;MX5QNNw?SwauQ3xjLf{`oYIukTP($y
zC8@XAAj$t0dq!$vN@`JYkpL)}O5Eaudr1$(DiUH~V7MhzkXTfl8V|{T@oAYksl~VW
zLFqXelG)<(ld_6<Kq@6cn!q6v4|5Py%`Fy?FK)3x{BVl}<b_)-Mfv$9w*=BM^AdA1
zt5W0h!8xzEh#6!SdwOa~Vo6C6#43nXd<rO^vXvI3B$lM!Vgd1rBp4VNiuge~nDUEn
zu@oehWZYuO%FoOz5(Eiy6&K`WmZTJAmZjcePfRKX$!qf6;sm)g9uyfx${+(&L4+De
z14m|YeokUZYD$p`NDLeT5Y?dQxy6`ri#b0j>lS0?Ew*BCY~NzePOZGf3o<x9FFzh^
z)k=mUD+UIJUv17-F`>n&Ma40xIVqV%G5&d}E+D5U=qiNzd4{<L1$%}#1}lKd5kJ>p
zPsf;GS6|oQ5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq!>^H>J}s>XD6no7RMB1
z7U;)k=9Q!t<t66m=fKKO{dkZE!BL@CP<cxb!HtKwS`<{o_<_nDb{-}UMixdcCJsgr
z&Bw^Y$i*VVD8tCZ$ic|Q$ODEPOe~BXj3Vp;jABe6Q5HrfMkYosMyB5!99)btjBFs@
zKMvL+8wLgjlrjxeo`Ep9OtWBMU?^dzVW?rOVX9%SVX0wlW~*f@VXR?GVU%R3VM}2G
zlgwa}1x&I^GNiEevIa9~vL{+IGcbTNmwRf7LP<udf)d0tN(#yOMMbH_1^Ia?nR)37
zCHY|4%)Elq5`}`qqQu<PlGLJNJ%x~rR79=?o0O8DT$-DjR|2kf6bg#+%Q90^i^1BH
z^YcnlD@wqX56H5_vc$}s#H5^51&FQ1R$vn{N=gcft@QO%@{^18Ao)r!zbIYbSRa}P
z^fU8PQY-W_N^*0Q6LY{ZRg$U;l?2<%1vbbE>{77%z$w!T><UmCRme{Rv!SsL@?TME
zNl|8MSt?i@;vSGgbredAQ&Ygkfr_fkJg_`8mqXpH07|N0B~TkdS<^}(GcP4GIk5!f
z`FxNmV4X@JIVGq@WIdn^j7twl4yH#TF)sx*Sd$WqQ^6*I9GH?>l$u<UUsMTlJlMwK
z#9W9p)N!CP!b$-|Du63jh4PHd<P3%Ul8n?M1(^2C)MACiqEv;VR9%qqkN|)h0L#x-
z3aN#qnPs4Axdaq~C}psYLZ)7-o<d5#LSB9esHst$nUY!rcV?ZwUO^=yM<u7FD`*tt
z7iU&zD&!X_)aheL=H=(<LKURtBg}zD6et3U!G=TK2q_kEg(pN7XNZCg0tF_>>+m4K
z5~4*?pb||IM96`PI(A6CQ+$ghC9xz?lNC+A$QGp14pcKRf%A0{FNn=vWC#*REjEjc
zKw{t$(;UPCm44tNu*e!@6BnqufOtLxRPcbR8wM#MMkYo!82nvi4=Or9B@zsSYEV#Z
z2rfEuz(q%qNeN>X(*ouamMqp3#)V9^3}8N64Z}jlVgoQ6BF6-ht6>OcC}GKBPhm)5
z236-NEZIy&F<`w6DXd@-HjqdPdoaWtxZYp}O%A_X?7`rQx%d`yQfA&uP)qF=TS{V4
zd1l^AkPoT^^n)vlOHy<7eKM1Z5{oMJtN8Rwi;KX;aE^XbW}YTT5vWa9qyq{QT@axM
z3J&Jt%3^T!a*HjsBD1)p_!bAKqE5>%$^}*YNtt=^1(lHC0|z8H48hG-uoSo*Pyr7|
zCKg5kCLTrsMiyojMi#~*PxNpEg(s*^1&1T3cToavSoSgoGiWmVxvgZp#S5}NzPKPY
zIWsLYxd_z9K(Zd;25wM1LK_$DAO|pk%w{U`A<fE=A}>%_5U?f(+;r(dvc?x=4JcKB
zYz1Ku8)ORDXP}k<$Y(VSDNMagCEx}#h?NHFT(J1LX)+aggRBLm(h#s8H5tLNfaFzh
zNDG2}2@d7d6i^qTcp}IVp!jEC=3?afR|Kj!HCf&K{M`Itl;SP+`1q9k<oI|<Y`cOY
znir|e$W18%h1M+rP=gR$GebKow-C)HJ!o@D4_Z5bn?m3gVUZHZJYj@+#g)a77FiL<
zUANduDho36(u+V<Z4n2^o17p56x&7IAQrfRCS8zOpa*X*=;h|8q~;XsK{6&dci)mi
zRRMM<$W;Z2CE%odOAea?M282`6k`DuMc@V)q~HK$ZE(5-r<5X4Jc7dzDdZ7}jKd~3
xKczG$)eaQ9#h?ts!U}4eKw2U^j0#L(784H(!+$PE21Y3S#ihc*&%w&U3IHqDEHwZC

diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/_sysconfig.cpython-39.pyc
deleted file mode 100644
index 92a05c6453ca8f227db8ed333822ae0bdf066118..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4525
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
WgO8Dmm4Oioe{p$maB#44umS)&w4jCn

diff --git a/env/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/locations/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index eed182270bed2d109b288c03b2fe65a134ee2e86..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1238
zcmYe~<>g{vU|^UdaWM55D+9x05C<7^FfcGUFfcF__c1Uqq%fo~<}gG-XvQc;FrO)k
z2~0CbF@tHAD3%n46s8>3T(&4SMvz+O9QIs}C=N!3RJH}2DJ%;aqqtI;7jUPrE@X`2
zNnuN2Z()eyP2ou4Y+;DvtKvyzT)@AOAxa>eAy0yZAyu%lgOLFQQyH^_q68ut@|X-5
zQW%37G`U`aT<WLEc#A!;pdcl)s92NnmPAo$US4KidVFbKN@`JjS!Pj5X<|-lUfC_?
zg3N+j>;<JosX3WR$sn!Bn2CXb!5QRH9*{>FvlvPkvzYoAf*CZKs#3WW6ciMKQcFsU
z@)SxkQWbI&v+|2{b2IbuixkRIi;6Sz^Az&az*5PjMMbH3B?<wRB^mj73W>!Ei3-If
zMVWc&Itr<J>3U$Jl#KPvl@#)e6qJnh3=NbZf>o^5wR+XHn#{M@((;RP6H9I}7grYF
z;(=NapP84IzmlPdlYs$3{AzHviU}=FEh>&l%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi
z3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwuiAglk&B;&CEH25+j!Dfci}A@!iYd-4
zN!2Y#OwLYBPc4oq$Sly0&&(@HEy_#G(a*_GPAtjH&nwnXN-R#*E2z9Bo}O9~4-SlY
zaA3qk-6{wQNKl9}uoZDLFfgEmHX{QA11MR6Lpy?jfuV$<nW0Dm6y6J%OIWg4Qy3RA
z)iUInREa^w7#FZDWPpf<GvvvzFqE)YdV!JzBSQ(x0*(}>g^Y|0kc0u&!CAww5R^ce
z{cbTA7bREOhGe8Fq~+(Nq!uYu=9elY7NshrR-`7EmSpCoD->iFD5MqT=PD#8<|*Xm
zE9B(orKc7tB!RS)=B4OqauqQ%FfiO=$}hgfQjl1Zaf>A@KQph09VEzBP?VaMS#gUk
zJ+&mcJmnU<f3Ry&QGU@ameh*Ol3VPFNyQ*7nvA!&ii?utA*vB^SOm&_xA;K8h>(^7
zg&rR$aWb(n3NbS=iZSvq39uB2F)%P_3K#K$>}3H(6vPRf#g)a$`FUxX>9^QQDho36
z(xZe6G7I$J5vNyLl9^Ln1d5Maa#&>a5SawxQ@+yT)S~$0#N>?B_>|0|TYRCxu0iq6
zj?Nyg@h+Z0w>UuV1$pZhFUT43u=E0sYp^qK38$x)fJ_0&!=!I<f<)p$Lbv!FOG=6|
zlS)fcA;HB7wj$Uw#1$!Uz)2k(LL4@^`6;D2sdk{mQ!E2YL5v&_$i&0Q!_39Z#mvFU
MA;`qc!^p!30L-^j>;M1&

diff --git a/env/Lib/site-packages/pip/_internal/locations/_distutils.py b/env/Lib/site-packages/pip/_internal/locations/_distutils.py
index 2d7ab732..92bd9317 100644
--- a/env/Lib/site-packages/pip/_internal/locations/_distutils.py
+++ b/env/Lib/site-packages/pip/_internal/locations/_distutils.py
@@ -3,13 +3,25 @@
 # The following comment should be removed at some point in the future.
 # mypy: strict-optional=False
 
+# If pip's going to use distutils, it should not be using the copy that setuptools
+# might have injected into the environment. This is done by removing the injected
+# shim, if it's injected.
+#
+# See https://github.com/pypa/pip/issues/8761 for the original discussion and
+# rationale for why this is done within pip.
+try:
+    __import__("_distutils_hack").remove_shim()
+except (ImportError, AttributeError):
+    pass
+
+import logging
 import os
 import sys
 from distutils.cmd import Command as DistutilsCommand
 from distutils.command.install import SCHEME_KEYS
 from distutils.command.install import install as distutils_install_command
 from distutils.sysconfig import get_python_lib
-from typing import Dict, List, Optional, Tuple, Union, cast
+from typing import Dict, List, Optional, Union, cast
 
 from pip._internal.models.scheme import Scheme
 from pip._internal.utils.compat import WINDOWS
@@ -17,23 +29,40 @@ from pip._internal.utils.virtualenv import running_under_virtualenv
 
 from .base import get_major_minor_version
 
+logger = logging.getLogger(__name__)
 
-def _distutils_scheme(
-    dist_name, user=False, home=None, root=None, isolated=False, prefix=None
-):
-    # type:(str, bool, str, str, bool, str) -> Dict[str, str]
+
+def distutils_scheme(
+    dist_name: str,
+    user: bool = False,
+    home: Optional[str] = None,
+    root: Optional[str] = None,
+    isolated: bool = False,
+    prefix: Optional[str] = None,
+    *,
+    ignore_config_files: bool = False,
+) -> Dict[str, str]:
     """
     Return a distutils install scheme
     """
     from distutils.dist import Distribution
 
-    dist_args = {"name": dist_name}  # type: Dict[str, Union[str, List[str]]]
+    dist_args: Dict[str, Union[str, List[str]]] = {"name": dist_name}
     if isolated:
         dist_args["script_args"] = ["--no-user-cfg"]
 
     d = Distribution(dist_args)
-    d.parse_config_files()
-    obj = None  # type: Optional[DistutilsCommand]
+    if not ignore_config_files:
+        try:
+            d.parse_config_files()
+        except UnicodeDecodeError:
+            # Typeshed does not include find_config_files() for some reason.
+            paths = d.find_config_files()  # type: ignore
+            logger.warning(
+                "Ignore distutils configs in %s due to encoding errors.",
+                ", ".join(os.path.basename(p) for p in paths),
+            )
+    obj: Optional[DistutilsCommand] = None
     obj = d.get_command_obj("install", create=True)
     assert obj is not None
     i = cast(distutils_install_command, obj)
@@ -63,8 +92,14 @@ def _distutils_scheme(
         scheme.update(dict(purelib=i.install_lib, platlib=i.install_lib))
 
     if running_under_virtualenv():
+        if home:
+            prefix = home
+        elif user:
+            prefix = i.install_userbase
+        else:
+            prefix = i.prefix
         scheme["headers"] = os.path.join(
-            i.prefix,
+            prefix,
             "include",
             "site",
             f"python{get_major_minor_version()}",
@@ -73,23 +108,19 @@ def _distutils_scheme(
 
         if root is not None:
             path_no_drive = os.path.splitdrive(os.path.abspath(scheme["headers"]))[1]
-            scheme["headers"] = os.path.join(
-                root,
-                path_no_drive[1:],
-            )
+            scheme["headers"] = os.path.join(root, path_no_drive[1:])
 
     return scheme
 
 
 def get_scheme(
-    dist_name,  # type: str
-    user=False,  # type: bool
-    home=None,  # type: Optional[str]
-    root=None,  # type: Optional[str]
-    isolated=False,  # type: bool
-    prefix=None,  # type: Optional[str]
-):
-    # type: (...) -> Scheme
+    dist_name: str,
+    user: bool = False,
+    home: Optional[str] = None,
+    root: Optional[str] = None,
+    isolated: bool = False,
+    prefix: Optional[str] = None,
+) -> Scheme:
     """
     Get the "scheme" corresponding to the input parameters. The distutils
     documentation provides the context for the available schemes:
@@ -107,7 +138,7 @@ def get_scheme(
     :param prefix: indicates to use the "prefix" scheme and provides the
         base directory for the same
     """
-    scheme = _distutils_scheme(dist_name, user, home, root, isolated, prefix)
+    scheme = distutils_scheme(dist_name, user, home, root, isolated, prefix)
     return Scheme(
         platlib=scheme["platlib"],
         purelib=scheme["purelib"],
@@ -117,34 +148,26 @@ def get_scheme(
     )
 
 
-def get_bin_prefix():
-    # type: () -> str
+def get_bin_prefix() -> str:
+    # XXX: In old virtualenv versions, sys.prefix can contain '..' components,
+    # so we need to call normpath to eliminate them.
+    prefix = os.path.normpath(sys.prefix)
     if WINDOWS:
-        bin_py = os.path.join(sys.prefix, "Scripts")
+        bin_py = os.path.join(prefix, "Scripts")
         # buildout uses 'bin' on Windows too?
         if not os.path.exists(bin_py):
-            bin_py = os.path.join(sys.prefix, "bin")
+            bin_py = os.path.join(prefix, "bin")
         return bin_py
     # Forcing to use /usr/local/bin for standard macOS framework installs
     # Also log to ~/Library/Logs/ for use with the Console.app log viewer
-    if sys.platform[:6] == "darwin" and sys.prefix[:16] == "/System/Library/":
+    if sys.platform[:6] == "darwin" and prefix[:16] == "/System/Library/":
         return "/usr/local/bin"
-    return os.path.join(sys.prefix, "bin")
+    return os.path.join(prefix, "bin")
 
 
-def get_purelib():
-    # type: () -> str
+def get_purelib() -> str:
     return get_python_lib(plat_specific=False)
 
 
-def get_platlib():
-    # type: () -> str
+def get_platlib() -> str:
     return get_python_lib(plat_specific=True)
-
-
-def get_prefixed_libs(prefix):
-    # type: (str) -> Tuple[str, str]
-    return (
-        get_python_lib(plat_specific=False, prefix=prefix),
-        get_python_lib(plat_specific=True, prefix=prefix),
-    )
diff --git a/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py b/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py
index 03366ce6..97aef1f1 100644
--- a/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py
+++ b/env/Lib/site-packages/pip/_internal/locations/_sysconfig.py
@@ -1,4 +1,3 @@
-import distutils.util  # FIXME: For change_root.
 import logging
 import os
 import sys
@@ -9,14 +8,14 @@ from pip._internal.exceptions import InvalidSchemeCombination, UserInstallationI
 from pip._internal.models.scheme import SCHEME_KEYS, Scheme
 from pip._internal.utils.virtualenv import running_under_virtualenv
 
-from .base import get_major_minor_version
+from .base import change_root, get_major_minor_version, is_osx_framework
 
 logger = logging.getLogger(__name__)
 
 
 # Notes on _infer_* functions.
-# Unfortunately ``_get_default_scheme()`` is private, so there's no way to
-# ask things like "what is the '_prefix' scheme on this platform". These
+# Unfortunately ``get_default_scheme()`` didn't exist before 3.10, so there's no
+# way to ask things like "what is the '_prefix' scheme on this platform". These
 # functions try to answer that with some heuristics while accounting for ad-hoc
 # platforms not covered by CPython's default sysconfig implementation. If the
 # ad-hoc implementation does not fully implement sysconfig, we'll fall back to
@@ -24,13 +23,42 @@ logger = logging.getLogger(__name__)
 
 _AVAILABLE_SCHEMES = set(sysconfig.get_scheme_names())
 
+_PREFERRED_SCHEME_API = getattr(sysconfig, "get_preferred_scheme", None)
 
-def _infer_prefix():
-    # type: () -> str
+
+def _should_use_osx_framework_prefix() -> bool:
+    """Check for Apple's ``osx_framework_library`` scheme.
+
+    Python distributed by Apple's Command Line Tools has this special scheme
+    that's used when:
+
+    * This is a framework build.
+    * We are installing into the system prefix.
+
+    This does not account for ``pip install --prefix`` (also means we're not
+    installing to the system prefix), which should use ``posix_prefix``, but
+    logic here means ``_infer_prefix()`` outputs ``osx_framework_library``. But
+    since ``prefix`` is not available for ``sysconfig.get_default_scheme()``,
+    which is the stdlib replacement for ``_infer_prefix()``, presumably Apple
+    wouldn't be able to magically switch between ``osx_framework_library`` and
+    ``posix_prefix``. ``_infer_prefix()`` returning ``osx_framework_library``
+    means its behavior is consistent whether we use the stdlib implementation
+    or our own, and we deal with this special case in ``get_scheme()`` instead.
+    """
+    return (
+        "osx_framework_library" in _AVAILABLE_SCHEMES
+        and not running_under_virtualenv()
+        and is_osx_framework()
+    )
+
+
+def _infer_prefix() -> str:
     """Try to find a prefix scheme for the current platform.
 
     This tries:
 
+    * A special ``osx_framework_library`` for Python distributed by Apple's
+      Command Line Tools, when not running in a virtual environment.
     * Implementation + OS, used by PyPy on Windows (``pypy_nt``).
     * Implementation without OS, used by PyPy on POSIX (``pypy``).
     * OS + "prefix", used by CPython on POSIX (``posix_prefix``).
@@ -38,6 +66,10 @@ def _infer_prefix():
 
     If none of the above works, fall back to ``posix_prefix``.
     """
+    if _PREFERRED_SCHEME_API:
+        return _PREFERRED_SCHEME_API("prefix")
+    if _should_use_osx_framework_prefix():
+        return "osx_framework_library"
     implementation_suffixed = f"{sys.implementation.name}_{os.name}"
     if implementation_suffixed in _AVAILABLE_SCHEMES:
         return implementation_suffixed
@@ -51,10 +83,14 @@ def _infer_prefix():
     return "posix_prefix"
 
 
-def _infer_user():
-    # type: () -> str
+def _infer_user() -> str:
     """Try to find a user scheme for the current platform."""
-    suffixed = f"{os.name}_user"
+    if _PREFERRED_SCHEME_API:
+        return _PREFERRED_SCHEME_API("user")
+    if is_osx_framework() and not running_under_virtualenv():
+        suffixed = "osx_framework_user"
+    else:
+        suffixed = f"{os.name}_user"
     if suffixed in _AVAILABLE_SCHEMES:
         return suffixed
     if "posix_user" not in _AVAILABLE_SCHEMES:  # User scheme unavailable.
@@ -62,9 +98,10 @@ def _infer_user():
     return "posix_user"
 
 
-def _infer_home():
-    # type: () -> str
+def _infer_home() -> str:
     """Try to find a home for the current platform."""
+    if _PREFERRED_SCHEME_API:
+        return _PREFERRED_SCHEME_API("home")
     suffixed = f"{os.name}_home"
     if suffixed in _AVAILABLE_SCHEMES:
         return suffixed
@@ -85,14 +122,13 @@ if sysconfig.get_config_var("userbase") is not None:
 
 
 def get_scheme(
-    dist_name,  # type: str
-    user=False,  # type: bool
-    home=None,  # type: typing.Optional[str]
-    root=None,  # type: typing.Optional[str]
-    isolated=False,  # type: bool
-    prefix=None,  # type: typing.Optional[str]
-):
-    # type: (...) -> Scheme
+    dist_name: str,
+    user: bool = False,
+    home: typing.Optional[str] = None,
+    root: typing.Optional[str] = None,
+    isolated: bool = False,
+    prefix: typing.Optional[str] = None,
+) -> Scheme:
     """
     Get the "scheme" corresponding to the input parameters.
 
@@ -118,6 +154,12 @@ def get_scheme(
     else:
         scheme_name = _infer_prefix()
 
+    # Special case: When installing into a custom prefix, use posix_prefix
+    # instead of osx_framework_library. See _should_use_osx_framework_prefix()
+    # docstring for details.
+    if prefix is not None and scheme_name == "osx_framework_library":
+        scheme_name = "posix_prefix"
+
     if home is not None:
         variables = {k: home for k in _HOME_KEYS}
     elif prefix is not None:
@@ -151,30 +193,21 @@ def get_scheme(
     )
     if root is not None:
         for key in SCHEME_KEYS:
-            value = distutils.util.change_root(root, getattr(scheme, key))
+            value = change_root(root, getattr(scheme, key))
             setattr(scheme, key, value)
     return scheme
 
 
-def get_bin_prefix():
-    # type: () -> str
+def get_bin_prefix() -> str:
     # Forcing to use /usr/local/bin for standard macOS framework installs.
     if sys.platform[:6] == "darwin" and sys.prefix[:16] == "/System/Library/":
         return "/usr/local/bin"
     return sysconfig.get_paths()["scripts"]
 
 
-def get_purelib():
-    # type: () -> str
+def get_purelib() -> str:
     return sysconfig.get_paths()["purelib"]
 
 
-def get_platlib():
-    # type: () -> str
+def get_platlib() -> str:
     return sysconfig.get_paths()["platlib"]
-
-
-def get_prefixed_libs(prefix):
-    # type: (str) -> typing.Tuple[str, str]
-    paths = sysconfig.get_paths(vars={"base": prefix, "platbase": prefix})
-    return (paths["purelib"], paths["platlib"])
diff --git a/env/Lib/site-packages/pip/_internal/locations/base.py b/env/Lib/site-packages/pip/_internal/locations/base.py
index 98557abb..3f9f896e 100644
--- a/env/Lib/site-packages/pip/_internal/locations/base.py
+++ b/env/Lib/site-packages/pip/_internal/locations/base.py
@@ -1,9 +1,11 @@
+import functools
 import os
 import site
 import sys
 import sysconfig
 import typing
 
+from pip._internal.exceptions import InstallationError
 from pip._internal.utils import appdirs
 from pip._internal.utils.virtualenv import running_under_virtualenv
 
@@ -11,11 +13,10 @@ from pip._internal.utils.virtualenv import running_under_virtualenv
 USER_CACHE_DIR = appdirs.user_cache_dir("pip")
 
 # FIXME doesn't account for venv linked to global site-packages
-site_packages = sysconfig.get_path("purelib")  # type: typing.Optional[str]
+site_packages: str = sysconfig.get_path("purelib")
 
 
-def get_major_minor_version():
-    # type: () -> str
+def get_major_minor_version() -> str:
     """
     Return the major-minor version of the current Python as a string, e.g.
     "3.7" or "3.10".
@@ -23,8 +24,35 @@ def get_major_minor_version():
     return "{}.{}".format(*sys.version_info)
 
 
-def get_src_prefix():
-    # type: () -> str
+def change_root(new_root: str, pathname: str) -> str:
+    """Return 'pathname' with 'new_root' prepended.
+
+    If 'pathname' is relative, this is equivalent to os.path.join(new_root, pathname).
+    Otherwise, it requires making 'pathname' relative and then joining the
+    two, which is tricky on DOS/Windows and Mac OS.
+
+    This is borrowed from Python's standard library's distutils module.
+    """
+    if os.name == "posix":
+        if not os.path.isabs(pathname):
+            return os.path.join(new_root, pathname)
+        else:
+            return os.path.join(new_root, pathname[1:])
+
+    elif os.name == "nt":
+        (drive, path) = os.path.splitdrive(pathname)
+        if path[0] == "\\":
+            path = path[1:]
+        return os.path.join(new_root, path)
+
+    else:
+        raise InstallationError(
+            f"Unknown platform: {os.name}\n"
+            "Can not change root path prefix on unknown platform."
+        )
+
+
+def get_src_prefix() -> str:
     if running_under_virtualenv():
         src_prefix = os.path.join(sys.prefix, "src")
     else:
@@ -43,6 +71,11 @@ def get_src_prefix():
 try:
     # Use getusersitepackages if this is present, as it ensures that the
     # value is initialised properly.
-    user_site = site.getusersitepackages()  # type: typing.Optional[str]
+    user_site: typing.Optional[str] = site.getusersitepackages()
 except AttributeError:
     user_site = site.USER_SITE
+
+
+@functools.lru_cache(maxsize=None)
+def is_osx_framework() -> bool:
+    return bool(sysconfig.get_config_var("PYTHONFRAMEWORK"))
diff --git a/env/Lib/site-packages/pip/_internal/main.py b/env/Lib/site-packages/pip/_internal/main.py
index 51eee158..33c6d24c 100644
--- a/env/Lib/site-packages/pip/_internal/main.py
+++ b/env/Lib/site-packages/pip/_internal/main.py
@@ -1,8 +1,7 @@
 from typing import List, Optional
 
 
-def main(args=None):
-    # type: (Optional[List[str]]) -> int
+def main(args: Optional[List[str]] = None) -> int:
     """This is preserved for old console scripts that may still be referencing
     it.
 
diff --git a/env/Lib/site-packages/pip/_internal/metadata/__init__.py b/env/Lib/site-packages/pip/_internal/metadata/__init__.py
index 63335a19..9f73ca71 100644
--- a/env/Lib/site-packages/pip/_internal/metadata/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/metadata/__init__.py
@@ -1,36 +1,100 @@
-from typing import List, Optional
+import contextlib
+import functools
+import os
+import sys
+from typing import TYPE_CHECKING, List, Optional, Type, cast
 
-from .base import BaseDistribution, BaseEnvironment
+from pip._internal.utils.misc import strtobool
 
+from .base import BaseDistribution, BaseEnvironment, FilesystemWheel, MemoryWheel, Wheel
 
-def get_default_environment():
-    # type: () -> BaseEnvironment
+if TYPE_CHECKING:
+    from typing import Protocol
+else:
+    Protocol = object
+
+__all__ = [
+    "BaseDistribution",
+    "BaseEnvironment",
+    "FilesystemWheel",
+    "MemoryWheel",
+    "Wheel",
+    "get_default_environment",
+    "get_environment",
+    "get_wheel_distribution",
+    "select_backend",
+]
+
+
+def _should_use_importlib_metadata() -> bool:
+    """Whether to use the ``importlib.metadata`` or ``pkg_resources`` backend.
+
+    By default, pip uses ``importlib.metadata`` on Python 3.11+, and
+    ``pkg_resourcess`` otherwise. This can be overridden by a couple of ways:
+
+    * If environment variable ``_PIP_USE_IMPORTLIB_METADATA`` is set, it
+      dictates whether ``importlib.metadata`` is used, regardless of Python
+      version.
+    * On Python 3.11+, Python distributors can patch ``importlib.metadata``
+      to add a global constant ``_PIP_USE_IMPORTLIB_METADATA = False``. This
+      makes pip use ``pkg_resources`` (unless the user set the aforementioned
+      environment variable to *True*).
+    """
+    with contextlib.suppress(KeyError, ValueError):
+        return bool(strtobool(os.environ["_PIP_USE_IMPORTLIB_METADATA"]))
+    if sys.version_info < (3, 11):
+        return False
+    import importlib.metadata
+
+    return bool(getattr(importlib.metadata, "_PIP_USE_IMPORTLIB_METADATA", True))
+
+
+class Backend(Protocol):
+    Distribution: Type[BaseDistribution]
+    Environment: Type[BaseEnvironment]
+
+
+@functools.lru_cache(maxsize=None)
+def select_backend() -> Backend:
+    if _should_use_importlib_metadata():
+        from . import importlib
+
+        return cast(Backend, importlib)
+    from . import pkg_resources
+
+    return cast(Backend, pkg_resources)
+
+
+def get_default_environment() -> BaseEnvironment:
     """Get the default representation for the current environment.
 
     This returns an Environment instance from the chosen backend. The default
     Environment instance should be built from ``sys.path`` and may use caching
     to share instance state accorss calls.
     """
-    from .pkg_resources import Environment
+    return select_backend().Environment.default()
 
-    return Environment.default()
 
-
-def get_environment(paths):
-    # type: (Optional[List[str]]) -> BaseEnvironment
+def get_environment(paths: Optional[List[str]]) -> BaseEnvironment:
     """Get a representation of the environment specified by ``paths``.
 
     This returns an Environment instance from the chosen backend based on the
     given import paths. The backend must build a fresh instance representing
     the state of installed distributions when this function is called.
     """
-    from .pkg_resources import Environment
+    return select_backend().Environment.from_paths(paths)
+
+
+def get_directory_distribution(directory: str) -> BaseDistribution:
+    """Get the distribution metadata representation in the specified directory.
 
-    return Environment.from_paths(paths)
+    This returns a Distribution instance from the chosen backend based on
+    the given on-disk ``.dist-info`` directory.
+    """
+    return select_backend().Distribution.from_directory(directory)
 
 
-def get_wheel_distribution(wheel_path, canonical_name):
-    # type: (str, str) -> BaseDistribution
+def get_wheel_distribution(wheel: Wheel, canonical_name: str) -> BaseDistribution:
     """Get the representation of the specified wheel's distribution metadata.
 
     This returns a Distribution instance from the chosen backend based on
@@ -38,6 +102,26 @@ def get_wheel_distribution(wheel_path, canonical_name):
 
     :param canonical_name: Normalized project name of the given wheel.
     """
-    from .pkg_resources import Distribution
+    return select_backend().Distribution.from_wheel(wheel, canonical_name)
+
 
-    return Distribution.from_wheel(wheel_path, canonical_name)
+def get_metadata_distribution(
+    metadata_contents: bytes,
+    filename: str,
+    canonical_name: str,
+) -> BaseDistribution:
+    """Get the dist representation of the specified METADATA file contents.
+
+    This returns a Distribution instance from the chosen backend sourced from the data
+    in `metadata_contents`.
+
+    :param metadata_contents: Contents of a METADATA file within a dist, or one served
+                              via PEP 658.
+    :param filename: Filename for the dist this metadata represents.
+    :param canonical_name: Normalized project name of the given dist.
+    """
+    return select_backend().Distribution.from_metadata_file_contents(
+        metadata_contents,
+        filename,
+        canonical_name,
+    )
diff --git a/env/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/metadata/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index bea5930d53a0c4717b2f4cfcd5dc5ca87ed994c8..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1753
zcmYe~<>g{vU|^UdaWHj1D+9x05C<7EF)%PVFfcF_+b}RNq%fo~<}l<kMlt3xMKLil
zq%fs0=P>88M6u+uMzJz7q_Cv0wlGAorLd*2w=hJpr*NcjwlG9-q;Lf@XmY;<nXAck
zi^V6ixa1axe?duReqLhEOGX9;22G}00#1p=sV<qtB}JJ@r68$W{2&q6yt2%q{Jh-M
zypm*)0Wb{G1#+A-$Z;Yd$1$cbfgD%Mz{pU;uz+bHLokCTb0Q}r1A}{Ni9$(6szOR?
zT4HHVi9%6oK~ZXPYF<eq$R35X{35V)a%oXfYF>##D#A)VE-nQH1%;4|%wmP2)RNMo
zykdpKJOw02DP-mqmn7yTrz)fs<>x}o$;dBG%~ME9OwLZtOVLvZL0Ano4Xf_rjQrA^
z6osTzg{0EVoDzs>2?@oO#d-yaB^e0`3W<3s3b~1u3Z=!V3dxDd8JT(MVB<>i6^b(w
zi&7CTDK1GYNmWQpPR=hXE>=iR%*iR%11l|JVPIfb$#{z!$qAaww|EP()8mU$i}Op1
zl2eO|I2afhZm~lHtB4(>g`tR>fq~&yv$Iu9XmM&$aZGAXN@h`ve_pCfQD#}Hg04cS
zpJ$kBP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54
zPi9g~ab`)XZb4#lc4B&JaZEvGfqr~uUP)?EUSf`ZZfZ$lN@7W(etdjpUS>&ryk0@&
zE%Ef!l6a`=;*sKt4U`f<9%SI)VJhNfU|>iFB@$SI0VNh@1_lOjf)PVbFpP{0HH-_G
zY8VzWf|HCoG|42QCzSj&aQq_KsZd;ynw*)InVO=IRH=}V0E(*Ogaj%i8-=9A;?xv{
z{5+7A;K)nQEKAK($jmLsFDg+0TLej3&~&DdTUuNKPCO|Ji3({&sl^$H6ai21@I;f5
zssKqQ`DqYkIXS5*3MokWuUMfxBNb$QX0bwAX<jlouVg~fQ)&uQf&wQIP39s_1_lO5
z;^6}2g?O+VHJNU)f*D{La591rJfKv@4~k2q@DxUgLjh16g5nJphoJZa#V|MyC6MEg
ziIJg(2^5Dlj0>5-vB(FFMNr0vdmobFq49`_yYh_G)ExC<6z?m*5+BycR6s7NAOVP{
z41h-_I3htVf<z|F-h>1_P{`|M=B4E)Bq*e07NsVa<QG*!t+pyiEK1B(NKVYl&&y0s
z%!$uS%uTgY@XIgCP0Y!xN=;EHD9X=DO)gOYNhm<Qhhzm(WN9+q;z4#hEZzh`(E*7!
zu&XqgZ*hSc;Ap(XhiZ8dNI4`PK?Oq*I5NdRkqOZQ@(rvUSAfSUCl6DRC<6n7pC;!m
zwvx(%%)Im>Q1ljo;`J5_D8(1Cf)WuZD}!@z5hw|O^&nY>u#v+iH$SB`C)Ey=(ThRl
NmH?9gGY2mRF8~lL`J(^;

diff --git a/env/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/metadata/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index 15d4d9cd43929bb8621359d7e234a9b49100ce51..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5327
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
E0M5M}kN^Mx

diff --git a/env/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/metadata/__pycache__/pkg_resources.cpython-39.pyc
deleted file mode 100644
index cd3d97162b0966eb1f7c5aad8187877a7c799777..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/metadata/base.py b/env/Lib/site-packages/pip/_internal/metadata/base.py
index 37f9a823..cafb79fb 100644
--- a/env/Lib/site-packages/pip/_internal/metadata/base.py
+++ b/env/Lib/site-packages/pip/_internal/metadata/base.py
@@ -1,85 +1,604 @@
+import csv
+import email.message
+import functools
+import json
 import logging
+import pathlib
 import re
-from typing import Container, Iterator, List, Optional, Union
+import zipfile
+from typing import (
+    IO,
+    TYPE_CHECKING,
+    Any,
+    Collection,
+    Container,
+    Dict,
+    Iterable,
+    Iterator,
+    List,
+    NamedTuple,
+    Optional,
+    Tuple,
+    Union,
+)
 
+from pip._vendor.packaging.requirements import Requirement
+from pip._vendor.packaging.specifiers import InvalidSpecifier, SpecifierSet
+from pip._vendor.packaging.utils import NormalizedName
 from pip._vendor.packaging.version import LegacyVersion, Version
 
-from pip._internal.utils.misc import stdlib_pkgs  # TODO: Move definition here.
+from pip._internal.exceptions import NoneMetadataError
+from pip._internal.locations import site_packages, user_site
+from pip._internal.models.direct_url import (
+    DIRECT_URL_METADATA_NAME,
+    DirectUrl,
+    DirectUrlValidationError,
+)
+from pip._internal.utils.compat import stdlib_pkgs  # TODO: Move definition here.
+from pip._internal.utils.egg_link import egg_link_path_from_sys_path
+from pip._internal.utils.misc import is_local, normalize_path
+from pip._internal.utils.packaging import safe_extra
+from pip._internal.utils.urls import url_to_path
+
+from ._json import msg_to_json
+
+if TYPE_CHECKING:
+    from typing import Protocol
+else:
+    Protocol = object
 
 DistributionVersion = Union[LegacyVersion, Version]
 
+InfoPath = Union[str, pathlib.PurePath]
+
 logger = logging.getLogger(__name__)
 
 
-class BaseDistribution:
+class BaseEntryPoint(Protocol):
+    @property
+    def name(self) -> str:
+        raise NotImplementedError()
+
+    @property
+    def value(self) -> str:
+        raise NotImplementedError()
+
+    @property
+    def group(self) -> str:
+        raise NotImplementedError()
+
+
+def _convert_installed_files_path(
+    entry: Tuple[str, ...],
+    info: Tuple[str, ...],
+) -> str:
+    """Convert a legacy installed-files.txt path into modern RECORD path.
+
+    The legacy format stores paths relative to the info directory, while the
+    modern format stores paths relative to the package root, e.g. the
+    site-packages directory.
+
+    :param entry: Path parts of the installed-files.txt entry.
+    :param info: Path parts of the egg-info directory relative to package root.
+    :returns: The converted entry.
+
+    For best compatibility with symlinks, this does not use ``abspath()`` or
+    ``Path.resolve()``, but tries to work with path parts:
+
+    1. While ``entry`` starts with ``..``, remove the equal amounts of parts
+       from ``info``; if ``info`` is empty, start appending ``..`` instead.
+    2. Join the two directly.
+    """
+    while entry and entry[0] == "..":
+        if not info or info[-1] == "..":
+            info += ("..",)
+        else:
+            info = info[:-1]
+        entry = entry[1:]
+    return str(pathlib.Path(*info, *entry))
+
+
+class RequiresEntry(NamedTuple):
+    requirement: str
+    extra: str
+    marker: str
+
+
+class BaseDistribution(Protocol):
+    @classmethod
+    def from_directory(cls, directory: str) -> "BaseDistribution":
+        """Load the distribution from a metadata directory.
+
+        :param directory: Path to a metadata directory, e.g. ``.dist-info``.
+        """
+        raise NotImplementedError()
+
+    @classmethod
+    def from_metadata_file_contents(
+        cls,
+        metadata_contents: bytes,
+        filename: str,
+        project_name: str,
+    ) -> "BaseDistribution":
+        """Load the distribution from the contents of a METADATA file.
+
+        This is used to implement PEP 658 by generating a "shallow" dist object that can
+        be used for resolution without downloading or building the actual dist yet.
+
+        :param metadata_contents: The contents of a METADATA file.
+        :param filename: File name for the dist with this metadata.
+        :param project_name: Name of the project this dist represents.
+        """
+        raise NotImplementedError()
+
+    @classmethod
+    def from_wheel(cls, wheel: "Wheel", name: str) -> "BaseDistribution":
+        """Load the distribution from a given wheel.
+
+        :param wheel: A concrete wheel definition.
+        :param name: File name of the wheel.
+
+        :raises InvalidWheel: Whenever loading of the wheel causes a
+            :py:exc:`zipfile.BadZipFile` exception to be thrown.
+        :raises UnsupportedWheel: If the wheel is a valid zip, but malformed
+            internally.
+        """
+        raise NotImplementedError()
+
+    def __repr__(self) -> str:
+        return f"{self.raw_name} {self.version} ({self.location})"
+
+    def __str__(self) -> str:
+        return f"{self.raw_name} {self.version}"
+
     @property
-    def location(self):
-        # type: () -> Optional[str]
+    def location(self) -> Optional[str]:
         """Where the distribution is loaded from.
 
         A string value is not necessarily a filesystem path, since distributions
         can be loaded from other sources, e.g. arbitrary zip archives. ``None``
         means the distribution is created in-memory.
+
+        Do not canonicalize this value with e.g. ``pathlib.Path.resolve()``. If
+        this is a symbolic link, we want to preserve the relative path between
+        it and files in the distribution.
         """
         raise NotImplementedError()
 
     @property
-    def metadata_version(self):
-        # type: () -> Optional[str]
-        """Value of "Metadata-Version:" in the distribution, if available."""
-        raise NotImplementedError()
+    def editable_project_location(self) -> Optional[str]:
+        """The project location for editable distributions.
+
+        This is the directory where pyproject.toml or setup.py is located.
+        None if the distribution is not installed in editable mode.
+        """
+        # TODO: this property is relatively costly to compute, memoize it ?
+        direct_url = self.direct_url
+        if direct_url:
+            if direct_url.is_local_editable():
+                return url_to_path(direct_url.url)
+        else:
+            # Search for an .egg-link file by walking sys.path, as it was
+            # done before by dist_is_editable().
+            egg_link_path = egg_link_path_from_sys_path(self.raw_name)
+            if egg_link_path:
+                # TODO: get project location from second line of egg_link file
+                #       (https://github.com/pypa/pip/issues/10243)
+                return self.location
+        return None
 
     @property
-    def canonical_name(self):
-        # type: () -> str
+    def installed_location(self) -> Optional[str]:
+        """The distribution's "installed" location.
+
+        This should generally be a ``site-packages`` directory. This is
+        usually ``dist.location``, except for legacy develop-installed packages,
+        where ``dist.location`` is the source code location, and this is where
+        the ``.egg-link`` file is.
+
+        The returned location is normalized (in particular, with symlinks removed).
+        """
         raise NotImplementedError()
 
     @property
-    def version(self):
-        # type: () -> DistributionVersion
+    def info_location(self) -> Optional[str]:
+        """Location of the .[egg|dist]-info directory or file.
+
+        Similarly to ``location``, a string value is not necessarily a
+        filesystem path. ``None`` means the distribution is created in-memory.
+
+        For a modern .dist-info installation on disk, this should be something
+        like ``{location}/{raw_name}-{version}.dist-info``.
+
+        Do not canonicalize this value with e.g. ``pathlib.Path.resolve()``. If
+        this is a symbolic link, we want to preserve the relative path between
+        it and other files in the distribution.
+        """
         raise NotImplementedError()
 
     @property
-    def installer(self):
-        # type: () -> str
+    def installed_by_distutils(self) -> bool:
+        """Whether this distribution is installed with legacy distutils format.
+
+        A distribution installed with "raw" distutils not patched by setuptools
+        uses one single file at ``info_location`` to store metadata. We need to
+        treat this specially on uninstallation.
+        """
+        info_location = self.info_location
+        if not info_location:
+            return False
+        return pathlib.Path(info_location).is_file()
+
+    @property
+    def installed_as_egg(self) -> bool:
+        """Whether this distribution is installed as an egg.
+
+        This usually indicates the distribution was installed by (older versions
+        of) easy_install.
+        """
+        location = self.location
+        if not location:
+            return False
+        return location.endswith(".egg")
+
+    @property
+    def installed_with_setuptools_egg_info(self) -> bool:
+        """Whether this distribution is installed with the ``.egg-info`` format.
+
+        This usually indicates the distribution was installed with setuptools
+        with an old pip version or with ``single-version-externally-managed``.
+
+        Note that this ensure the metadata store is a directory. distutils can
+        also installs an ``.egg-info``, but as a file, not a directory. This
+        property is *False* for that case. Also see ``installed_by_distutils``.
+        """
+        info_location = self.info_location
+        if not info_location:
+            return False
+        if not info_location.endswith(".egg-info"):
+            return False
+        return pathlib.Path(info_location).is_dir()
+
+    @property
+    def installed_with_dist_info(self) -> bool:
+        """Whether this distribution is installed with the "modern format".
+
+        This indicates a "modern" installation, e.g. storing metadata in the
+        ``.dist-info`` directory. This applies to installations made by
+        setuptools (but through pip, not directly), or anything using the
+        standardized build backend interface (PEP 517).
+        """
+        info_location = self.info_location
+        if not info_location:
+            return False
+        if not info_location.endswith(".dist-info"):
+            return False
+        return pathlib.Path(info_location).is_dir()
+
+    @property
+    def canonical_name(self) -> NormalizedName:
         raise NotImplementedError()
 
     @property
-    def editable(self):
-        # type: () -> bool
+    def version(self) -> DistributionVersion:
         raise NotImplementedError()
 
     @property
-    def local(self):
-        # type: () -> bool
+    def setuptools_filename(self) -> str:
+        """Convert a project name to its setuptools-compatible filename.
+
+        This is a copy of ``pkg_resources.to_filename()`` for compatibility.
+        """
+        return self.raw_name.replace("-", "_")
+
+    @property
+    def direct_url(self) -> Optional[DirectUrl]:
+        """Obtain a DirectUrl from this distribution.
+
+        Returns None if the distribution has no `direct_url.json` metadata,
+        or if `direct_url.json` is invalid.
+        """
+        try:
+            content = self.read_text(DIRECT_URL_METADATA_NAME)
+        except FileNotFoundError:
+            return None
+        try:
+            return DirectUrl.from_json(content)
+        except (
+            UnicodeDecodeError,
+            json.JSONDecodeError,
+            DirectUrlValidationError,
+        ) as e:
+            logger.warning(
+                "Error parsing %s for %s: %s",
+                DIRECT_URL_METADATA_NAME,
+                self.canonical_name,
+                e,
+            )
+            return None
+
+    @property
+    def installer(self) -> str:
+        try:
+            installer_text = self.read_text("INSTALLER")
+        except (OSError, ValueError, NoneMetadataError):
+            return ""  # Fail silently if the installer file cannot be read.
+        for line in installer_text.splitlines():
+            cleaned_line = line.strip()
+            if cleaned_line:
+                return cleaned_line
+        return ""
+
+    @property
+    def requested(self) -> bool:
+        return self.is_file("REQUESTED")
+
+    @property
+    def editable(self) -> bool:
+        return bool(self.editable_project_location)
+
+    @property
+    def local(self) -> bool:
+        """If distribution is installed in the current virtual environment.
+
+        Always True if we're not in a virtualenv.
+        """
+        if self.installed_location is None:
+            return False
+        return is_local(self.installed_location)
+
+    @property
+    def in_usersite(self) -> bool:
+        if self.installed_location is None or user_site is None:
+            return False
+        return self.installed_location.startswith(normalize_path(user_site))
+
+    @property
+    def in_site_packages(self) -> bool:
+        if self.installed_location is None or site_packages is None:
+            return False
+        return self.installed_location.startswith(normalize_path(site_packages))
+
+    def is_file(self, path: InfoPath) -> bool:
+        """Check whether an entry in the info directory is a file."""
+        raise NotImplementedError()
+
+    def iter_distutils_script_names(self) -> Iterator[str]:
+        """Find distutils 'scripts' entries metadata.
+
+        If 'scripts' is supplied in ``setup.py``, distutils records those in the
+        installed distribution's ``scripts`` directory, a file for each script.
+        """
+        raise NotImplementedError()
+
+    def read_text(self, path: InfoPath) -> str:
+        """Read a file in the info directory.
+
+        :raise FileNotFoundError: If ``path`` does not exist in the directory.
+        :raise NoneMetadataError: If ``path`` exists in the info directory, but
+            cannot be read.
+        """
+        raise NotImplementedError()
+
+    def iter_entry_points(self) -> Iterable[BaseEntryPoint]:
+        raise NotImplementedError()
+
+    def _metadata_impl(self) -> email.message.Message:
         raise NotImplementedError()
 
+    @functools.lru_cache(maxsize=1)
+    def _metadata_cached(self) -> email.message.Message:
+        # When we drop python 3.7 support, move this to the metadata property and use
+        # functools.cached_property instead of lru_cache.
+        metadata = self._metadata_impl()
+        self._add_egg_info_requires(metadata)
+        return metadata
+
+    @property
+    def metadata(self) -> email.message.Message:
+        """Metadata of distribution parsed from e.g. METADATA or PKG-INFO.
+
+        This should return an empty message if the metadata file is unavailable.
+
+        :raises NoneMetadataError: If the metadata file is available, but does
+            not contain valid metadata.
+        """
+        return self._metadata_cached()
+
+    @property
+    def metadata_dict(self) -> Dict[str, Any]:
+        """PEP 566 compliant JSON-serializable representation of METADATA or PKG-INFO.
+
+        This should return an empty dict if the metadata file is unavailable.
+
+        :raises NoneMetadataError: If the metadata file is available, but does
+            not contain valid metadata.
+        """
+        return msg_to_json(self.metadata)
+
+    @property
+    def metadata_version(self) -> Optional[str]:
+        """Value of "Metadata-Version:" in distribution metadata, if available."""
+        return self.metadata.get("Metadata-Version")
+
+    @property
+    def raw_name(self) -> str:
+        """Value of "Name:" in distribution metadata."""
+        # The metadata should NEVER be missing the Name: key, but if it somehow
+        # does, fall back to the known canonical name.
+        return self.metadata.get("Name", self.canonical_name)
+
     @property
-    def in_usersite(self):
-        # type: () -> bool
+    def requires_python(self) -> SpecifierSet:
+        """Value of "Requires-Python:" in distribution metadata.
+
+        If the key does not exist or contains an invalid value, an empty
+        SpecifierSet should be returned.
+        """
+        value = self.metadata.get("Requires-Python")
+        if value is None:
+            return SpecifierSet()
+        try:
+            # Convert to str to satisfy the type checker; this can be a Header object.
+            spec = SpecifierSet(str(value))
+        except InvalidSpecifier as e:
+            message = "Package %r has an invalid Requires-Python: %s"
+            logger.warning(message, self.raw_name, e)
+            return SpecifierSet()
+        return spec
+
+    def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]:
+        """Dependencies of this distribution.
+
+        For modern .dist-info distributions, this is the collection of
+        "Requires-Dist:" entries in distribution metadata.
+        """
+        raise NotImplementedError()
+
+    def iter_provided_extras(self) -> Iterable[str]:
+        """Extras provided by this distribution.
+
+        For modern .dist-info distributions, this is the collection of
+        "Provides-Extra:" entries in distribution metadata.
+        """
         raise NotImplementedError()
 
+    def _iter_declared_entries_from_record(self) -> Optional[Iterator[str]]:
+        try:
+            text = self.read_text("RECORD")
+        except FileNotFoundError:
+            return None
+        # This extra Path-str cast normalizes entries.
+        return (str(pathlib.Path(row[0])) for row in csv.reader(text.splitlines()))
+
+    def _iter_declared_entries_from_legacy(self) -> Optional[Iterator[str]]:
+        try:
+            text = self.read_text("installed-files.txt")
+        except FileNotFoundError:
+            return None
+        paths = (p for p in text.splitlines(keepends=False) if p)
+        root = self.location
+        info = self.info_location
+        if root is None or info is None:
+            return paths
+        try:
+            info_rel = pathlib.Path(info).relative_to(root)
+        except ValueError:  # info is not relative to root.
+            return paths
+        if not info_rel.parts:  # info *is* root.
+            return paths
+        return (
+            _convert_installed_files_path(pathlib.Path(p).parts, info_rel.parts)
+            for p in paths
+        )
+
+    def iter_declared_entries(self) -> Optional[Iterator[str]]:
+        """Iterate through file entries declared in this distribution.
+
+        For modern .dist-info distributions, this is the files listed in the
+        ``RECORD`` metadata file. For legacy setuptools distributions, this
+        comes from ``installed-files.txt``, with entries normalized to be
+        compatible with the format used by ``RECORD``.
+
+        :return: An iterator for listed entries, or None if the distribution
+            contains neither ``RECORD`` nor ``installed-files.txt``.
+        """
+        return (
+            self._iter_declared_entries_from_record()
+            or self._iter_declared_entries_from_legacy()
+        )
+
+    def _iter_requires_txt_entries(self) -> Iterator[RequiresEntry]:
+        """Parse a ``requires.txt`` in an egg-info directory.
+
+        This is an INI-ish format where an egg-info stores dependencies. A
+        section name describes extra other environment markers, while each entry
+        is an arbitrary string (not a key-value pair) representing a dependency
+        as a requirement string (no markers).
+
+        There is a construct in ``importlib.metadata`` called ``Sectioned`` that
+        does mostly the same, but the format is currently considered private.
+        """
+        try:
+            content = self.read_text("requires.txt")
+        except FileNotFoundError:
+            return
+        extra = marker = ""  # Section-less entries don't have markers.
+        for line in content.splitlines():
+            line = line.strip()
+            if not line or line.startswith("#"):  # Comment; ignored.
+                continue
+            if line.startswith("[") and line.endswith("]"):  # A section header.
+                extra, _, marker = line.strip("[]").partition(":")
+                continue
+            yield RequiresEntry(requirement=line, extra=extra, marker=marker)
+
+    def _iter_egg_info_extras(self) -> Iterable[str]:
+        """Get extras from the egg-info directory."""
+        known_extras = {""}
+        for entry in self._iter_requires_txt_entries():
+            if entry.extra in known_extras:
+                continue
+            known_extras.add(entry.extra)
+            yield entry.extra
+
+    def _iter_egg_info_dependencies(self) -> Iterable[str]:
+        """Get distribution dependencies from the egg-info directory.
+
+        To ease parsing, this converts a legacy dependency entry into a PEP 508
+        requirement string. Like ``_iter_requires_txt_entries()``, there is code
+        in ``importlib.metadata`` that does mostly the same, but not do exactly
+        what we need.
+
+        Namely, ``importlib.metadata`` does not normalize the extra name before
+        putting it into the requirement string, which causes marker comparison
+        to fail because the dist-info format do normalize. This is consistent in
+        all currently available PEP 517 backends, although not standardized.
+        """
+        for entry in self._iter_requires_txt_entries():
+            if entry.extra and entry.marker:
+                marker = f'({entry.marker}) and extra == "{safe_extra(entry.extra)}"'
+            elif entry.extra:
+                marker = f'extra == "{safe_extra(entry.extra)}"'
+            elif entry.marker:
+                marker = entry.marker
+            else:
+                marker = ""
+            if marker:
+                yield f"{entry.requirement} ; {marker}"
+            else:
+                yield entry.requirement
+
+    def _add_egg_info_requires(self, metadata: email.message.Message) -> None:
+        """Add egg-info requires.txt information to the metadata."""
+        if not metadata.get_all("Requires-Dist"):
+            for dep in self._iter_egg_info_dependencies():
+                metadata["Requires-Dist"] = dep
+        if not metadata.get_all("Provides-Extra"):
+            for extra in self._iter_egg_info_extras():
+                metadata["Provides-Extra"] = extra
+
 
 class BaseEnvironment:
     """An environment containing distributions to introspect."""
 
     @classmethod
-    def default(cls):
-        # type: () -> BaseEnvironment
+    def default(cls) -> "BaseEnvironment":
         raise NotImplementedError()
 
     @classmethod
-    def from_paths(cls, paths):
-        # type: (Optional[List[str]]) -> BaseEnvironment
+    def from_paths(cls, paths: Optional[List[str]]) -> "BaseEnvironment":
         raise NotImplementedError()
 
-    def get_distribution(self, name):
-        # type: (str) -> Optional[BaseDistribution]
-        """Given a requirement name, return the installed distributions."""
+    def get_distribution(self, name: str) -> Optional["BaseDistribution"]:
+        """Given a requirement name, return the installed distributions.
+
+        The name may not be normalized. The implementation must canonicalize
+        it for lookup.
+        """
         raise NotImplementedError()
 
-    def _iter_distributions(self):
-        # type: () -> Iterator[BaseDistribution]
+    def _iter_distributions(self) -> Iterator["BaseDistribution"]:
         """Iterate through installed distributions.
 
         This function should be implemented by subclass, but never called
@@ -88,9 +607,8 @@ class BaseEnvironment:
         """
         raise NotImplementedError()
 
-    def iter_distributions(self):
-        # type: () -> Iterator[BaseDistribution]
-        """Iterate through installed distributions."""
+    def iter_all_distributions(self) -> Iterator[BaseDistribution]:
+        """Iterate through all installed distributions without any filtering."""
         for dist in self._iter_distributions():
             # Make sure the distribution actually comes from a valid Python
             # packaging distribution. Pip's AdjacentTempDirectory leaves folders
@@ -112,15 +630,19 @@ class BaseEnvironment:
 
     def iter_installed_distributions(
         self,
-        local_only=True,  # type: bool
-        skip=stdlib_pkgs,  # type: Container[str]
-        include_editables=True,  # type: bool
-        editables_only=False,  # type: bool
-        user_only=False,  # type: bool
-    ):
-        # type: (...) -> Iterator[BaseDistribution]
+        local_only: bool = True,
+        skip: Container[str] = stdlib_pkgs,
+        include_editables: bool = True,
+        editables_only: bool = False,
+        user_only: bool = False,
+    ) -> Iterator[BaseDistribution]:
         """Return a list of installed distributions.
 
+        This is based on ``iter_all_distributions()`` with additional filtering
+        options. Note that ``iter_installed_distributions()`` without arguments
+        is *not* equal to ``iter_all_distributions()``, since some of the
+        configurations exclude packages by default.
+
         :param local_only: If True (default), only return installations
         local to the current virtualenv, if in a virtualenv.
         :param skip: An iterable of canonicalized project names to ignore;
@@ -130,7 +652,7 @@ class BaseEnvironment:
         :param user_only: If True, only report installations in the user
         site directory.
         """
-        it = self.iter_distributions()
+        it = self.iter_all_distributions()
         if local_only:
             it = (d for d in it if d.local)
         if not include_editables:
@@ -140,3 +662,27 @@ class BaseEnvironment:
         if user_only:
             it = (d for d in it if d.in_usersite)
         return (d for d in it if d.canonical_name not in skip)
+
+
+class Wheel(Protocol):
+    location: str
+
+    def as_zipfile(self) -> zipfile.ZipFile:
+        raise NotImplementedError()
+
+
+class FilesystemWheel(Wheel):
+    def __init__(self, location: str) -> None:
+        self.location = location
+
+    def as_zipfile(self) -> zipfile.ZipFile:
+        return zipfile.ZipFile(self.location, allowZip64=True)
+
+
+class MemoryWheel(Wheel):
+    def __init__(self, location: str, stream: IO[bytes]) -> None:
+        self.location = location
+        self.stream = stream
+
+    def as_zipfile(self) -> zipfile.ZipFile:
+        return zipfile.ZipFile(self.stream, allowZip64=True)
diff --git a/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py b/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py
index f39a39eb..f330ef12 100644
--- a/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py
+++ b/env/Lib/site-packages/pip/_internal/metadata/pkg_resources.py
@@ -1,104 +1,253 @@
+import email.message
+import email.parser
+import logging
+import os
 import zipfile
-from typing import Iterator, List, Optional
+from typing import Collection, Iterable, Iterator, List, Mapping, NamedTuple, Optional
 
 from pip._vendor import pkg_resources
-from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.packaging.requirements import Requirement
+from pip._vendor.packaging.utils import NormalizedName, canonicalize_name
 from pip._vendor.packaging.version import parse as parse_version
 
-from pip._internal.utils import misc  # TODO: Move definition here.
-from pip._internal.utils.packaging import get_installer
-from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel
+from pip._internal.exceptions import InvalidWheel, NoneMetadataError, UnsupportedWheel
+from pip._internal.utils.egg_link import egg_link_path_from_location
+from pip._internal.utils.misc import display_path, normalize_path
+from pip._internal.utils.wheel import parse_wheel, read_wheel_metadata_file
 
-from .base import BaseDistribution, BaseEnvironment, DistributionVersion
+from .base import (
+    BaseDistribution,
+    BaseEntryPoint,
+    BaseEnvironment,
+    DistributionVersion,
+    InfoPath,
+    Wheel,
+)
+
+logger = logging.getLogger(__name__)
+
+
+class EntryPoint(NamedTuple):
+    name: str
+    value: str
+    group: str
+
+
+class InMemoryMetadata:
+    """IMetadataProvider that reads metadata files from a dictionary.
+
+    This also maps metadata decoding exceptions to our internal exception type.
+    """
+
+    def __init__(self, metadata: Mapping[str, bytes], wheel_name: str) -> None:
+        self._metadata = metadata
+        self._wheel_name = wheel_name
+
+    def has_metadata(self, name: str) -> bool:
+        return name in self._metadata
+
+    def get_metadata(self, name: str) -> str:
+        try:
+            return self._metadata[name].decode()
+        except UnicodeDecodeError as e:
+            # Augment the default error with the origin of the file.
+            raise UnsupportedWheel(
+                f"Error decoding metadata for {self._wheel_name}: {e} in {name} file"
+            )
+
+    def get_metadata_lines(self, name: str) -> Iterable[str]:
+        return pkg_resources.yield_lines(self.get_metadata(name))
+
+    def metadata_isdir(self, name: str) -> bool:
+        return False
+
+    def metadata_listdir(self, name: str) -> List[str]:
+        return []
+
+    def run_script(self, script_name: str, namespace: str) -> None:
+        pass
 
 
 class Distribution(BaseDistribution):
-    def __init__(self, dist):
-        # type: (pkg_resources.Distribution) -> None
+    def __init__(self, dist: pkg_resources.Distribution) -> None:
         self._dist = dist
 
     @classmethod
-    def from_wheel(cls, path, name):
-        # type: (str, str) -> Distribution
-        with zipfile.ZipFile(path, allowZip64=True) as zf:
-            dist = pkg_resources_distribution_for_wheel(zf, name, path)
+    def from_directory(cls, directory: str) -> BaseDistribution:
+        dist_dir = directory.rstrip(os.sep)
+
+        # Build a PathMetadata object, from path to metadata. :wink:
+        base_dir, dist_dir_name = os.path.split(dist_dir)
+        metadata = pkg_resources.PathMetadata(base_dir, dist_dir)
+
+        # Determine the correct Distribution object type.
+        if dist_dir.endswith(".egg-info"):
+            dist_cls = pkg_resources.Distribution
+            dist_name = os.path.splitext(dist_dir_name)[0]
+        else:
+            assert dist_dir.endswith(".dist-info")
+            dist_cls = pkg_resources.DistInfoDistribution
+            dist_name = os.path.splitext(dist_dir_name)[0].split("-")[0]
+
+        dist = dist_cls(base_dir, project_name=dist_name, metadata=metadata)
+        return cls(dist)
+
+    @classmethod
+    def from_metadata_file_contents(
+        cls,
+        metadata_contents: bytes,
+        filename: str,
+        project_name: str,
+    ) -> BaseDistribution:
+        metadata_dict = {
+            "METADATA": metadata_contents,
+        }
+        dist = pkg_resources.DistInfoDistribution(
+            location=filename,
+            metadata=InMemoryMetadata(metadata_dict, filename),
+            project_name=project_name,
+        )
+        return cls(dist)
+
+    @classmethod
+    def from_wheel(cls, wheel: Wheel, name: str) -> BaseDistribution:
+        try:
+            with wheel.as_zipfile() as zf:
+                info_dir, _ = parse_wheel(zf, name)
+                metadata_dict = {
+                    path.split("/", 1)[-1]: read_wheel_metadata_file(zf, path)
+                    for path in zf.namelist()
+                    if path.startswith(f"{info_dir}/")
+                }
+        except zipfile.BadZipFile as e:
+            raise InvalidWheel(wheel.location, name) from e
+        except UnsupportedWheel as e:
+            raise UnsupportedWheel(f"{name} has an invalid wheel, {e}")
+        dist = pkg_resources.DistInfoDistribution(
+            location=wheel.location,
+            metadata=InMemoryMetadata(metadata_dict, wheel.location),
+            project_name=name,
+        )
         return cls(dist)
 
     @property
-    def location(self):
-        # type: () -> Optional[str]
+    def location(self) -> Optional[str]:
         return self._dist.location
 
     @property
-    def metadata_version(self):
-        # type: () -> Optional[str]
-        for line in self._dist.get_metadata_lines(self._dist.PKG_INFO):
-            if line.lower().startswith("metadata-version:"):
-                return line.split(":", 1)[-1].strip()
-        return None
+    def installed_location(self) -> Optional[str]:
+        egg_link = egg_link_path_from_location(self.raw_name)
+        if egg_link:
+            location = egg_link
+        elif self.location:
+            location = self.location
+        else:
+            return None
+        return normalize_path(location)
 
     @property
-    def canonical_name(self):
-        # type: () -> str
-        return canonicalize_name(self._dist.project_name)
+    def info_location(self) -> Optional[str]:
+        return self._dist.egg_info
 
     @property
-    def version(self):
-        # type: () -> DistributionVersion
-        return parse_version(self._dist.version)
+    def installed_by_distutils(self) -> bool:
+        # A distutils-installed distribution is provided by FileMetadata. This
+        # provider has a "path" attribute not present anywhere else. Not the
+        # best introspection logic, but pip has been doing this for a long time.
+        try:
+            return bool(self._dist._provider.path)
+        except AttributeError:
+            return False
 
     @property
-    def installer(self):
-        # type: () -> str
-        return get_installer(self._dist)
+    def canonical_name(self) -> NormalizedName:
+        return canonicalize_name(self._dist.project_name)
 
     @property
-    def editable(self):
-        # type: () -> bool
-        return misc.dist_is_editable(self._dist)
+    def version(self) -> DistributionVersion:
+        return parse_version(self._dist.version)
 
-    @property
-    def local(self):
-        # type: () -> bool
-        return misc.dist_is_local(self._dist)
+    def is_file(self, path: InfoPath) -> bool:
+        return self._dist.has_metadata(str(path))
 
-    @property
-    def in_usersite(self):
-        # type: () -> bool
-        return misc.dist_in_usersite(self._dist)
+    def iter_distutils_script_names(self) -> Iterator[str]:
+        yield from self._dist.metadata_listdir("scripts")
+
+    def read_text(self, path: InfoPath) -> str:
+        name = str(path)
+        if not self._dist.has_metadata(name):
+            raise FileNotFoundError(name)
+        content = self._dist.get_metadata(name)
+        if content is None:
+            raise NoneMetadataError(self, name)
+        return content
+
+    def iter_entry_points(self) -> Iterable[BaseEntryPoint]:
+        for group, entries in self._dist.get_entry_map().items():
+            for name, entry_point in entries.items():
+                name, _, value = str(entry_point).partition("=")
+                yield EntryPoint(name=name.strip(), value=value.strip(), group=group)
+
+    def _metadata_impl(self) -> email.message.Message:
+        """
+        :raises NoneMetadataError: if the distribution reports `has_metadata()`
+            True but `get_metadata()` returns None.
+        """
+        if isinstance(self._dist, pkg_resources.DistInfoDistribution):
+            metadata_name = "METADATA"
+        else:
+            metadata_name = "PKG-INFO"
+        try:
+            metadata = self.read_text(metadata_name)
+        except FileNotFoundError:
+            if self.location:
+                displaying_path = display_path(self.location)
+            else:
+                displaying_path = repr(self.location)
+            logger.warning("No metadata found in %s", displaying_path)
+            metadata = ""
+        feed_parser = email.parser.FeedParser()
+        feed_parser.feed(metadata)
+        return feed_parser.close()
+
+    def iter_dependencies(self, extras: Collection[str] = ()) -> Iterable[Requirement]:
+        if extras:  # pkg_resources raises on invalid extras, so we sanitize.
+            extras = frozenset(extras).intersection(self._dist.extras)
+        return self._dist.requires(extras)
+
+    def iter_provided_extras(self) -> Iterable[str]:
+        return self._dist.extras
 
 
 class Environment(BaseEnvironment):
-    def __init__(self, ws):
-        # type: (pkg_resources.WorkingSet) -> None
+    def __init__(self, ws: pkg_resources.WorkingSet) -> None:
         self._ws = ws
 
     @classmethod
-    def default(cls):
-        # type: () -> BaseEnvironment
+    def default(cls) -> BaseEnvironment:
         return cls(pkg_resources.working_set)
 
     @classmethod
-    def from_paths(cls, paths):
-        # type: (Optional[List[str]]) -> BaseEnvironment
+    def from_paths(cls, paths: Optional[List[str]]) -> BaseEnvironment:
         return cls(pkg_resources.WorkingSet(paths))
 
-    def _search_distribution(self, name):
-        # type: (str) -> Optional[BaseDistribution]
+    def _iter_distributions(self) -> Iterator[BaseDistribution]:
+        for dist in self._ws:
+            yield Distribution(dist)
+
+    def _search_distribution(self, name: str) -> Optional[BaseDistribution]:
         """Find a distribution matching the ``name`` in the environment.
 
         This searches from *all* distributions available in the environment, to
         match the behavior of ``pkg_resources.get_distribution()``.
         """
         canonical_name = canonicalize_name(name)
-        for dist in self.iter_distributions():
+        for dist in self.iter_all_distributions():
             if dist.canonical_name == canonical_name:
                 return dist
         return None
 
-    def get_distribution(self, name):
-        # type: (str) -> Optional[BaseDistribution]
-
+    def get_distribution(self, name: str) -> Optional[BaseDistribution]:
         # Search the distribution by looking through the working set.
         dist = self._search_distribution(name)
         if dist:
@@ -119,8 +268,3 @@ class Environment(BaseEnvironment):
         except pkg_resources.DistributionNotFound:
             return None
         return self._search_distribution(name)
-
-    def _iter_distributions(self):
-        # type: () -> Iterator[BaseDistribution]
-        for dist in self._ws:
-            yield Distribution(dist)
diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index dcf6e70dd4b33c0f8fc88f364e6993e5bd8bd334..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 288
zcmYe~<>g{vU|^UdaWK`Mfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}U_92E)@
zld}`kQx!@w5=#`4^Ycm)GxLfSa`RJCbBZB?MX3cvsl};zB?_r|C7C6esl|F+ewvK8
z*yH0<@{{A^S27eaF)%=gUyaUIF`>n&Ma40xIVqV%G5&d}E=8GTsS3IZp?;oWu0g?`
zA&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylB
zsk%^i7RMB17U;)k=9Q!t<t66mLma9fAD@|*SrQ+wS5SG2!zMRBr8Fni4&>|4pkM$1
DLO@ik

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/candidate.cpython-39.pyc
deleted file mode 100644
index cfafa5c29d3746c7b5bcc5e4e07212cdcae43d18..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1401
zcmYe~<>g{vU|^UdaWM5IGXuk85C<8vFfcGUFfcF_TQD#%q%fo~<}l<kMlmsh*i1Rh
zxhzpEU^a6OYc5+98zX}|Lkdd@YYRgPYbskaa};|DTQGwr`%93SnvAzt3lfWpQ#BcH
zvG`=>Wot6t67f#0bV@8vO>xf8El4a%_06ov%u5ETM#jug4%ii`3{i|J3{gxej8V+#
z3@J>D7^7I)8PXV2m{V9<IHFinSX0<q7^2ux*i$%K7^2wQ8CV#iID#28Id6%2<`tJD
z=Hw)nWaj5NC+4MOrX-f6R#^t678Ioxr{<LuD<mou<d>x8m1HL7C@3Yvlqe~r<rgVr
zBI(xSQczG(&}6>Fl9!m9dW*d*wWv5VKkpVxPG(+qGAP)fZe{?nK^WwTVlxH?h8o5i
zhIob&#u}z(5R0jXxrQO0xrC*eA&a$!A&a4gA&aSoA&WVUxr8l+u@@ZJ!3>&Aews|T
zn6pzWZ}Fw1re)@3=B39c=Oh*vYqA%yF)%RP;spn8Jk%vc><kPHMI0ar*5cBF)S_D)
z@$s2?nI-Y@MXU@A44N#rSc+3~(!hEVidQn;;*5uw8y~-t;a8KhRZM7cYEf}aYEDXK
zQH+0Hs!LI3S*n7rLa3i-m}^k5XNY64f~TL0zn^Qcr(;a8tFLQth-;97Sxi8HPfVhT
zZccuBW^qYoc1&tsS&UC+QcQ7XNvdu^Vsdt3dTMb@L1uw|d}dxrYEfQdj(%=_N@`BA
zK0M_03Mz|u85kHqxR?(Vrc7*%T#Rf?Y>a%2O#iCnutupK%&W<aAT3Y~VuQTy3`)=<
zpajjh02JDcun=F!3=ZciO&hGHYE&y0)#@l9NKLzyEVtOw@{4j4OEAK*2;|x#K~OA!
z2_aBaaKy(Kr4|&$$4h|R0E#vSCKg7X|G51DQBIye6hTf^fQO}m1~hFbRM#pbmMB!$
zY8DBD+$Rbmz>WkHV3)GT#}}6r#mCE`IaC&F(C9%`YjT2;87ND{$KT?LkI&6dDa}cZ
zkH5teA75CSm;;qzkB?8uPmYfVrM2Rm{F37McyKHiiGf@q4hkt=Xevxj&B=+6M+!%N
zkP?s+!O0ku%8Nl|7zZN@GY1n7HwPP7+)tAuO12=gKrg;5H7_N<NDq?UGV{{)pn*`t
z1Tu&lWS1mZAuJ8*LDHZeC?^+za_ucCRQb}9%$#DVsv=O<2HS|_L_{cZ*g!(S4wUwa
NLGjJQ#KXwL3;=^kWbyz2

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/direct_url.cpython-39.pyc
deleted file mode 100644
index b9a0186dc4d74627482e3280c892f7ab28f87fa7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/format_control.cpython-39.pyc
deleted file mode 100644
index 042aa0e879b593edd2b294db2605eabf3e41cd6d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2558
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
Z13By#hYiI4cA$)13<^aNCLSgpW&pv|aSs3h

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/index.cpython-39.pyc
deleted file mode 100644
index 4c259d1af5dadcee851e9537a750d766df23152f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1211
zcmYe~<>g{vU|^UdaWK_|g@NHQh=Yt-7#J8F7#J9ejTjghQW#Pga~Pr+-5FAtQkYv9
zQka{WqL@;dQdm-0Q`mZ$qL@>eQrJ^Cz-*Qj#$X0b&X*w5{E|T=GG>NyiVYYT7*ZLc
z7*iOcm{J&{n9~_jm=-Zcv9vR!F{Uu5u(WVQv4Tu*VTfXDXJBE7Vh?7}WWU7|keHmE
zn4apHmy%jh<sOt;P?TDnnpaY+kf;EaQUJ>-B<7_k6cpu`Wu~MSE2JhCXQmb@Bqk@P
z78fg&<SV4+r4;06=9Lt4DJUo?XtLg7E-lKr#g>;^l9Qi&i>o*@w;(4q9wf$5P+5=(
zW(lWd=A_0Km*f{Erl-cI<mV=4<|V^C1o9V%4a3Dw3=9k<49yG+7#A`yGSo2EFvK&J
zFlVtWV69<X$e6`e!w}C_!?1uog>fNBjswhQ0<$@5m}(f}xl$N{88n&wZm~gJbBhJ!
z5>4(~ti`1TsYSOq;^Q;(GE3s)i$HeXVk<4m$;nK*#afV9RGfN?qqHcexF9F9qzDw1
zw|GH5h)>HeiZ4hk$tYrFU|=X>0}<>D3=Epgw^)i(bJD;D6@f%nGT!2hk5A4?EG~|Z
zU&-*R&e<v^v^ce>I3_hGC9^2TKQGm#D6=e8L02Kv&oj(5DA+T^F<8OV&&A)*HQ3WJ
zCfL>2H8{jINWm;7AiyUk(L^^VKRvU!Br`iEHLonjCo?IgII|>Gw*V5I#W4k$1^V%s
zc_pbud5Jmtx%nxnImP;!pjg%`s4U`UU|;~@VjfU9GjTDpF$ys9F!Hcgi9%x?9O-(n
zAW3Edse@t=8x#o6p!6&Nj+QLO1xz&zS<E$z3z>o$G#ULgS&BeL7x6MMFx+A<Ey~Ht
z&&&gdhbB`INY5=6aKH(J!VFA^fLQzt3=9$=V?lN>FjYyRx~8-!2Oj2{9H1D>OUzA;
zkH5tgAD^3_Qknx|^Tfv&mL}#vW!U56Q}UDJ<3ZtHoReQt93Kz%eG$m2TfERnNlwkl
ziH|P=I|NJ!f?NZ3638VW-xhN)Ffed1vM_Tn^Y9jdM5_cdN=gcft@QOl2}v)%C|$ow
z43wse^$IFWGV=2>@{3DSQ$P}$jNoKYB?i+`l3HA%htMVs;_Kqj%X*6kk{0#ANf8pT
zAP3xH38)P4yu}fcT3iBRA-Nyy36T45ao9jY#*Psbu6!U*F!M<=F|zz;V+N4`*6uyV

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/link.cpython-39.pyc
deleted file mode 100644
index 05cb7364d3452159544d3bf6f73ba5f3edb1c51a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7215
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
Tk%v))l?OZm!ow_3&yWNF;FOZq

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/scheme.cpython-39.pyc
deleted file mode 100644
index 8b62e151b755803d9720ca204d857e1b6aac09c2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 966
zcmYe~<>g{vU|^UdaWIvMnStRkh=Yuo85kHG7#J9e<ro+kQW&Bb(iu`17coXLx-+CO
zr7*WJq%b!#MKPtY1T$!|R_)?)%P&$WsVqn>R!A%^&QH!vEJ;mKD9<d(P{_<HE=kPE
zNi50C&r>K)&PdHoE!N`#Ye-Z`Pt8j$O3YEnFH0>d%S<g-$WK#9EKAJHNleN~g{f9Z
z%u7)y$w<vCQb^9vD@m;=(NQQ)P36icDJdwn($`PPPcGIgs4U6I&(q5<O4m2mhuW#1
znU|7Up_fsTo1>hVQ<7Sgmspaj3zY;rNRMkJ>n-+zoWzox%%ofF1*Ju)U`9r2VoGXJ
z@h$e^<f6=ilHyw|DTyVC$;crDVl%-)Nrr)eA(bJDF@+(DDTOhLIh7@f6%tNSY>+Uz
z#TE?qdsT^}0)(ZIk)M-NtWc0xl2NQso{^cHp^#XVs!&>-nxc?c4Dzr-QettcLP};)
zYH~?_QD$nfLRx+imx6+VLSj)#W?Eu$31)C7Dg=N-LZKirIXf{uRS&E_nGNJzC<d`X
zE_VjSuMz_TLk(jMLp(zbQw>8rV-0f+Lp)OrOASLja}8?^Lp)0gLokCTqhApt0|SF5
z+bx#j)SR>;kp3c2A}L~FU|=X>1rZ=~S27fFGB7aws&}@E2`x@7Dvn9bNy#jV@y|<j
zDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKL
zF3HS}NzE&Z@ySezDb6fO)rESiIHn-8KtDb+4;-sG`nmZjsX4{^ko2WjP<e|ZK0Y%q
zvm`!V801TEV&`CEgup6(NDSz~)c9$#gEZtN=BCES-{Ojo&&^LM%>l7_;^PZT6LX+4
z?D6p_`N{F|x446yJzRZV<Go!YgKu%h#~0`1mlVgx7jc8affJPg*<HlWz`(!*atSDq
uI2c)2SeU?Kewxfh{2=uLAOfTc9DYayNc$}g8;FbSK#@=k3UU?>4rTz^N(K-B

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/search_scope.cpython-39.pyc
deleted file mode 100644
index 980cbaa7b8aded7542d6bd21504ca764aa9dd1d7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/selection_prefs.cpython-39.pyc
deleted file mode 100644
index c6bc3292e8a33c9ecd1ff1f32ce95f22c0d04374..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1601
zcmYe~<>g{vU|^UdaWHi@I|IXG5C<7EGcYhXFfcF_YcVh|q%fo~<}l<kMlmvi*i1Q0
zxy(__j12A!Da<J>Eet6v%}h}&DXhT^nrtsYrf4$W;_xph$;{77%+X}L#p{+|l$%)M
zoS#=xl%JCfQh|(FV0I}nFfgPtL@}l?L@}i>Mlq)|q%bXFjABV)Phm}AYhjFHO<@UU
z(B!x!5}cZonhY{OpeQvhwJ0?&IkmVdg-by}LBTaIIkBL)G$*knwOFAfBUK?eF)t-E
zC9xz`p%|u1p#Y&xAuYd1Atk>&FDE}SB{MG_Y)E2Wib7^yaY<rMPG(-ZLRw}{YOx+z
zW+m$_p2VD-{POt9#Jud(lv|<@USdv8d_hraQEE<VVsUEmExt6cpW~Aup1#Eku`)g>
zGcU2I@|IX;dR~4}YJ5>@VQFSjYH@r)Wl2VUo||7X8&c4K*h~xz49=jK&|_d=s9{ZE
zEM+L-NnxsGtzoQTh-au_s$qy{tYNNUh-a!{sbPp`u3@cVh-XP*3}(<|PAq3)U~n!<
z1^GTv0b8gk<R@jNCYR`Ofqe%GK&yhpqQqPUh_@h~v{DGqNG-`oErNuELT+MFc4~@3
zVzB~5UO^)>4;<FTsd>ezaFal$<)<kGxCSVgS{i98Bo?JA6r>jAW|owsrYMx;D<mPs
zPBAzlpn(nvYmk1ZYfwYeO2JV9B~3wnp^#ss;Fq75s;3ZI46y+k{3uQWB??4R$WK!!
z&Mz%WPE{yKOwLYBPc2r^SAfJ4LZmz+HBTWqKd-nnrv#QpK&}H}ka3xLDXA3-pj4BS
znU@VsDj-Ry^HCxn5t=3W(3Gf<n5U4RlcJ-LR9d1?mY9<XVuDi&ipx_ni%S&p%TkLJ
z5*6}N%V7=&31fs9_5_AvH$;g-W?piBZb4#6W>OAn+$jY?Q>ShKICUz4oK~7ztdN<f
z0P&}SOKMtTX--KoC^p>^bBa?D?(lOfVr5`p&}6&CQk<HTRs>4SMeGa=3`HCuf)hl5
z3Zaz@MLY})48J;@tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1
z{QX>mJso3$U431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy@V@fuT*
zS)d=EnOBlpl$V&JpPQeOnp3O~PYIyxn^vq>P<e|ZK0Y%qvm`!V7?kh$Kp9e$gOP=a
zjS&K?WU=KWJ(w;{7B@dPKTS4}IeCe>sqyi*xZ>k;^HWN5Ky04)_`=e}9H<O?e0)lN
za(w(P&iMG^ocxmF`1m4_jo>grB6vZ;1u7{)!B`AZ!NJJF%E86J2!_9kKyrSXthd-o
zDho36(u+Xl#x3Q7%mO{Qm-QfC)<exqMWC`CtR2ZZP>d9T?7YQc197<>BPcLHw(v0V
GFarQ}2G1P;

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/target_python.cpython-39.pyc
deleted file mode 100644
index 4f07b5657e4314610b53751575176d986ceb0970..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/models/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index 269f3b7fa5ee1adc13f1fb969e28ed26d3f3f0d7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4213
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
V)Iu!=jWMt=b1;f9@i6f)0{|8gf;|8L

diff --git a/env/Lib/site-packages/pip/_internal/models/candidate.py b/env/Lib/site-packages/pip/_internal/models/candidate.py
index 3b91704a..a4963aec 100644
--- a/env/Lib/site-packages/pip/_internal/models/candidate.py
+++ b/env/Lib/site-packages/pip/_internal/models/candidate.py
@@ -5,30 +5,30 @@ from pip._internal.utils.models import KeyBasedCompareMixin
 
 
 class InstallationCandidate(KeyBasedCompareMixin):
-    """Represents a potential "candidate" for installation.
-    """
+    """Represents a potential "candidate" for installation."""
 
     __slots__ = ["name", "version", "link"]
 
-    def __init__(self, name, version, link):
-        # type: (str, str, Link) -> None
+    def __init__(self, name: str, version: str, link: Link) -> None:
         self.name = name
         self.version = parse_version(version)
         self.link = link
 
         super().__init__(
             key=(self.name, self.version, self.link),
-            defining_class=InstallationCandidate
+            defining_class=InstallationCandidate,
         )
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "<InstallationCandidate({!r}, {!r}, {!r})>".format(
-            self.name, self.version, self.link,
+            self.name,
+            self.version,
+            self.link,
         )
 
-    def __str__(self):
-        # type: () -> str
-        return '{!r} candidate (version {} at {})'.format(
-            self.name, self.version, self.link,
+    def __str__(self) -> str:
+        return "{!r} candidate (version {} at {})".format(
+            self.name,
+            self.version,
+            self.link,
         )
diff --git a/env/Lib/site-packages/pip/_internal/models/direct_url.py b/env/Lib/site-packages/pip/_internal/models/direct_url.py
index 345dbaf1..e219d738 100644
--- a/env/Lib/site-packages/pip/_internal/models/direct_url.py
+++ b/env/Lib/site-packages/pip/_internal/models/direct_url.py
@@ -22,8 +22,9 @@ class DirectUrlValidationError(Exception):
     pass
 
 
-def _get(d, expected_type, key, default=None):
-    # type: (Dict[str, Any], Type[T], str, Optional[T]) -> Optional[T]
+def _get(
+    d: Dict[str, Any], expected_type: Type[T], key: str, default: Optional[T] = None
+) -> Optional[T]:
     """Get value from dictionary and verify expected type."""
     if key not in d:
         return default
@@ -37,16 +38,16 @@ def _get(d, expected_type, key, default=None):
     return value
 
 
-def _get_required(d, expected_type, key, default=None):
-    # type: (Dict[str, Any], Type[T], str, Optional[T]) -> T
+def _get_required(
+    d: Dict[str, Any], expected_type: Type[T], key: str, default: Optional[T] = None
+) -> T:
     value = _get(d, expected_type, key, default)
     if value is None:
         raise DirectUrlValidationError(f"{key} must have a value")
     return value
 
 
-def _exactly_one_of(infos):
-    # type: (Iterable[Optional[InfoType]]) -> InfoType
+def _exactly_one_of(infos: Iterable[Optional["InfoType"]]) -> "InfoType":
     infos = [info for info in infos if info is not None]
     if not infos:
         raise DirectUrlValidationError(
@@ -60,8 +61,7 @@ def _exactly_one_of(infos):
     return infos[0]
 
 
-def _filter_none(**kwargs):
-    # type: (Any) -> Dict[str, Any]
+def _filter_none(**kwargs: Any) -> Dict[str, Any]:
     """Make dict excluding None values."""
     return {k: v for k, v in kwargs.items() if v is not None}
 
@@ -71,39 +71,29 @@ class VcsInfo:
 
     def __init__(
         self,
-        vcs,  # type: str
-        commit_id,  # type: str
-        requested_revision=None,  # type: Optional[str]
-        resolved_revision=None,  # type: Optional[str]
-        resolved_revision_type=None,  # type: Optional[str]
-    ):
+        vcs: str,
+        commit_id: str,
+        requested_revision: Optional[str] = None,
+    ) -> None:
         self.vcs = vcs
         self.requested_revision = requested_revision
         self.commit_id = commit_id
-        self.resolved_revision = resolved_revision
-        self.resolved_revision_type = resolved_revision_type
 
     @classmethod
-    def _from_dict(cls, d):
-        # type: (Optional[Dict[str, Any]]) -> Optional[VcsInfo]
+    def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["VcsInfo"]:
         if d is None:
             return None
         return cls(
             vcs=_get_required(d, str, "vcs"),
             commit_id=_get_required(d, str, "commit_id"),
             requested_revision=_get(d, str, "requested_revision"),
-            resolved_revision=_get(d, str, "resolved_revision"),
-            resolved_revision_type=_get(d, str, "resolved_revision_type"),
         )
 
-    def _to_dict(self):
-        # type: () -> Dict[str, Any]
+    def _to_dict(self) -> Dict[str, Any]:
         return _filter_none(
             vcs=self.vcs,
             requested_revision=self.requested_revision,
             commit_id=self.commit_id,
-            resolved_revision=self.resolved_revision,
-            resolved_revision_type=self.resolved_revision_type,
         )
 
 
@@ -112,20 +102,43 @@ class ArchiveInfo:
 
     def __init__(
         self,
-        hash=None,  # type: Optional[str]
-    ):
+        hash: Optional[str] = None,
+        hashes: Optional[Dict[str, str]] = None,
+    ) -> None:
+        # set hashes before hash, since the hash setter will further populate hashes
+        self.hashes = hashes
         self.hash = hash
 
+    @property
+    def hash(self) -> Optional[str]:
+        return self._hash
+
+    @hash.setter
+    def hash(self, value: Optional[str]) -> None:
+        if value is not None:
+            # Auto-populate the hashes key to upgrade to the new format automatically.
+            # We don't back-populate the legacy hash key from hashes.
+            try:
+                hash_name, hash_value = value.split("=", 1)
+            except ValueError:
+                raise DirectUrlValidationError(
+                    f"invalid archive_info.hash format: {value!r}"
+                )
+            if self.hashes is None:
+                self.hashes = {hash_name: hash_value}
+            elif hash_name not in self.hashes:
+                self.hashes = self.hashes.copy()
+                self.hashes[hash_name] = hash_value
+        self._hash = value
+
     @classmethod
-    def _from_dict(cls, d):
-        # type: (Optional[Dict[str, Any]]) -> Optional[ArchiveInfo]
+    def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["ArchiveInfo"]:
         if d is None:
             return None
-        return cls(hash=_get(d, str, "hash"))
+        return cls(hash=_get(d, str, "hash"), hashes=_get(d, dict, "hashes"))
 
-    def _to_dict(self):
-        # type: () -> Dict[str, Any]
-        return _filter_none(hash=self.hash)
+    def _to_dict(self) -> Dict[str, Any]:
+        return _filter_none(hash=self.hash, hashes=self.hashes)
 
 
 class DirInfo:
@@ -133,21 +146,17 @@ class DirInfo:
 
     def __init__(
         self,
-        editable=False,  # type: bool
-    ):
+        editable: bool = False,
+    ) -> None:
         self.editable = editable
 
     @classmethod
-    def _from_dict(cls, d):
-        # type: (Optional[Dict[str, Any]]) -> Optional[DirInfo]
+    def _from_dict(cls, d: Optional[Dict[str, Any]]) -> Optional["DirInfo"]:
         if d is None:
             return None
-        return cls(
-            editable=_get_required(d, bool, "editable", default=False)
-        )
+        return cls(editable=_get_required(d, bool, "editable", default=False))
 
-    def _to_dict(self):
-        # type: () -> Dict[str, Any]
+    def _to_dict(self) -> Dict[str, Any]:
         return _filter_none(editable=self.editable or None)
 
 
@@ -155,26 +164,24 @@ InfoType = Union[ArchiveInfo, DirInfo, VcsInfo]
 
 
 class DirectUrl:
-
     def __init__(
         self,
-        url,  # type: str
-        info,  # type: InfoType
-        subdirectory=None,  # type: Optional[str]
-    ):
+        url: str,
+        info: InfoType,
+        subdirectory: Optional[str] = None,
+    ) -> None:
         self.url = url
         self.info = info
         self.subdirectory = subdirectory
 
-    def _remove_auth_from_netloc(self, netloc):
-        # type: (str) -> str
+    def _remove_auth_from_netloc(self, netloc: str) -> str:
         if "@" not in netloc:
             return netloc
         user_pass, netloc_no_user_pass = netloc.split("@", 1)
         if (
-            isinstance(self.info, VcsInfo) and
-            self.info.vcs == "git" and
-            user_pass == "git"
+            isinstance(self.info, VcsInfo)
+            and self.info.vcs == "git"
+            and user_pass == "git"
         ):
             return netloc
         if ENV_VAR_RE.match(user_pass):
@@ -182,8 +189,7 @@ class DirectUrl:
         return netloc_no_user_pass
 
     @property
-    def redacted_url(self):
-        # type: () -> str
+    def redacted_url(self) -> str:
         """url with user:password part removed unless it is formed with
         environment variables as specified in PEP 610, or it is ``git``
         in the case of a git URL.
@@ -195,13 +201,11 @@ class DirectUrl:
         )
         return surl
 
-    def validate(self):
-        # type: () -> None
+    def validate(self) -> None:
         self.from_dict(self.to_dict())
 
     @classmethod
-    def from_dict(cls, d):
-        # type: (Dict[str, Any]) -> DirectUrl
+    def from_dict(cls, d: Dict[str, Any]) -> "DirectUrl":
         return DirectUrl(
             url=_get_required(d, str, "url"),
             subdirectory=_get(d, str, "subdirectory"),
@@ -214,8 +218,7 @@ class DirectUrl:
             ),
         )
 
-    def to_dict(self):
-        # type: () -> Dict[str, Any]
+    def to_dict(self) -> Dict[str, Any]:
         res = _filter_none(
             url=self.redacted_url,
             subdirectory=self.subdirectory,
@@ -224,10 +227,11 @@ class DirectUrl:
         return res
 
     @classmethod
-    def from_json(cls, s):
-        # type: (str) -> DirectUrl
+    def from_json(cls, s: str) -> "DirectUrl":
         return cls.from_dict(json.loads(s))
 
-    def to_json(self):
-        # type: () -> str
+    def to_json(self) -> str:
         return json.dumps(self.to_dict(), sort_keys=True)
+
+    def is_local_editable(self) -> bool:
+        return isinstance(self.info, DirInfo) and self.info.editable
diff --git a/env/Lib/site-packages/pip/_internal/models/format_control.py b/env/Lib/site-packages/pip/_internal/models/format_control.py
index cf262af2..db3995ea 100644
--- a/env/Lib/site-packages/pip/_internal/models/format_control.py
+++ b/env/Lib/site-packages/pip/_internal/models/format_control.py
@@ -6,13 +6,15 @@ from pip._internal.exceptions import CommandError
 
 
 class FormatControl:
-    """Helper for managing formats from which a package can be installed.
-    """
+    """Helper for managing formats from which a package can be installed."""
 
     __slots__ = ["no_binary", "only_binary"]
 
-    def __init__(self, no_binary=None, only_binary=None):
-        # type: (Optional[Set[str]], Optional[Set[str]]) -> None
+    def __init__(
+        self,
+        no_binary: Optional[Set[str]] = None,
+        only_binary: Optional[Set[str]] = None,
+    ) -> None:
         if no_binary is None:
             no_binary = set()
         if only_binary is None:
@@ -21,66 +23,58 @@ class FormatControl:
         self.no_binary = no_binary
         self.only_binary = only_binary
 
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         if not isinstance(other, self.__class__):
             return NotImplemented
 
         if self.__slots__ != other.__slots__:
             return False
 
-        return all(
-            getattr(self, k) == getattr(other, k)
-            for k in self.__slots__
-        )
+        return all(getattr(self, k) == getattr(other, k) for k in self.__slots__)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{}({}, {})".format(
-            self.__class__.__name__,
-            self.no_binary,
-            self.only_binary
+            self.__class__.__name__, self.no_binary, self.only_binary
         )
 
     @staticmethod
-    def handle_mutual_excludes(value, target, other):
-        # type: (str, Set[str], Set[str]) -> None
-        if value.startswith('-'):
+    def handle_mutual_excludes(value: str, target: Set[str], other: Set[str]) -> None:
+        if value.startswith("-"):
             raise CommandError(
                 "--no-binary / --only-binary option requires 1 argument."
             )
-        new = value.split(',')
-        while ':all:' in new:
+        new = value.split(",")
+        while ":all:" in new:
             other.clear()
             target.clear()
-            target.add(':all:')
-            del new[:new.index(':all:') + 1]
+            target.add(":all:")
+            del new[: new.index(":all:") + 1]
             # Without a none, we want to discard everything as :all: covers it
-            if ':none:' not in new:
+            if ":none:" not in new:
                 return
         for name in new:
-            if name == ':none:':
+            if name == ":none:":
                 target.clear()
                 continue
             name = canonicalize_name(name)
             other.discard(name)
             target.add(name)
 
-    def get_allowed_formats(self, canonical_name):
-        # type: (str) -> FrozenSet[str]
+    def get_allowed_formats(self, canonical_name: str) -> FrozenSet[str]:
         result = {"binary", "source"}
         if canonical_name in self.only_binary:
-            result.discard('source')
+            result.discard("source")
         elif canonical_name in self.no_binary:
-            result.discard('binary')
-        elif ':all:' in self.only_binary:
-            result.discard('source')
-        elif ':all:' in self.no_binary:
-            result.discard('binary')
+            result.discard("binary")
+        elif ":all:" in self.only_binary:
+            result.discard("source")
+        elif ":all:" in self.no_binary:
+            result.discard("binary")
         return frozenset(result)
 
-    def disallow_binaries(self):
-        # type: () -> None
+    def disallow_binaries(self) -> None:
         self.handle_mutual_excludes(
-            ':all:', self.no_binary, self.only_binary,
+            ":all:",
+            self.no_binary,
+            self.only_binary,
         )
diff --git a/env/Lib/site-packages/pip/_internal/models/index.py b/env/Lib/site-packages/pip/_internal/models/index.py
index b148abb4..b94c3251 100644
--- a/env/Lib/site-packages/pip/_internal/models/index.py
+++ b/env/Lib/site-packages/pip/_internal/models/index.py
@@ -2,33 +2,27 @@ import urllib.parse
 
 
 class PackageIndex:
-    """Represents a Package Index and provides easier access to endpoints
-    """
+    """Represents a Package Index and provides easier access to endpoints"""
 
-    __slots__ = ['url', 'netloc', 'simple_url', 'pypi_url',
-                 'file_storage_domain']
+    __slots__ = ["url", "netloc", "simple_url", "pypi_url", "file_storage_domain"]
 
-    def __init__(self, url, file_storage_domain):
-        # type: (str, str) -> None
+    def __init__(self, url: str, file_storage_domain: str) -> None:
         super().__init__()
         self.url = url
         self.netloc = urllib.parse.urlsplit(url).netloc
-        self.simple_url = self._url_for_path('simple')
-        self.pypi_url = self._url_for_path('pypi')
+        self.simple_url = self._url_for_path("simple")
+        self.pypi_url = self._url_for_path("pypi")
 
         # This is part of a temporary hack used to block installs of PyPI
         # packages which depend on external urls only necessary until PyPI can
         # block such packages themselves
         self.file_storage_domain = file_storage_domain
 
-    def _url_for_path(self, path):
-        # type: (str) -> str
+    def _url_for_path(self, path: str) -> str:
         return urllib.parse.urljoin(self.url, path)
 
 
-PyPI = PackageIndex(
-    'https://pypi.org/', file_storage_domain='files.pythonhosted.org'
-)
+PyPI = PackageIndex("https://pypi.org/", file_storage_domain="files.pythonhosted.org")
 TestPyPI = PackageIndex(
-    'https://test.pypi.org/', file_storage_domain='test-files.pythonhosted.org'
+    "https://test.pypi.org/", file_storage_domain="test-files.pythonhosted.org"
 )
diff --git a/env/Lib/site-packages/pip/_internal/models/link.py b/env/Lib/site-packages/pip/_internal/models/link.py
index 86d0be40..4453519a 100644
--- a/env/Lib/site-packages/pip/_internal/models/link.py
+++ b/env/Lib/site-packages/pip/_internal/models/link.py
@@ -1,12 +1,28 @@
+import functools
+import itertools
+import logging
 import os
 import posixpath
 import re
 import urllib.parse
-from typing import TYPE_CHECKING, Optional, Tuple, Union
+from dataclasses import dataclass
+from typing import (
+    TYPE_CHECKING,
+    Any,
+    Dict,
+    List,
+    Mapping,
+    NamedTuple,
+    Optional,
+    Tuple,
+    Union,
+)
 
+from pip._internal.utils.deprecation import deprecated
 from pip._internal.utils.filetypes import WHEEL_EXTENSION
 from pip._internal.utils.hashes import Hashes
 from pip._internal.utils.misc import (
+    pairwise,
     redact_auth_from_url,
     split_auth_from_netloc,
     splitext,
@@ -15,34 +31,182 @@ from pip._internal.utils.models import KeyBasedCompareMixin
 from pip._internal.utils.urls import path_to_url, url_to_path
 
 if TYPE_CHECKING:
-    from pip._internal.index.collector import HTMLPage
+    from pip._internal.index.collector import IndexContent
 
+logger = logging.getLogger(__name__)
 
-class Link(KeyBasedCompareMixin):
-    """Represents a parsed link from a Package Index's simple URL
+
+# Order matters, earlier hashes have a precedence over later hashes for what
+# we will pick to use.
+_SUPPORTED_HASHES = ("sha512", "sha384", "sha256", "sha224", "sha1", "md5")
+
+
+@dataclass(frozen=True)
+class LinkHash:
+    """Links to content may have embedded hash values. This class parses those.
+
+    `name` must be any member of `_SUPPORTED_HASHES`.
+
+    This class can be converted to and from `ArchiveInfo`. While ArchiveInfo intends to
+    be JSON-serializable to conform to PEP 610, this class contains the logic for
+    parsing a hash name and value for correctness, and then checking whether that hash
+    conforms to a schema with `.is_hash_allowed()`."""
+
+    name: str
+    value: str
+
+    _hash_url_fragment_re = re.compile(
+        # NB: we do not validate that the second group (.*) is a valid hex
+        # digest. Instead, we simply keep that string in this class, and then check it
+        # against Hashes when hash-checking is needed. This is easier to debug than
+        # proactively discarding an invalid hex digest, as we handle incorrect hashes
+        # and malformed hashes in the same place.
+        r"[#&]({choices})=([^&]*)".format(
+            choices="|".join(re.escape(hash_name) for hash_name in _SUPPORTED_HASHES)
+        ),
+    )
+
+    def __post_init__(self) -> None:
+        assert self.name in _SUPPORTED_HASHES
+
+    @classmethod
+    @functools.lru_cache(maxsize=None)
+    def find_hash_url_fragment(cls, url: str) -> Optional["LinkHash"]:
+        """Search a string for a checksum algorithm name and encoded output value."""
+        match = cls._hash_url_fragment_re.search(url)
+        if match is None:
+            return None
+        name, value = match.groups()
+        return cls(name=name, value=value)
+
+    def as_dict(self) -> Dict[str, str]:
+        return {self.name: self.value}
+
+    def as_hashes(self) -> Hashes:
+        """Return a Hashes instance which checks only for the current hash."""
+        return Hashes({self.name: [self.value]})
+
+    def is_hash_allowed(self, hashes: Optional[Hashes]) -> bool:
+        """
+        Return True if the current hash is allowed by `hashes`.
+        """
+        if hashes is None:
+            return False
+        return hashes.is_hash_allowed(self.name, hex_digest=self.value)
+
+
+@dataclass(frozen=True)
+class MetadataFile:
+    """Information about a core metadata file associated with a distribution."""
+
+    hashes: Optional[Dict[str, str]]
+
+    def __post_init__(self) -> None:
+        if self.hashes is not None:
+            assert all(name in _SUPPORTED_HASHES for name in self.hashes)
+
+
+def supported_hashes(hashes: Optional[Dict[str, str]]) -> Optional[Dict[str, str]]:
+    # Remove any unsupported hash types from the mapping. If this leaves no
+    # supported hashes, return None
+    if hashes is None:
+        return None
+    hashes = {n: v for n, v in hashes.items() if n in _SUPPORTED_HASHES}
+    if not hashes:
+        return None
+    return hashes
+
+
+def _clean_url_path_part(part: str) -> str:
     """
+    Clean a "part" of a URL path (i.e. after splitting on "@" characters).
+    """
+    # We unquote prior to quoting to make sure nothing is double quoted.
+    return urllib.parse.quote(urllib.parse.unquote(part))
+
+
+def _clean_file_url_path(part: str) -> str:
+    """
+    Clean the first part of a URL path that corresponds to a local
+    filesystem path (i.e. the first part after splitting on "@" characters).
+    """
+    # We unquote prior to quoting to make sure nothing is double quoted.
+    # Also, on Windows the path part might contain a drive letter which
+    # should not be quoted. On Linux where drive letters do not
+    # exist, the colon should be quoted. We rely on urllib.request
+    # to do the right thing here.
+    return urllib.request.pathname2url(urllib.request.url2pathname(part))
+
+
+# percent-encoded:                   /
+_reserved_chars_re = re.compile("(@|%2F)", re.IGNORECASE)
+
+
+def _clean_url_path(path: str, is_local_path: bool) -> str:
+    """
+    Clean the path portion of a URL.
+    """
+    if is_local_path:
+        clean_func = _clean_file_url_path
+    else:
+        clean_func = _clean_url_path_part
+
+    # Split on the reserved characters prior to cleaning so that
+    # revision strings in VCS URLs are properly preserved.
+    parts = _reserved_chars_re.split(path)
+
+    cleaned_parts = []
+    for to_clean, reserved in pairwise(itertools.chain(parts, [""])):
+        cleaned_parts.append(clean_func(to_clean))
+        # Normalize %xx escapes (e.g. %2f -> %2F)
+        cleaned_parts.append(reserved.upper())
+
+    return "".join(cleaned_parts)
+
+
+def _ensure_quoted_url(url: str) -> str:
+    """
+    Make sure a link is fully quoted.
+    For example, if ' ' occurs in the URL, it will be replaced with "%20",
+    and without double-quoting other characters.
+    """
+    # Split the URL into parts according to the general structure
+    # `scheme://netloc/path;parameters?query#fragment`.
+    result = urllib.parse.urlparse(url)
+    # If the netloc is empty, then the URL refers to a local filesystem path.
+    is_local_path = not result.netloc
+    path = _clean_url_path(result.path, is_local_path=is_local_path)
+    return urllib.parse.urlunparse(result._replace(path=path))
+
+
+class Link(KeyBasedCompareMixin):
+    """Represents a parsed link from a Package Index's simple URL"""
 
     __slots__ = [
         "_parsed_url",
         "_url",
+        "_hashes",
         "comes_from",
         "requires_python",
         "yanked_reason",
+        "metadata_file_data",
         "cache_link_parsing",
+        "egg_fragment",
     ]
 
     def __init__(
         self,
-        url,                   # type: str
-        comes_from=None,       # type: Optional[Union[str, HTMLPage]]
-        requires_python=None,  # type: Optional[str]
-        yanked_reason=None,    # type: Optional[str]
-        cache_link_parsing=True,  # type: bool
-    ):
-        # type: (...) -> None
+        url: str,
+        comes_from: Optional[Union[str, "IndexContent"]] = None,
+        requires_python: Optional[str] = None,
+        yanked_reason: Optional[str] = None,
+        metadata_file_data: Optional[MetadataFile] = None,
+        cache_link_parsing: bool = True,
+        hashes: Optional[Mapping[str, str]] = None,
+    ) -> None:
         """
         :param url: url of the resource pointed to (href of the link)
-        :param comes_from: instance of HTMLPage where the link was found,
+        :param comes_from: instance of IndexContent where the link was found,
             or string.
         :param requires_python: String containing the `Requires-Python`
             metadata field, specified in PEP 345. This may be specified by
@@ -54,15 +218,23 @@ class Link(KeyBasedCompareMixin):
             a simple repository HTML link. If the file has been yanked but
             no reason was provided, this should be the empty string. See
             PEP 592 for more information and the specification.
+        :param metadata_file_data: the metadata attached to the file, or None if
+            no such metadata is provided. This argument, if not None, indicates
+            that a separate metadata file exists, and also optionally supplies
+            hashes for that file.
         :param cache_link_parsing: A flag that is used elsewhere to determine
-                                   whether resources retrieved from this link
-                                   should be cached. PyPI index urls should
-                                   generally have this set to False, for
-                                   example.
+            whether resources retrieved from this link should be cached. PyPI
+            URLs should generally have this set to False, for example.
+        :param hashes: A mapping of hash names to digests to allow us to
+            determine the validity of a download.
         """
 
+        # The comes_from, requires_python, and metadata_file_data arguments are
+        # only used by classmethods of this class, and are not used in client
+        # code directly.
+
         # url can be a UNC windows share
-        if url.startswith('\\\\'):
+        if url.startswith("\\\\"):
             url = path_to_url(url)
 
         self._parsed_url = urllib.parse.urlsplit(url)
@@ -70,39 +242,148 @@ class Link(KeyBasedCompareMixin):
         # trying to set a new value.
         self._url = url
 
+        link_hash = LinkHash.find_hash_url_fragment(url)
+        hashes_from_link = {} if link_hash is None else link_hash.as_dict()
+        if hashes is None:
+            self._hashes = hashes_from_link
+        else:
+            self._hashes = {**hashes, **hashes_from_link}
+
         self.comes_from = comes_from
         self.requires_python = requires_python if requires_python else None
         self.yanked_reason = yanked_reason
+        self.metadata_file_data = metadata_file_data
 
         super().__init__(key=url, defining_class=Link)
 
         self.cache_link_parsing = cache_link_parsing
+        self.egg_fragment = self._egg_fragment()
+
+    @classmethod
+    def from_json(
+        cls,
+        file_data: Dict[str, Any],
+        page_url: str,
+    ) -> Optional["Link"]:
+        """
+        Convert an pypi json document from a simple repository page into a Link.
+        """
+        file_url = file_data.get("url")
+        if file_url is None:
+            return None
 
-    def __str__(self):
-        # type: () -> str
+        url = _ensure_quoted_url(urllib.parse.urljoin(page_url, file_url))
+        pyrequire = file_data.get("requires-python")
+        yanked_reason = file_data.get("yanked")
+        hashes = file_data.get("hashes", {})
+
+        # PEP 714: Indexes must use the name core-metadata, but
+        # clients should support the old name as a fallback for compatibility.
+        metadata_info = file_data.get("core-metadata")
+        if metadata_info is None:
+            metadata_info = file_data.get("dist-info-metadata")
+
+        # The metadata info value may be a boolean, or a dict of hashes.
+        if isinstance(metadata_info, dict):
+            # The file exists, and hashes have been supplied
+            metadata_file_data = MetadataFile(supported_hashes(metadata_info))
+        elif metadata_info:
+            # The file exists, but there are no hashes
+            metadata_file_data = MetadataFile(None)
+        else:
+            # False or not present: the file does not exist
+            metadata_file_data = None
+
+        # The Link.yanked_reason expects an empty string instead of a boolean.
+        if yanked_reason and not isinstance(yanked_reason, str):
+            yanked_reason = ""
+        # The Link.yanked_reason expects None instead of False.
+        elif not yanked_reason:
+            yanked_reason = None
+
+        return cls(
+            url,
+            comes_from=page_url,
+            requires_python=pyrequire,
+            yanked_reason=yanked_reason,
+            hashes=hashes,
+            metadata_file_data=metadata_file_data,
+        )
+
+    @classmethod
+    def from_element(
+        cls,
+        anchor_attribs: Dict[str, Optional[str]],
+        page_url: str,
+        base_url: str,
+    ) -> Optional["Link"]:
+        """
+        Convert an anchor element's attributes in a simple repository page to a Link.
+        """
+        href = anchor_attribs.get("href")
+        if not href:
+            return None
+
+        url = _ensure_quoted_url(urllib.parse.urljoin(base_url, href))
+        pyrequire = anchor_attribs.get("data-requires-python")
+        yanked_reason = anchor_attribs.get("data-yanked")
+
+        # PEP 714: Indexes must use the name data-core-metadata, but
+        # clients should support the old name as a fallback for compatibility.
+        metadata_info = anchor_attribs.get("data-core-metadata")
+        if metadata_info is None:
+            metadata_info = anchor_attribs.get("data-dist-info-metadata")
+        # The metadata info value may be the string "true", or a string of
+        # the form "hashname=hashval"
+        if metadata_info == "true":
+            # The file exists, but there are no hashes
+            metadata_file_data = MetadataFile(None)
+        elif metadata_info is None:
+            # The file does not exist
+            metadata_file_data = None
+        else:
+            # The file exists, and hashes have been supplied
+            hashname, sep, hashval = metadata_info.partition("=")
+            if sep == "=":
+                metadata_file_data = MetadataFile(supported_hashes({hashname: hashval}))
+            else:
+                # Error - data is wrong. Treat as no hashes supplied.
+                logger.debug(
+                    "Index returned invalid data-dist-info-metadata value: %s",
+                    metadata_info,
+                )
+                metadata_file_data = MetadataFile(None)
+
+        return cls(
+            url,
+            comes_from=page_url,
+            requires_python=pyrequire,
+            yanked_reason=yanked_reason,
+            metadata_file_data=metadata_file_data,
+        )
+
+    def __str__(self) -> str:
         if self.requires_python:
-            rp = f' (requires-python:{self.requires_python})'
+            rp = f" (requires-python:{self.requires_python})"
         else:
-            rp = ''
+            rp = ""
         if self.comes_from:
-            return '{} (from {}){}'.format(
-                redact_auth_from_url(self._url), self.comes_from, rp)
+            return "{} (from {}){}".format(
+                redact_auth_from_url(self._url), self.comes_from, rp
+            )
         else:
             return redact_auth_from_url(str(self._url))
 
-    def __repr__(self):
-        # type: () -> str
-        return f'<Link {self}>'
+    def __repr__(self) -> str:
+        return f"<Link {self}>"
 
     @property
-    def url(self):
-        # type: () -> str
+    def url(self) -> str:
         return self._url
 
     @property
-    def filename(self):
-        # type: () -> str
-        path = self.path.rstrip('/')
+    def filename(self) -> str:
+        path = self.path.rstrip("/")
         name = posixpath.basename(path)
         if not name:
             # Make sure we don't leak auth information if the netloc
@@ -111,138 +392,190 @@ class Link(KeyBasedCompareMixin):
             return netloc
 
         name = urllib.parse.unquote(name)
-        assert name, f'URL {self._url!r} produced no filename'
+        assert name, f"URL {self._url!r} produced no filename"
         return name
 
     @property
-    def file_path(self):
-        # type: () -> str
+    def file_path(self) -> str:
         return url_to_path(self.url)
 
     @property
-    def scheme(self):
-        # type: () -> str
+    def scheme(self) -> str:
         return self._parsed_url.scheme
 
     @property
-    def netloc(self):
-        # type: () -> str
+    def netloc(self) -> str:
         """
         This can contain auth information.
         """
         return self._parsed_url.netloc
 
     @property
-    def path(self):
-        # type: () -> str
+    def path(self) -> str:
         return urllib.parse.unquote(self._parsed_url.path)
 
-    def splitext(self):
-        # type: () -> Tuple[str, str]
-        return splitext(posixpath.basename(self.path.rstrip('/')))
+    def splitext(self) -> Tuple[str, str]:
+        return splitext(posixpath.basename(self.path.rstrip("/")))
 
     @property
-    def ext(self):
-        # type: () -> str
+    def ext(self) -> str:
         return self.splitext()[1]
 
     @property
-    def url_without_fragment(self):
-        # type: () -> str
+    def url_without_fragment(self) -> str:
         scheme, netloc, path, query, fragment = self._parsed_url
-        return urllib.parse.urlunsplit((scheme, netloc, path, query, None))
+        return urllib.parse.urlunsplit((scheme, netloc, path, query, ""))
 
-    _egg_fragment_re = re.compile(r'[#&]egg=([^&]*)')
+    _egg_fragment_re = re.compile(r"[#&]egg=([^&]*)")
 
-    @property
-    def egg_fragment(self):
-        # type: () -> Optional[str]
+    # Per PEP 508.
+    _project_name_re = re.compile(
+        r"^([A-Z0-9]|[A-Z0-9][A-Z0-9._-]*[A-Z0-9])$", re.IGNORECASE
+    )
+
+    def _egg_fragment(self) -> Optional[str]:
         match = self._egg_fragment_re.search(self._url)
         if not match:
             return None
-        return match.group(1)
 
-    _subdirectory_fragment_re = re.compile(r'[#&]subdirectory=([^&]*)')
+        # An egg fragment looks like a PEP 508 project name, along with
+        # an optional extras specifier. Anything else is invalid.
+        project_name = match.group(1)
+        if not self._project_name_re.match(project_name):
+            deprecated(
+                reason=f"{self} contains an egg fragment with a non-PEP 508 name",
+                replacement="to use the req @ url syntax, and remove the egg fragment",
+                gone_in="25.0",
+                issue=11617,
+            )
+
+        return project_name
+
+    _subdirectory_fragment_re = re.compile(r"[#&]subdirectory=([^&]*)")
 
     @property
-    def subdirectory_fragment(self):
-        # type: () -> Optional[str]
+    def subdirectory_fragment(self) -> Optional[str]:
         match = self._subdirectory_fragment_re.search(self._url)
         if not match:
             return None
         return match.group(1)
 
-    _hash_re = re.compile(
-        r'(sha1|sha224|sha384|sha256|sha512|md5)=([a-f0-9]+)'
-    )
+    def metadata_link(self) -> Optional["Link"]:
+        """Return a link to the associated core metadata file (if any)."""
+        if self.metadata_file_data is None:
+            return None
+        metadata_url = f"{self.url_without_fragment}.metadata"
+        if self.metadata_file_data.hashes is None:
+            return Link(metadata_url)
+        return Link(metadata_url, hashes=self.metadata_file_data.hashes)
+
+    def as_hashes(self) -> Hashes:
+        return Hashes({k: [v] for k, v in self._hashes.items()})
 
     @property
-    def hash(self):
-        # type: () -> Optional[str]
-        match = self._hash_re.search(self._url)
-        if match:
-            return match.group(2)
-        return None
+    def hash(self) -> Optional[str]:
+        return next(iter(self._hashes.values()), None)
 
     @property
-    def hash_name(self):
-        # type: () -> Optional[str]
-        match = self._hash_re.search(self._url)
-        if match:
-            return match.group(1)
-        return None
+    def hash_name(self) -> Optional[str]:
+        return next(iter(self._hashes), None)
 
     @property
-    def show_url(self):
-        # type: () -> str
-        return posixpath.basename(self._url.split('#', 1)[0].split('?', 1)[0])
+    def show_url(self) -> str:
+        return posixpath.basename(self._url.split("#", 1)[0].split("?", 1)[0])
 
     @property
-    def is_file(self):
-        # type: () -> bool
-        return self.scheme == 'file'
+    def is_file(self) -> bool:
+        return self.scheme == "file"
 
-    def is_existing_dir(self):
-        # type: () -> bool
+    def is_existing_dir(self) -> bool:
         return self.is_file and os.path.isdir(self.file_path)
 
     @property
-    def is_wheel(self):
-        # type: () -> bool
+    def is_wheel(self) -> bool:
         return self.ext == WHEEL_EXTENSION
 
     @property
-    def is_vcs(self):
-        # type: () -> bool
+    def is_vcs(self) -> bool:
         from pip._internal.vcs import vcs
 
         return self.scheme in vcs.all_schemes
 
     @property
-    def is_yanked(self):
-        # type: () -> bool
+    def is_yanked(self) -> bool:
         return self.yanked_reason is not None
 
     @property
-    def has_hash(self):
-        # type: () -> bool
-        return self.hash_name is not None
+    def has_hash(self) -> bool:
+        return bool(self._hashes)
 
-    def is_hash_allowed(self, hashes):
-        # type: (Optional[Hashes]) -> bool
+    def is_hash_allowed(self, hashes: Optional[Hashes]) -> bool:
         """
-        Return True if the link has a hash and it is allowed.
+        Return True if the link has a hash and it is allowed by `hashes`.
         """
-        if hashes is None or not self.has_hash:
+        if hashes is None:
             return False
-        # Assert non-None so mypy knows self.hash_name and self.hash are str.
-        assert self.hash_name is not None
-        assert self.hash is not None
+        return any(hashes.is_hash_allowed(k, v) for k, v in self._hashes.items())
+
+
+class _CleanResult(NamedTuple):
+    """Convert link for equivalency check.
+
+    This is used in the resolver to check whether two URL-specified requirements
+    likely point to the same distribution and can be considered equivalent. This
+    equivalency logic avoids comparing URLs literally, which can be too strict
+    (e.g. "a=1&b=2" vs "b=2&a=1") and produce conflicts unexpecting to users.
+
+    Currently this does three things:
+
+    1. Drop the basic auth part. This is technically wrong since a server can
+       serve different content based on auth, but if it does that, it is even
+       impossible to guarantee two URLs without auth are equivalent, since
+       the user can input different auth information when prompted. So the
+       practical solution is to assume the auth doesn't affect the response.
+    2. Parse the query to avoid the ordering issue. Note that ordering under the
+       same key in the query are NOT cleaned; i.e. "a=1&a=2" and "a=2&a=1" are
+       still considered different.
+    3. Explicitly drop most of the fragment part, except ``subdirectory=`` and
+       hash values, since it should have no impact the downloaded content. Note
+       that this drops the "egg=" part historically used to denote the requested
+       project (and extras), which is wrong in the strictest sense, but too many
+       people are supplying it inconsistently to cause superfluous resolution
+       conflicts, so we choose to also ignore them.
+    """
 
-        return hashes.is_hash_allowed(self.hash_name, hex_digest=self.hash)
+    parsed: urllib.parse.SplitResult
+    query: Dict[str, List[str]]
+    subdirectory: str
+    hashes: Dict[str, str]
+
+
+def _clean_link(link: Link) -> _CleanResult:
+    parsed = link._parsed_url
+    netloc = parsed.netloc.rsplit("@", 1)[-1]
+    # According to RFC 8089, an empty host in file: means localhost.
+    if parsed.scheme == "file" and not netloc:
+        netloc = "localhost"
+    fragment = urllib.parse.parse_qs(parsed.fragment)
+    if "egg" in fragment:
+        logger.debug("Ignoring egg= fragment in %s", link)
+    try:
+        # If there are multiple subdirectory values, use the first one.
+        # This matches the behavior of Link.subdirectory_fragment.
+        subdirectory = fragment["subdirectory"][0]
+    except (IndexError, KeyError):
+        subdirectory = ""
+    # If there are multiple hash values under the same algorithm, use the
+    # first one. This matches the behavior of Link.hash_value.
+    hashes = {k: fragment[k][0] for k in _SUPPORTED_HASHES if k in fragment}
+    return _CleanResult(
+        parsed=parsed._replace(netloc=netloc, query="", fragment=""),
+        query=urllib.parse.parse_qs(parsed.query),
+        subdirectory=subdirectory,
+        hashes=hashes,
+    )
 
 
-# TODO: Relax this comparison logic to ignore, for example, fragments.
-def links_equivalent(link1, link2):
-    # type: (Link, Link) -> bool
-    return link1 == link2
+@functools.lru_cache(maxsize=None)
+def links_equivalent(link1: Link, link2: Link) -> bool:
+    return _clean_link(link1) == _clean_link(link2)
diff --git a/env/Lib/site-packages/pip/_internal/models/scheme.py b/env/Lib/site-packages/pip/_internal/models/scheme.py
index 697cd19b..f51190ac 100644
--- a/env/Lib/site-packages/pip/_internal/models/scheme.py
+++ b/env/Lib/site-packages/pip/_internal/models/scheme.py
@@ -6,7 +6,7 @@ https://docs.python.org/3/install/index.html#alternate-installation.
 """
 
 
-SCHEME_KEYS = ['platlib', 'purelib', 'headers', 'scripts', 'data']
+SCHEME_KEYS = ["platlib", "purelib", "headers", "scripts", "data"]
 
 
 class Scheme:
@@ -18,12 +18,12 @@ class Scheme:
 
     def __init__(
         self,
-        platlib,  # type: str
-        purelib,  # type: str
-        headers,  # type: str
-        scripts,  # type: str
-        data,  # type: str
-    ):
+        platlib: str,
+        purelib: str,
+        headers: str,
+        scripts: str,
+        data: str,
+    ) -> None:
         self.platlib = platlib
         self.purelib = purelib
         self.headers = headers
diff --git a/env/Lib/site-packages/pip/_internal/models/search_scope.py b/env/Lib/site-packages/pip/_internal/models/search_scope.py
index a3f0a5c0..fe61e811 100644
--- a/env/Lib/site-packages/pip/_internal/models/search_scope.py
+++ b/env/Lib/site-packages/pip/_internal/models/search_scope.py
@@ -20,15 +20,15 @@ class SearchScope:
     Encapsulates the locations that pip is configured to search.
     """
 
-    __slots__ = ["find_links", "index_urls"]
+    __slots__ = ["find_links", "index_urls", "no_index"]
 
     @classmethod
     def create(
         cls,
-        find_links,  # type: List[str]
-        index_urls,  # type: List[str]
-    ):
-        # type: (...) -> SearchScope
+        find_links: List[str],
+        index_urls: List[str],
+        no_index: bool,
+    ) -> "SearchScope":
         """
         Create a SearchScope object after normalizing the `find_links`.
         """
@@ -37,9 +37,9 @@ class SearchScope:
         # it and if it exists, use the normalized version.
         # This is deliberately conservative - it might be fine just to
         # blindly normalize anything starting with a ~...
-        built_find_links = []  # type: List[str]
+        built_find_links: List[str] = []
         for link in find_links:
-            if link.startswith('~'):
+            if link.startswith("~"):
                 new_link = normalize_path(link)
                 if os.path.exists(new_link):
                     link = new_link
@@ -50,35 +50,35 @@ class SearchScope:
         if not has_tls():
             for link in itertools.chain(index_urls, built_find_links):
                 parsed = urllib.parse.urlparse(link)
-                if parsed.scheme == 'https':
+                if parsed.scheme == "https":
                     logger.warning(
-                        'pip is configured with locations that require '
-                        'TLS/SSL, however the ssl module in Python is not '
-                        'available.'
+                        "pip is configured with locations that require "
+                        "TLS/SSL, however the ssl module in Python is not "
+                        "available."
                     )
                     break
 
         return cls(
             find_links=built_find_links,
             index_urls=index_urls,
+            no_index=no_index,
         )
 
     def __init__(
         self,
-        find_links,  # type: List[str]
-        index_urls,  # type: List[str]
-    ):
-        # type: (...) -> None
+        find_links: List[str],
+        index_urls: List[str],
+        no_index: bool,
+    ) -> None:
         self.find_links = find_links
         self.index_urls = index_urls
+        self.no_index = no_index
 
-    def get_formatted_locations(self):
-        # type: () -> str
+    def get_formatted_locations(self) -> str:
         lines = []
         redacted_index_urls = []
         if self.index_urls and self.index_urls != [PyPI.simple_url]:
             for url in self.index_urls:
-
                 redacted_index_url = redact_auth_from_url(url)
 
                 # Parse the URL
@@ -91,41 +91,42 @@ class SearchScope:
                 # exceptions for malformed URLs
                 if not purl.scheme and not purl.netloc:
                     logger.warning(
-                        'The index url "%s" seems invalid, '
-                        'please provide a scheme.', redacted_index_url)
+                        'The index url "%s" seems invalid, please provide a scheme.',
+                        redacted_index_url,
+                    )
 
                 redacted_index_urls.append(redacted_index_url)
 
-            lines.append('Looking in indexes: {}'.format(
-                ', '.join(redacted_index_urls)))
+            lines.append(
+                "Looking in indexes: {}".format(", ".join(redacted_index_urls))
+            )
 
         if self.find_links:
             lines.append(
-                'Looking in links: {}'.format(', '.join(
-                    redact_auth_from_url(url) for url in self.find_links))
+                "Looking in links: {}".format(
+                    ", ".join(redact_auth_from_url(url) for url in self.find_links)
+                )
             )
-        return '\n'.join(lines)
+        return "\n".join(lines)
 
-    def get_index_urls_locations(self, project_name):
-        # type: (str) -> List[str]
+    def get_index_urls_locations(self, project_name: str) -> List[str]:
         """Returns the locations found via self.index_urls
 
         Checks the url_name on the main (first in the list) index and
         use this url_name to produce all locations
         """
 
-        def mkurl_pypi_url(url):
-            # type: (str) -> str
+        def mkurl_pypi_url(url: str) -> str:
             loc = posixpath.join(
-                url,
-                urllib.parse.quote(canonicalize_name(project_name)))
+                url, urllib.parse.quote(canonicalize_name(project_name))
+            )
             # For maximum compatibility with easy_install, ensure the path
             # ends in a trailing slash.  Although this isn't in the spec
             # (and PyPI can handle it without the slash) some other index
             # implementations might break if they relied on easy_install's
             # behavior.
-            if not loc.endswith('/'):
-                loc = loc + '/'
+            if not loc.endswith("/"):
+                loc = loc + "/"
             return loc
 
         return [mkurl_pypi_url(url) for url in self.index_urls]
diff --git a/env/Lib/site-packages/pip/_internal/models/selection_prefs.py b/env/Lib/site-packages/pip/_internal/models/selection_prefs.py
index edc1cf79..977bc4ca 100644
--- a/env/Lib/site-packages/pip/_internal/models/selection_prefs.py
+++ b/env/Lib/site-packages/pip/_internal/models/selection_prefs.py
@@ -9,8 +9,13 @@ class SelectionPreferences:
     and installing files.
     """
 
-    __slots__ = ['allow_yanked', 'allow_all_prereleases', 'format_control',
-                 'prefer_binary', 'ignore_requires_python']
+    __slots__ = [
+        "allow_yanked",
+        "allow_all_prereleases",
+        "format_control",
+        "prefer_binary",
+        "ignore_requires_python",
+    ]
 
     # Don't include an allow_yanked default value to make sure each call
     # site considers whether yanked releases are allowed. This also causes
@@ -18,13 +23,12 @@ class SelectionPreferences:
     # people when reading the code.
     def __init__(
         self,
-        allow_yanked,  # type: bool
-        allow_all_prereleases=False,  # type: bool
-        format_control=None,          # type: Optional[FormatControl]
-        prefer_binary=False,          # type: bool
-        ignore_requires_python=None,  # type: Optional[bool]
-    ):
-        # type: (...) -> None
+        allow_yanked: bool,
+        allow_all_prereleases: bool = False,
+        format_control: Optional[FormatControl] = None,
+        prefer_binary: bool = False,
+        ignore_requires_python: Optional[bool] = None,
+    ) -> None:
         """Create a SelectionPreferences object.
 
         :param allow_yanked: Whether files marked as yanked (in the sense
diff --git a/env/Lib/site-packages/pip/_internal/models/target_python.py b/env/Lib/site-packages/pip/_internal/models/target_python.py
index b91e349f..744bd7ef 100644
--- a/env/Lib/site-packages/pip/_internal/models/target_python.py
+++ b/env/Lib/site-packages/pip/_internal/models/target_python.py
@@ -26,12 +26,11 @@ class TargetPython:
 
     def __init__(
         self,
-        platforms=None,  # type: Optional[List[str]]
-        py_version_info=None,  # type: Optional[Tuple[int, ...]]
-        abis=None,  # type: Optional[List[str]]
-        implementation=None,  # type: Optional[str]
-    ):
-        # type: (...) -> None
+        platforms: Optional[List[str]] = None,
+        py_version_info: Optional[Tuple[int, ...]] = None,
+        abis: Optional[List[str]] = None,
+        implementation: Optional[str] = None,
+    ) -> None:
         """
         :param platforms: A list of strings or None. If None, searches for
             packages that are supported by the current system. Otherwise, will
@@ -54,7 +53,7 @@ class TargetPython:
         else:
             py_version_info = normalize_version_info(py_version_info)
 
-        py_version = '.'.join(map(str, py_version_info[:2]))
+        py_version = ".".join(map(str, py_version_info[:2]))
 
         self.abis = abis
         self.implementation = implementation
@@ -63,32 +62,29 @@ class TargetPython:
         self.py_version_info = py_version_info
 
         # This is used to cache the return value of get_tags().
-        self._valid_tags = None  # type: Optional[List[Tag]]
+        self._valid_tags: Optional[List[Tag]] = None
 
-    def format_given(self):
-        # type: () -> str
+    def format_given(self) -> str:
         """
         Format the given, non-None attributes for display.
         """
         display_version = None
         if self._given_py_version_info is not None:
-            display_version = '.'.join(
+            display_version = ".".join(
                 str(part) for part in self._given_py_version_info
             )
 
         key_values = [
-            ('platforms', self.platforms),
-            ('version_info', display_version),
-            ('abis', self.abis),
-            ('implementation', self.implementation),
+            ("platforms", self.platforms),
+            ("version_info", display_version),
+            ("abis", self.abis),
+            ("implementation", self.implementation),
         ]
-        return ' '.join(
-            f'{key}={value!r}' for key, value in key_values
-            if value is not None
+        return " ".join(
+            f"{key}={value!r}" for key, value in key_values if value is not None
         )
 
-    def get_tags(self):
-        # type: () -> List[Tag]
+    def get_tags(self) -> List[Tag]:
         """
         Return the supported PEP 425 tags to check wheel candidates against.
 
diff --git a/env/Lib/site-packages/pip/_internal/models/wheel.py b/env/Lib/site-packages/pip/_internal/models/wheel.py
index 0a582b30..a5dc12bd 100644
--- a/env/Lib/site-packages/pip/_internal/models/wheel.py
+++ b/env/Lib/site-packages/pip/_internal/models/wheel.py
@@ -13,45 +13,39 @@ class Wheel:
     """A wheel file"""
 
     wheel_file_re = re.compile(
-        r"""^(?P<namever>(?P<name>.+?)-(?P<ver>.*?))
-        ((-(?P<build>\d[^-]*?))?-(?P<pyver>.+?)-(?P<abi>.+?)-(?P<plat>.+?)
+        r"""^(?P<namever>(?P<name>[^\s-]+?)-(?P<ver>[^\s-]*?))
+        ((-(?P<build>\d[^-]*?))?-(?P<pyver>[^\s-]+?)-(?P<abi>[^\s-]+?)-(?P<plat>[^\s-]+?)
         \.whl|\.dist-info)$""",
-        re.VERBOSE
+        re.VERBOSE,
     )
 
-    def __init__(self, filename):
-        # type: (str) -> None
+    def __init__(self, filename: str) -> None:
         """
         :raises InvalidWheelFilename: when the filename is invalid for a wheel
         """
         wheel_info = self.wheel_file_re.match(filename)
         if not wheel_info:
-            raise InvalidWheelFilename(
-                f"{filename} is not a valid wheel filename."
-            )
+            raise InvalidWheelFilename(f"{filename} is not a valid wheel filename.")
         self.filename = filename
-        self.name = wheel_info.group('name').replace('_', '-')
+        self.name = wheel_info.group("name").replace("_", "-")
         # we'll assume "_" means "-" due to wheel naming scheme
         # (https://github.com/pypa/pip/issues/1150)
-        self.version = wheel_info.group('ver').replace('_', '-')
-        self.build_tag = wheel_info.group('build')
-        self.pyversions = wheel_info.group('pyver').split('.')
-        self.abis = wheel_info.group('abi').split('.')
-        self.plats = wheel_info.group('plat').split('.')
+        self.version = wheel_info.group("ver").replace("_", "-")
+        self.build_tag = wheel_info.group("build")
+        self.pyversions = wheel_info.group("pyver").split(".")
+        self.abis = wheel_info.group("abi").split(".")
+        self.plats = wheel_info.group("plat").split(".")
 
         # All the tag combinations from this file
         self.file_tags = {
-            Tag(x, y, z) for x in self.pyversions
-            for y in self.abis for z in self.plats
+            Tag(x, y, z) for x in self.pyversions for y in self.abis for z in self.plats
         }
 
-    def get_formatted_file_tags(self):
-        # type: () -> List[str]
+    def get_formatted_file_tags(self) -> List[str]:
         """Return the wheel's tags as a sorted list of strings."""
         return sorted(str(tag) for tag in self.file_tags)
 
-    def support_index_min(self, tags):
-        # type: (List[Tag]) -> int
+    def support_index_min(self, tags: List[Tag]) -> int:
         """Return the lowest index that one of the wheel's file_tag combinations
         achieves in the given list of supported tags.
 
@@ -64,12 +58,16 @@ class Wheel:
         :raises ValueError: If none of the wheel's file tags match one of
             the supported tags.
         """
-        return min(tags.index(tag) for tag in self.file_tags if tag in tags)
-
-    def find_most_preferred_tag(self, tags, tag_to_priority):
-        # type: (List[Tag], Dict[Tag, int]) -> int
+        try:
+            return next(i for i, t in enumerate(tags) if t in self.file_tags)
+        except StopIteration:
+            raise ValueError()
+
+    def find_most_preferred_tag(
+        self, tags: List[Tag], tag_to_priority: Dict[Tag, int]
+    ) -> int:
         """Return the priority of the most preferred tag that one of the wheel's file
-        tag combinations acheives in the given list of supported tags using the given
+        tag combinations achieves in the given list of supported tags using the given
         tag_to_priority mapping, where lower priorities are more-preferred.
 
         This is used in place of support_index_min in some cases in order to avoid
@@ -86,8 +84,7 @@ class Wheel:
             tag_to_priority[tag] for tag in self.file_tags if tag in tag_to_priority
         )
 
-    def supported(self, tags):
-        # type: (Iterable[Tag]) -> bool
+    def supported(self, tags: Iterable[Tag]) -> bool:
         """Return whether the wheel is compatible with one of the given tags.
 
         :param tags: the PEP 425 tags to check the wheel against.
diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index f3ee8b34fc4cf8f48df3d0a0ba2be58f2a0dc881..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 276
zcmYe~<>g{vU|^UdaWK`0fq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}Wjo%8cb
z5;OCP6$(m=QgbR5@={C6^NX@|i&AqEOHxx5N=q_xGD|X3i}kqtG#PKP$H%ASC&$OH
zWGG@{V1N+6nw+g-LW@(2iepl9QZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0
zT!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-cvlG)(
yi(?8h3-seN^GZ^S@)C3Op>EWVkI&4@EQycTE2zB1VUwGmQks)$2lDA>kk<iqDp1}4

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/auth.cpython-39.pyc
deleted file mode 100644
index 82ccc78d38e85aa7e23215159a1ab3a616e04a29..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/cache.cpython-39.pyc
deleted file mode 100644
index 26477c940f26ab4fbb0d679f7343d240d9a22075..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2755
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
PCILnsW)4;+MlNmu!SIE9

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/download.cpython-39.pyc
deleted file mode 100644
index 957193870cd2e7c0f55c2abd9650e129da0bf881..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5115
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
Xj3P{2%p4pXIvgAv{2US-9DIrZr@asT

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/lazy_wheel.cpython-39.pyc
deleted file mode 100644
index e362245d91698f9c1799de1f3559ba70b9251bb5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7940
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
OU@XGO!z{qUAp`&l6vw>)

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/session.cpython-39.pyc
deleted file mode 100644
index 4cc899614a1af82e99e45cee9f7293d508f21c37..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9523
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
E0KfPUw*UYD

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/utils.cpython-39.pyc
deleted file mode 100644
index bb437df66b90ddb6c559a84ca5c5ace45dc195d0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1342
zcmYe~<>g{vU|^UdaWM4-KLf*K5C<7EGcYhXFfcF_`!Fytq%fo~<}l<kMlt3xMKLjg
z_)Iy>xhzpExvWvFU_NsWTP}MPJ0n91OA2cyV-!aUTMBy%LlkE!OB!PeM+#>PV-!~k
zS1^Mn_e+pHnoPG?Tr!hOZgF^)q!uNX<QHi&-4b&4_X~0L3yF932=()h5B7|5y~Pof
zT3nEySDdQJcuUMLwWK`1DBC$dFE2H@Br`wHwWuh+sEXe)IXShUMAtPhIX@*cFZ~ur
zW=d*aNoGl9G9$<`C<gh7gMop;8RV}+Ab&B|GL|sZFk~^7Ff}t3IaLXO*bA6bm=-eD
zGKDh~day8*uvFSHGJqgdju|8u$x!HFz>voV602oOVX0xrVr5}qX2@nNic4Y5W+<x3
zV_{^-lLCp)W=LVHVVcd5!d}CW#WtH^E^94go>2-bNDiuJQVK^lL(w|09tn{6Y=#t0
zbUihUMf*zFYZz-7Qn-4Vnix|UK%wb(i=m3Ov?NW}qKYfCIA7Po!qigNFmnPU14HH)
zMh1o|eg)^8%+$OR1#nndDO7POq~#YWlosV!DP%@4fmH;j7L}zI!Bl86-r^{Ng*wMA
zuFT@hyyB9?yyVndY(=Sw#rb)+Sd%JCQj2e~rKBe3r=;Ez3eC#|F<ii0utm4Hi%Swq
zN{iz`;<uPfi*kzC7#J8dnQyUx%)Z5!QBqP6p9+e<_}t?3B5no-hLsFO!VC-yzv`W>
zVnT~ki;81Xb5b&kV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?
zT!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$MGxJJP
zi}Dh4^z$IeO24!uGpAUupz@YLQDSCsYJ6ILQ9Q&KvY;d*2TDgwEQ~y?OpF4IJd7et
zY)n#2V*go~K_nA13uBQe0|P@c6G$Bt!_r(b$bcXQ28Jqy8ip)}EXEqf6vh;$UM3fY
zSgu;88m2G?MutM6aE3e`7KRe0N*_>)V+5s5h6T(ujG#1E!&K~0=mAx!7s-&vWWbQZ
z9L%7}Qf1+uS(ciokf>0UT3DJ|TvDt6%QZR*1x5K~nJK9XB^jv-DTyVC3dtFzdD+E!
zTnY*b3T~Q=xA-8D7@wS<SCX1n;-|@Si@7MV{1#hrNl|KI?kzsYl9Hm#q|%a9NW`)f
zr6#6mG8b_&FfiQW0-F|JoLQB6ixtcUM<Ij|0jb~zMK>q|$AhJdEkGe51_~Y)CMGsU
zCUK@0Tv9xYJj^_dER0NyMWCSe)8xLzR#I7znU`J!3e6%=Fh)riWESYfm!;;V<QM6|
ze5#k5pOTtWT*Sh_z)-{rvQPr73>LY1sTH8IAu~U(7@Poav3s~Wy0``fgX0Qp8^p1o
jlm}sfoy}pBo1apelWGSlL5e|zr2vxv6OSkdGlw()nU!PF

diff --git a/env/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/network/__pycache__/xmlrpc.cpython-39.pyc
deleted file mode 100644
index d8acfbb5f179a9f877350bb380761b33f51769b6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1921
zcmYe~<>g{vU|^UdaWHi`8w0~*5C<8vFfcGUFfcF_w=pm<q%cG=q%fv1<uFDuf@!8G
zW-!eX#hSvH!kojF%O1s^%Mr!F2vWzA!<ow!#RX=w=5XioMDc*xY&pESd{KOi45{oz
zDJhI8>^UsC{89Y50#O2t45^F@1XG0;GDZozGo)~&aJDd{aHg_miDZd3Ge?P~Fa<Mc
za#bl;<mMC=B<Ex%>4g*}<`oy@7nLYv<`(3n=BDPAB$j06=W)FRdBabW=@xHDWPoeD
zvxlp*x2K=`E!L3If}B)M##>^3sU_w4McK~zd3mYHAU&={MfpXVjJLP~G7ExJi;FY!
z^E4T62^1w}7N^Fi<rl>lmn4>y7Hcxy;*9smFD?nGEJ(e@8}FM~RGg8RlarW~lbQ^&
z6&Zs95X3LmVPIfLWr$)-VTfW%VT@u<VQ*(hV@zRAVQJxvVoBjhVNGFcVT@vJXJBE7
zVhd)_<h&&mkXaA`_9@(#RY3to`DK|YsS1e-30OiQ0WBC5$}$r{N)bLv;8IXfP{>cp
zN=+`&1GC+dVU7ejl$C*jff<U6wHO!}N*J0M7BJQ@FJxq7C}GNCUcgerxR9}yrG_Po
zwT2;{t%j+FA)Y;jA(%mv(NB}(7He^7L2A)0j`;Y@yv&mL_*-nHML9W{Nw-)F5{rsc
zZ*i0s<v>_$#mO0|xv96<<Dm?W_+n_Vv)*DUPR&WX#hICxl3Ed8T9k8(9V&N=r?faV
zJ|(dvwInk)HHsUeq9C!Tq<AIcEzbD(<ebFf;`sQL48IzjtztrpQ;UjYQgc!=i(>rq
zQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1{QX>mJso3$U431HLtKLt%whrpd}0z!baV34
zGmA?yvtv^8%3^#nlVXZ9OHy?U5|gtN(^HFM3Nj1y<1_P0Qj78ubM*5dDM}v_F?t1+
zMcfPw3=*LH!vP9gCLTr}Mh?a*Y0QY#g9TSIC;~u=K^T-dLD(5&#2Rp9)G(GXHZv9T
zc`-CG)-Yr-)iBmDr7(bC8e1)E33C?90@fPVg^aaqRTiMknaNnoUc->Zmc?GfR>NGw
z4oY#oEVUdZ95o!xjEoF5EHw=AoHYy!xN11ExEC^pGXyiRFqH6AE@Nb<<z!^2(yHOi
z;w`QN*;m51fIo#5#Lp6_VOz+|$k4<P&Jf9v!cfau$C<|kp$!-e7{JMa&992bIX|x?
zHLpY$lvk=aN>VFIK%o<&$$X0?C9x#&7JEi&VoGXJ@h!IElA_ea+$uSbkdOd{R8Uq_
zP%Ty{&&bS4RY*@QDap)BS5Ph16uiZiS)7?yT#}fVoO+A7xTL5^fPsObhzCUQGB7aQ
z;wml5Da`{Xu_8f`082rBaY+#yh{;}-T9lMuoO+87EFWK#T3nEySDbo_xhS!`2$T<Q
zalpmca`MyDK}k8eD6=FpIWgxJH>3oJPtH$C)#NG?0vXAYkzZVLi#;PTFC{0n=oU{=
zYGG+=aY=kqeoAGLB1i=&;g=NOVlFMpDUt>`Qw1c-oLZ4w1WFqaLJ}m#4%I9Vif@oA
z1|~j6Ax0iXCPofME=HFBY)l-CY>a%2d>|f3^dAdLl@ylb1T{#L(G7&yLD?}cF*h|n
z{uWn!d~SY9X%2|Z6CYn#nwSHXVULeb$xn`t2dCO1J&=QVq1h=pH76%N9^z84o5eu>
z0J*t{lYxOj802110CO<1u<)^i#Wcl>j6g=PgF-PgFZ~t|q#V!#hdemGZt+5MN^(wS
zYF<ec8-#m{t)#LbGcUb}31kVVFuEmCkXfJy&uDt770Iaupdz~%5@)ig($IXU2Q4v*
zKw0XRG<G$mC7C(J;KWhH4zdoEQEzdkr<VADBfm%=B&Z7V2phzew>aUYG1#9-fdUR0
kP@vr6uz`fJ9U~}YK!L@=%)tnP0^mY`hlzzzfQgG40Qk)vM*si-

diff --git a/env/Lib/site-packages/pip/_internal/network/auth.py b/env/Lib/site-packages/pip/_internal/network/auth.py
index bd54a5cb..94a82fa6 100644
--- a/env/Lib/site-packages/pip/_internal/network/auth.py
+++ b/env/Lib/site-packages/pip/_internal/network/auth.py
@@ -3,15 +3,24 @@
 Contains interface (MultiDomainBasicAuth) and associated glue code for
 providing credentials in the context of network requests.
 """
-
 import logging
+import os
+import shutil
+import subprocess
+import sysconfig
+import typing
 import urllib.parse
-from typing import Any, Dict, List, Optional, Tuple
+from abc import ABC, abstractmethod
+from functools import lru_cache
+from os.path import commonprefix
+from pathlib import Path
+from typing import Any, Dict, List, NamedTuple, Optional, Tuple
 
 from pip._vendor.requests.auth import AuthBase, HTTPBasicAuth
 from pip._vendor.requests.models import Request, Response
 from pip._vendor.requests.utils import get_netrc_auth
 
+from pip._internal.utils.logging import getLogger
 from pip._internal.utils.misc import (
     ask,
     ask_input,
@@ -21,70 +30,256 @@ from pip._internal.utils.misc import (
 )
 from pip._internal.vcs.versioncontrol import AuthInfo
 
-logger = logging.getLogger(__name__)
+logger = getLogger(__name__)
+
+KEYRING_DISABLED = False
+
+
+class Credentials(NamedTuple):
+    url: str
+    username: str
+    password: str
+
+
+class KeyRingBaseProvider(ABC):
+    """Keyring base provider interface"""
+
+    has_keyring: bool
+
+    @abstractmethod
+    def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]:
+        ...
+
+    @abstractmethod
+    def save_auth_info(self, url: str, username: str, password: str) -> None:
+        ...
 
-Credentials = Tuple[str, str, str]
 
-try:
-    import keyring
-except ImportError:
-    keyring = None
-except Exception as exc:
-    logger.warning(
-        "Keyring is skipped due to an exception: %s", str(exc),
-    )
-    keyring = None
+class KeyRingNullProvider(KeyRingBaseProvider):
+    """Keyring null provider"""
 
+    has_keyring = False
 
-def get_keyring_auth(url, username):
-    # type: (Optional[str], Optional[str]) -> Optional[AuthInfo]
-    """Return the tuple auth for a given url from keyring."""
-    global keyring
-    if not url or not keyring:
+    def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]:
         return None
 
-    try:
-        try:
-            get_credential = keyring.get_credential
-        except AttributeError:
-            pass
-        else:
+    def save_auth_info(self, url: str, username: str, password: str) -> None:
+        return None
+
+
+class KeyRingPythonProvider(KeyRingBaseProvider):
+    """Keyring interface which uses locally imported `keyring`"""
+
+    has_keyring = True
+
+    def __init__(self) -> None:
+        import keyring
+
+        self.keyring = keyring
+
+    def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]:
+        # Support keyring's get_credential interface which supports getting
+        # credentials without a username. This is only available for
+        # keyring>=15.2.0.
+        if hasattr(self.keyring, "get_credential"):
             logger.debug("Getting credentials from keyring for %s", url)
-            cred = get_credential(url, username)
+            cred = self.keyring.get_credential(url, username)
             if cred is not None:
                 return cred.username, cred.password
             return None
 
-        if username:
+        if username is not None:
             logger.debug("Getting password from keyring for %s", url)
-            password = keyring.get_password(url, username)
+            password = self.keyring.get_password(url, username)
             if password:
                 return username, password
+        return None
+
+    def save_auth_info(self, url: str, username: str, password: str) -> None:
+        self.keyring.set_password(url, username, password)
+
+
+class KeyRingCliProvider(KeyRingBaseProvider):
+    """Provider which uses `keyring` cli
+
+    Instead of calling the keyring package installed alongside pip
+    we call keyring on the command line which will enable pip to
+    use which ever installation of keyring is available first in
+    PATH.
+    """
+
+    has_keyring = True
+
+    def __init__(self, cmd: str) -> None:
+        self.keyring = cmd
+
+    def get_auth_info(self, url: str, username: Optional[str]) -> Optional[AuthInfo]:
+        # This is the default implementation of keyring.get_credential
+        # https://github.com/jaraco/keyring/blob/97689324abcf01bd1793d49063e7ca01e03d7d07/keyring/backend.py#L134-L139
+        if username is not None:
+            password = self._get_password(url, username)
+            if password is not None:
+                return username, password
+        return None
+
+    def save_auth_info(self, url: str, username: str, password: str) -> None:
+        return self._set_password(url, username, password)
 
-    except Exception as exc:
-        logger.warning(
-            "Keyring is skipped due to an exception: %s", str(exc),
+    def _get_password(self, service_name: str, username: str) -> Optional[str]:
+        """Mirror the implementation of keyring.get_password using cli"""
+        if self.keyring is None:
+            return None
+
+        cmd = [self.keyring, "get", service_name, username]
+        env = os.environ.copy()
+        env["PYTHONIOENCODING"] = "utf-8"
+        res = subprocess.run(
+            cmd,
+            stdin=subprocess.DEVNULL,
+            stdout=subprocess.PIPE,
+            env=env,
         )
-        keyring = None
-    return None
+        if res.returncode:
+            return None
+        return res.stdout.decode("utf-8").strip(os.linesep)
 
+    def _set_password(self, service_name: str, username: str, password: str) -> None:
+        """Mirror the implementation of keyring.set_password using cli"""
+        if self.keyring is None:
+            return None
+        env = os.environ.copy()
+        env["PYTHONIOENCODING"] = "utf-8"
+        subprocess.run(
+            [self.keyring, "set", service_name, username],
+            input=f"{password}{os.linesep}".encode("utf-8"),
+            env=env,
+            check=True,
+        )
+        return None
+
+
+@lru_cache(maxsize=None)
+def get_keyring_provider(provider: str) -> KeyRingBaseProvider:
+    logger.verbose("Keyring provider requested: %s", provider)
+
+    # keyring has previously failed and been disabled
+    if KEYRING_DISABLED:
+        provider = "disabled"
+    if provider in ["import", "auto"]:
+        try:
+            impl = KeyRingPythonProvider()
+            logger.verbose("Keyring provider set: import")
+            return impl
+        except ImportError:
+            pass
+        except Exception as exc:
+            # In the event of an unexpected exception
+            # we should warn the user
+            msg = "Installed copy of keyring fails with exception %s"
+            if provider == "auto":
+                msg = msg + ", trying to find a keyring executable as a fallback"
+            logger.warning(msg, exc, exc_info=logger.isEnabledFor(logging.DEBUG))
+    if provider in ["subprocess", "auto"]:
+        cli = shutil.which("keyring")
+        if cli and cli.startswith(sysconfig.get_path("scripts")):
+            # all code within this function is stolen from shutil.which implementation
+            @typing.no_type_check
+            def PATH_as_shutil_which_determines_it() -> str:
+                path = os.environ.get("PATH", None)
+                if path is None:
+                    try:
+                        path = os.confstr("CS_PATH")
+                    except (AttributeError, ValueError):
+                        # os.confstr() or CS_PATH is not available
+                        path = os.defpath
+                # bpo-35755: Don't use os.defpath if the PATH environment variable is
+                # set to an empty string
+
+                return path
+
+            scripts = Path(sysconfig.get_path("scripts"))
+
+            paths = []
+            for path in PATH_as_shutil_which_determines_it().split(os.pathsep):
+                p = Path(path)
+                try:
+                    if not p.samefile(scripts):
+                        paths.append(path)
+                except FileNotFoundError:
+                    pass
+
+            path = os.pathsep.join(paths)
+
+            cli = shutil.which("keyring", path=path)
+
+        if cli:
+            logger.verbose("Keyring provider set: subprocess with executable %s", cli)
+            return KeyRingCliProvider(cli)
+
+    logger.verbose("Keyring provider set: disabled")
+    return KeyRingNullProvider()
 
-class MultiDomainBasicAuth(AuthBase):
 
-    def __init__(self, prompting=True, index_urls=None):
-        # type: (bool, Optional[List[str]]) -> None
+class MultiDomainBasicAuth(AuthBase):
+    def __init__(
+        self,
+        prompting: bool = True,
+        index_urls: Optional[List[str]] = None,
+        keyring_provider: str = "auto",
+    ) -> None:
         self.prompting = prompting
         self.index_urls = index_urls
-        self.passwords = {}  # type: Dict[str, AuthInfo]
+        self.keyring_provider = keyring_provider  # type: ignore[assignment]
+        self.passwords: Dict[str, AuthInfo] = {}
         # When the user is prompted to enter credentials and keyring is
         # available, we will offer to save them. If the user accepts,
         # this value is set to the credentials they entered. After the
         # request authenticates, the caller should call
         # ``save_credentials`` to save these.
-        self._credentials_to_save = None  # type: Optional[Credentials]
+        self._credentials_to_save: Optional[Credentials] = None
+
+    @property
+    def keyring_provider(self) -> KeyRingBaseProvider:
+        return get_keyring_provider(self._keyring_provider)
+
+    @keyring_provider.setter
+    def keyring_provider(self, provider: str) -> None:
+        # The free function get_keyring_provider has been decorated with
+        # functools.cache. If an exception occurs in get_keyring_auth that
+        # cache will be cleared and keyring disabled, take that into account
+        # if you want to remove this indirection.
+        self._keyring_provider = provider
+
+    @property
+    def use_keyring(self) -> bool:
+        # We won't use keyring when --no-input is passed unless
+        # a specific provider is requested because it might require
+        # user interaction
+        return self.prompting or self._keyring_provider not in ["auto", "disabled"]
+
+    def _get_keyring_auth(
+        self,
+        url: Optional[str],
+        username: Optional[str],
+    ) -> Optional[AuthInfo]:
+        """Return the tuple auth for a given url from keyring."""
+        # Do nothing if no url was provided
+        if not url:
+            return None
+
+        try:
+            return self.keyring_provider.get_auth_info(url, username)
+        except Exception as exc:
+            logger.warning(
+                "Keyring is skipped due to an exception: %s",
+                str(exc),
+            )
+            global KEYRING_DISABLED
+            KEYRING_DISABLED = True
+            get_keyring_provider.cache_clear()
+            return None
 
-    def _get_index_url(self, url):
-        # type: (str) -> Optional[str]
+    def _get_index_url(self, url: str) -> Optional[str]:
         """Return the original index URL matching the requested URL.
 
         Cached or dynamically generated credentials may work against
@@ -100,15 +295,45 @@ class MultiDomainBasicAuth(AuthBase):
         if not url or not self.index_urls:
             return None
 
-        for u in self.index_urls:
-            prefix = remove_auth_from_url(u).rstrip("/") + "/"
-            if url.startswith(prefix):
-                return u
-        return None
+        url = remove_auth_from_url(url).rstrip("/") + "/"
+        parsed_url = urllib.parse.urlsplit(url)
 
-    def _get_new_credentials(self, original_url, allow_netrc=True,
-                             allow_keyring=False):
-        # type: (str, bool, bool) -> AuthInfo
+        candidates = []
+
+        for index in self.index_urls:
+            index = index.rstrip("/") + "/"
+            parsed_index = urllib.parse.urlsplit(remove_auth_from_url(index))
+            if parsed_url == parsed_index:
+                return index
+
+            if parsed_url.netloc != parsed_index.netloc:
+                continue
+
+            candidate = urllib.parse.urlsplit(index)
+            candidates.append(candidate)
+
+        if not candidates:
+            return None
+
+        candidates.sort(
+            reverse=True,
+            key=lambda candidate: commonprefix(
+                [
+                    parsed_url.path,
+                    candidate.path,
+                ]
+            ).rfind("/"),
+        )
+
+        return urllib.parse.urlunsplit(candidates[0])
+
+    def _get_new_credentials(
+        self,
+        original_url: str,
+        *,
+        allow_netrc: bool = True,
+        allow_keyring: bool = False,
+    ) -> AuthInfo:
         """Find and return credentials for the specified URL."""
         # Split the credentials and netloc from the url.
         url, netloc, url_user_password = split_auth_netloc_from_url(
@@ -147,18 +372,21 @@ class MultiDomainBasicAuth(AuthBase):
         # If we don't have a password and keyring is available, use it.
         if allow_keyring:
             # The index url is more specific than the netloc, so try it first
+            # fmt: off
             kr_auth = (
-                get_keyring_auth(index_url, username) or
-                get_keyring_auth(netloc, username)
+                self._get_keyring_auth(index_url, username) or
+                self._get_keyring_auth(netloc, username)
             )
+            # fmt: on
             if kr_auth:
                 logger.debug("Found credentials in keyring for %s", netloc)
                 return kr_auth
 
         return username, password
 
-    def _get_url_and_credentials(self, original_url):
-        # type: (str) -> Tuple[str, Optional[str], Optional[str]]
+    def _get_url_and_credentials(
+        self, original_url: str
+    ) -> Tuple[str, Optional[str], Optional[str]]:
         """Return the credentials to use for the provided URL.
 
         If allowed, netrc and keyring may be used to obtain the
@@ -170,13 +398,19 @@ class MultiDomainBasicAuth(AuthBase):
         """
         url, netloc, _ = split_auth_netloc_from_url(original_url)
 
-        # Use any stored credentials that we have for this netloc
-        username, password = self.passwords.get(netloc, (None, None))
+        # Try to get credentials from original url
+        username, password = self._get_new_credentials(original_url)
 
-        if username is None and password is None:
-            # No stored credentials. Acquire new credentials without prompting
-            # the user. (e.g. from netrc, keyring, or the URL itself)
-            username, password = self._get_new_credentials(original_url)
+        # If credentials not found, use any stored credentials for this netloc.
+        # Do this if either the username or the password is missing.
+        # This accounts for the situation in which the user has specified
+        # the username in the index url, but the password comes from keyring.
+        if (username is None or password is None) and netloc in self.passwords:
+            un, pw = self.passwords[netloc]
+            # It is possible that the cached credentials are for a different username,
+            # in which case the cache should be ignored.
+            if username is None or username == un:
+                username, password = un, pw
 
         if username is not None or password is not None:
             # Convert the username and password if they're None, so that
@@ -191,15 +425,14 @@ class MultiDomainBasicAuth(AuthBase):
 
         assert (
             # Credentials were found
-            (username is not None and password is not None) or
+            (username is not None and password is not None)
             # Credentials were not found
-            (username is None and password is None)
+            or (username is None and password is None)
         ), f"Could not load credentials from url: {original_url}"
 
         return url, username, password
 
-    def __call__(self, req):
-        # type: (Request) -> Request
+    def __call__(self, req: Request) -> Request:
         # Get credentials for this request
         url, username, password = self._get_url_and_credentials(req.url)
 
@@ -216,42 +449,51 @@ class MultiDomainBasicAuth(AuthBase):
         return req
 
     # Factored out to allow for easy patching in tests
-    def _prompt_for_password(self, netloc):
-        # type: (str) -> Tuple[Optional[str], Optional[str], bool]
-        username = ask_input(f"User for {netloc}: ")
+    def _prompt_for_password(
+        self, netloc: str
+    ) -> Tuple[Optional[str], Optional[str], bool]:
+        username = ask_input(f"User for {netloc}: ") if self.prompting else None
         if not username:
             return None, None, False
-        auth = get_keyring_auth(netloc, username)
-        if auth and auth[0] is not None and auth[1] is not None:
-            return auth[0], auth[1], False
+        if self.use_keyring:
+            auth = self._get_keyring_auth(netloc, username)
+            if auth and auth[0] is not None and auth[1] is not None:
+                return auth[0], auth[1], False
         password = ask_password("Password: ")
         return username, password, True
 
     # Factored out to allow for easy patching in tests
-    def _should_save_password_to_keyring(self):
-        # type: () -> bool
-        if not keyring:
+    def _should_save_password_to_keyring(self) -> bool:
+        if (
+            not self.prompting
+            or not self.use_keyring
+            or not self.keyring_provider.has_keyring
+        ):
             return False
         return ask("Save credentials to keyring [y/N]: ", ["y", "n"]) == "y"
 
-    def handle_401(self, resp, **kwargs):
-        # type: (Response, **Any) -> Response
+    def handle_401(self, resp: Response, **kwargs: Any) -> Response:
         # We only care about 401 responses, anything else we want to just
         #   pass through the actual response
         if resp.status_code != 401:
             return resp
 
+        username, password = None, None
+
+        # Query the keyring for credentials:
+        if self.use_keyring:
+            username, password = self._get_new_credentials(
+                resp.url,
+                allow_netrc=False,
+                allow_keyring=True,
+            )
+
         # We are not able to prompt the user so simply return the response
-        if not self.prompting:
+        if not self.prompting and not username and not password:
             return resp
 
         parsed = urllib.parse.urlparse(resp.url)
 
-        # Query the keyring for credentials:
-        username, password = self._get_new_credentials(resp.url,
-                                                       allow_netrc=False,
-                                                       allow_keyring=True)
-
         # Prompt the user for a new username and password
         save = False
         if not username and not password:
@@ -264,11 +506,17 @@ class MultiDomainBasicAuth(AuthBase):
 
             # Prompt to save the password to keyring
             if save and self._should_save_password_to_keyring():
-                self._credentials_to_save = (parsed.netloc, username, password)
+                self._credentials_to_save = Credentials(
+                    url=parsed.netloc,
+                    username=username,
+                    password=password,
+                )
 
         # Consume content and release the original connection to allow our new
         #   request to reuse the same one.
-        resp.content
+        # The result of the assignment isn't used, it's just needed to consume
+        # the content.
+        _ = resp.content
         resp.raw.release_conn()
 
         # Add our new username and password to the request
@@ -287,26 +535,27 @@ class MultiDomainBasicAuth(AuthBase):
 
         return new_resp
 
-    def warn_on_401(self, resp, **kwargs):
-        # type: (Response, **Any) -> None
+    def warn_on_401(self, resp: Response, **kwargs: Any) -> None:
         """Response callback to warn about incorrect credentials."""
         if resp.status_code == 401:
             logger.warning(
-                '401 Error, Credentials not correct for %s', resp.request.url,
+                "401 Error, Credentials not correct for %s",
+                resp.request.url,
             )
 
-    def save_credentials(self, resp, **kwargs):
-        # type: (Response, **Any) -> None
+    def save_credentials(self, resp: Response, **kwargs: Any) -> None:
         """Response callback to save credentials on success."""
-        assert keyring is not None, "should never reach here without keyring"
-        if not keyring:
-            return
+        assert (
+            self.keyring_provider.has_keyring
+        ), "should never reach here without keyring"
 
         creds = self._credentials_to_save
         self._credentials_to_save = None
         if creds and resp.status_code < 400:
             try:
-                logger.info('Saving credentials to keyring')
-                keyring.set_password(*creds)
+                logger.info("Saving credentials to keyring")
+                self.keyring_provider.save_auth_info(
+                    creds.url, creds.username, creds.password
+                )
             except Exception:
-                logger.exception('Failed to save credentials')
+                logger.exception("Failed to save credentials")
diff --git a/env/Lib/site-packages/pip/_internal/network/cache.py b/env/Lib/site-packages/pip/_internal/network/cache.py
index ce08932a..a81a2398 100644
--- a/env/Lib/site-packages/pip/_internal/network/cache.py
+++ b/env/Lib/site-packages/pip/_internal/network/cache.py
@@ -3,7 +3,7 @@
 
 import os
 from contextlib import contextmanager
-from typing import Iterator, Optional
+from typing import Generator, Optional
 
 from pip._vendor.cachecontrol.cache import BaseCache
 from pip._vendor.cachecontrol.caches import FileCache
@@ -13,14 +13,12 @@ from pip._internal.utils.filesystem import adjacent_tmp_file, replace
 from pip._internal.utils.misc import ensure_dir
 
 
-def is_from_cache(response):
-    # type: (Response) -> bool
+def is_from_cache(response: Response) -> bool:
     return getattr(response, "from_cache", False)
 
 
 @contextmanager
-def suppressed_cache_errors():
-    # type: () -> Iterator[None]
+def suppressed_cache_errors() -> Generator[None, None, None]:
     """If we can't access the cache then we can just skip caching and process
     requests as if caching wasn't enabled.
     """
@@ -36,14 +34,12 @@ class SafeFileCache(BaseCache):
     not be accessible or writable.
     """
 
-    def __init__(self, directory):
-        # type: (str) -> None
+    def __init__(self, directory: str) -> None:
         assert directory is not None, "Cache directory must not be None."
         super().__init__()
         self.directory = directory
 
-    def _get_cache_path(self, name):
-        # type: (str) -> str
+    def _get_cache_path(self, name: str) -> str:
         # From cachecontrol.caches.file_cache.FileCache._fn, brought into our
         # class for backwards-compatibility and to avoid using a non-public
         # method.
@@ -51,15 +47,13 @@ class SafeFileCache(BaseCache):
         parts = list(hashed[:5]) + [hashed]
         return os.path.join(self.directory, *parts)
 
-    def get(self, key):
-        # type: (str) -> Optional[bytes]
+    def get(self, key: str) -> Optional[bytes]:
         path = self._get_cache_path(key)
         with suppressed_cache_errors():
-            with open(path, 'rb') as f:
+            with open(path, "rb") as f:
                 return f.read()
 
-    def set(self, key, value):
-        # type: (str, bytes) -> None
+    def set(self, key: str, value: bytes, expires: Optional[int] = None) -> None:
         path = self._get_cache_path(key)
         with suppressed_cache_errors():
             ensure_dir(os.path.dirname(path))
@@ -69,8 +63,7 @@ class SafeFileCache(BaseCache):
 
             replace(f.name, path)
 
-    def delete(self, key):
-        # type: (str) -> None
+    def delete(self, key: str) -> None:
         path = self._get_cache_path(key)
         with suppressed_cache_errors():
             os.remove(path)
diff --git a/env/Lib/site-packages/pip/_internal/network/download.py b/env/Lib/site-packages/pip/_internal/network/download.py
index 1897d99a..79b82a57 100644
--- a/env/Lib/site-packages/pip/_internal/network/download.py
+++ b/env/Lib/site-packages/pip/_internal/network/download.py
@@ -1,6 +1,6 @@
 """Download files with progress indicators.
 """
-import cgi
+import email.message
 import logging
 import mimetypes
 import os
@@ -8,7 +8,7 @@ from typing import Iterable, Optional, Tuple
 
 from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response
 
-from pip._internal.cli.progress_bars import DownloadProgressProvider
+from pip._internal.cli.progress_bars import get_download_progress_renderer
 from pip._internal.exceptions import NetworkConnectionError
 from pip._internal.models.index import PyPI
 from pip._internal.models.link import Link
@@ -20,20 +20,18 @@ from pip._internal.utils.misc import format_size, redact_auth_from_url, splitext
 logger = logging.getLogger(__name__)
 
 
-def _get_http_response_size(resp):
-    # type: (Response) -> Optional[int]
+def _get_http_response_size(resp: Response) -> Optional[int]:
     try:
-        return int(resp.headers['content-length'])
+        return int(resp.headers["content-length"])
     except (ValueError, KeyError, TypeError):
         return None
 
 
 def _prepare_download(
-    resp,  # type: Response
-    link,  # type: Link
-    progress_bar  # type: str
-):
-    # type: (...) -> Iterable[bytes]
+    resp: Response,
+    link: Link,
+    progress_bar: str,
+) -> Iterable[bytes]:
     total_length = _get_http_response_size(resp)
 
     if link.netloc == PyPI.file_storage_domain:
@@ -44,7 +42,7 @@ def _prepare_download(
     logged_url = redact_auth_from_url(url)
 
     if total_length:
-        logged_url = '{} ({})'.format(logged_url, format_size(total_length))
+        logged_url = "{} ({})".format(logged_url, format_size(total_length))
 
     if is_from_cache(resp):
         logger.info("Using cached %s", logged_url)
@@ -67,49 +65,44 @@ def _prepare_download(
     if not show_progress:
         return chunks
 
-    return DownloadProgressProvider(
-        progress_bar, max=total_length
-    )(chunks)
+    renderer = get_download_progress_renderer(bar_type=progress_bar, size=total_length)
+    return renderer(chunks)
 
 
-def sanitize_content_filename(filename):
-    # type: (str) -> str
+def sanitize_content_filename(filename: str) -> str:
     """
     Sanitize the "filename" value from a Content-Disposition header.
     """
     return os.path.basename(filename)
 
 
-def parse_content_disposition(content_disposition, default_filename):
-    # type: (str, str) -> str
+def parse_content_disposition(content_disposition: str, default_filename: str) -> str:
     """
     Parse the "filename" value from a Content-Disposition header, and
     return the default filename if the result is empty.
     """
-    _type, params = cgi.parse_header(content_disposition)
-    filename = params.get('filename')
+    m = email.message.Message()
+    m["content-type"] = content_disposition
+    filename = m.get_param("filename")
     if filename:
         # We need to sanitize the filename to prevent directory traversal
         # in case the filename contains ".." path parts.
-        filename = sanitize_content_filename(filename)
+        filename = sanitize_content_filename(str(filename))
     return filename or default_filename
 
 
-def _get_http_response_filename(resp, link):
-    # type: (Response, Link) -> str
+def _get_http_response_filename(resp: Response, link: Link) -> str:
     """Get an ideal filename from the given HTTP response, falling back to
     the link filename if not provided.
     """
     filename = link.filename  # fallback
     # Have a look at the Content-Disposition header for a better guess
-    content_disposition = resp.headers.get('content-disposition')
+    content_disposition = resp.headers.get("content-disposition")
     if content_disposition:
         filename = parse_content_disposition(content_disposition, filename)
-    ext = splitext(filename)[1]  # type: Optional[str]
+    ext: Optional[str] = splitext(filename)[1]
     if not ext:
-        ext = mimetypes.guess_extension(
-            resp.headers.get('content-type', '')
-        )
+        ext = mimetypes.guess_extension(resp.headers.get("content-type", ""))
         if ext:
             filename += ext
     if not ext and link.url != resp.url:
@@ -119,9 +112,8 @@ def _get_http_response_filename(resp, link):
     return filename
 
 
-def _http_get_download(session, link):
-    # type: (PipSession, Link) -> Response
-    target_url = link.url.split('#', 1)[0]
+def _http_get_download(session: PipSession, link: Link) -> Response:
+    target_url = link.url.split("#", 1)[0]
     resp = session.get(target_url, headers=HEADERS, stream=True)
     raise_for_status(resp)
     return resp
@@ -130,15 +122,13 @@ def _http_get_download(session, link):
 class Downloader:
     def __init__(
         self,
-        session,  # type: PipSession
-        progress_bar,  # type: str
-    ):
-        # type: (...) -> None
+        session: PipSession,
+        progress_bar: str,
+    ) -> None:
         self._session = session
         self._progress_bar = progress_bar
 
-    def __call__(self, link, location):
-        # type: (Link, str) -> Tuple[str, str]
+    def __call__(self, link: Link, location: str) -> Tuple[str, str]:
         """Download the file given by link into location."""
         try:
             resp = _http_get_download(self._session, link)
@@ -153,26 +143,25 @@ class Downloader:
         filepath = os.path.join(location, filename)
 
         chunks = _prepare_download(resp, link, self._progress_bar)
-        with open(filepath, 'wb') as content_file:
+        with open(filepath, "wb") as content_file:
             for chunk in chunks:
                 content_file.write(chunk)
-        content_type = resp.headers.get('Content-Type', '')
+        content_type = resp.headers.get("Content-Type", "")
         return filepath, content_type
 
 
 class BatchDownloader:
-
     def __init__(
         self,
-        session,  # type: PipSession
-        progress_bar,  # type: str
-    ):
-        # type: (...) -> None
+        session: PipSession,
+        progress_bar: str,
+    ) -> None:
         self._session = session
         self._progress_bar = progress_bar
 
-    def __call__(self, links, location):
-        # type: (Iterable[Link], str) -> Iterable[Tuple[Link, Tuple[str, str]]]
+    def __call__(
+        self, links: Iterable[Link], location: str
+    ) -> Iterable[Tuple[Link, Tuple[str, str]]]:
         """Download the files given by links into location."""
         for link in links:
             try:
@@ -181,7 +170,8 @@ class BatchDownloader:
                 assert e.response is not None
                 logger.critical(
                     "HTTP error %s while getting %s",
-                    e.response.status_code, link,
+                    e.response.status_code,
+                    link,
                 )
                 raise
 
@@ -189,8 +179,8 @@ class BatchDownloader:
             filepath = os.path.join(location, filename)
 
             chunks = _prepare_download(resp, link, self._progress_bar)
-            with open(filepath, 'wb') as content_file:
+            with open(filepath, "wb") as content_file:
                 for chunk in chunks:
                     content_file.write(chunk)
-            content_type = resp.headers.get('Content-Type', '')
+            content_type = resp.headers.get("Content-Type", "")
             yield link, (filepath, content_type)
diff --git a/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py b/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py
index b877d3b7..82ec50d5 100644
--- a/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py
+++ b/env/Lib/site-packages/pip/_internal/network/lazy_wheel.py
@@ -1,41 +1,40 @@
 """Lazy ZIP over HTTP"""
 
-__all__ = ['HTTPRangeRequestUnsupported', 'dist_from_wheel_url']
+__all__ = ["HTTPRangeRequestUnsupported", "dist_from_wheel_url"]
 
 from bisect import bisect_left, bisect_right
 from contextlib import contextmanager
 from tempfile import NamedTemporaryFile
-from typing import Any, Dict, Iterator, List, Optional, Tuple
-from zipfile import BadZipfile, ZipFile
+from typing import Any, Dict, Generator, List, Optional, Tuple
+from zipfile import BadZipFile, ZipFile
 
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.packaging.utils import canonicalize_name
 from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response
 
+from pip._internal.metadata import BaseDistribution, MemoryWheel, get_wheel_distribution
 from pip._internal.network.session import PipSession
 from pip._internal.network.utils import HEADERS, raise_for_status, response_chunks
-from pip._internal.utils.wheel import pkg_resources_distribution_for_wheel
 
 
 class HTTPRangeRequestUnsupported(Exception):
     pass
 
 
-def dist_from_wheel_url(name, url, session):
-    # type: (str, str, PipSession) -> Distribution
-    """Return a pkg_resources.Distribution from the given wheel URL.
+def dist_from_wheel_url(name: str, url: str, session: PipSession) -> BaseDistribution:
+    """Return a distribution object from the given wheel URL.
 
-    This uses HTTP range requests to only fetch the potion of the wheel
+    This uses HTTP range requests to only fetch the portion of the wheel
     containing metadata, just enough for the object to be constructed.
     If such requests are not supported, HTTPRangeRequestUnsupported
     is raised.
     """
-    with LazyZipOverHTTP(url, session) as wheel:
+    with LazyZipOverHTTP(url, session) as zf:
         # For read-only ZIP files, ZipFile only needs methods read,
         # seek, seekable and tell, not the whole IO protocol.
-        zip_file = ZipFile(wheel)  # type: ignore
+        wheel = MemoryWheel(zf.name, zf)  # type: ignore
         # After context manager exit, wheel.name
         # is an invalid file by intention.
-        return pkg_resources_distribution_for_wheel(zip_file, name, wheel.name)
+        return get_wheel_distribution(wheel, canonicalize_name(name))
 
 
 class LazyZipOverHTTP:
@@ -47,51 +46,46 @@ class LazyZipOverHTTP:
     during initialization.
     """
 
-    def __init__(self, url, session, chunk_size=CONTENT_CHUNK_SIZE):
-        # type: (str, PipSession, int) -> None
+    def __init__(
+        self, url: str, session: PipSession, chunk_size: int = CONTENT_CHUNK_SIZE
+    ) -> None:
         head = session.head(url, headers=HEADERS)
         raise_for_status(head)
         assert head.status_code == 200
         self._session, self._url, self._chunk_size = session, url, chunk_size
-        self._length = int(head.headers['Content-Length'])
+        self._length = int(head.headers["Content-Length"])
         self._file = NamedTemporaryFile()
         self.truncate(self._length)
-        self._left = []  # type: List[int]
-        self._right = []  # type: List[int]
-        if 'bytes' not in head.headers.get('Accept-Ranges', 'none'):
-            raise HTTPRangeRequestUnsupported('range request is not supported')
+        self._left: List[int] = []
+        self._right: List[int] = []
+        if "bytes" not in head.headers.get("Accept-Ranges", "none"):
+            raise HTTPRangeRequestUnsupported("range request is not supported")
         self._check_zip()
 
     @property
-    def mode(self):
-        # type: () -> str
+    def mode(self) -> str:
         """Opening mode, which is always rb."""
-        return 'rb'
+        return "rb"
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         """Path to the underlying file."""
         return self._file.name
 
-    def seekable(self):
-        # type: () -> bool
+    def seekable(self) -> bool:
         """Return whether random access is supported, which is True."""
         return True
 
-    def close(self):
-        # type: () -> None
+    def close(self) -> None:
         """Close the file."""
         self._file.close()
 
     @property
-    def closed(self):
-        # type: () -> bool
+    def closed(self) -> bool:
         """Whether the file is closed."""
         return self._file.closed
 
-    def read(self, size=-1):
-        # type: (int) -> bytes
+    def read(self, size: int = -1) -> bytes:
         """Read up to size bytes from the object and return them.
 
         As a convenience, if size is unspecified or -1,
@@ -100,18 +94,16 @@ class LazyZipOverHTTP:
         """
         download_size = max(size, self._chunk_size)
         start, length = self.tell(), self._length
-        stop = length if size < 0 else min(start+download_size, length)
-        start = max(0, stop-download_size)
-        self._download(start, stop-1)
+        stop = length if size < 0 else min(start + download_size, length)
+        start = max(0, stop - download_size)
+        self._download(start, stop - 1)
         return self._file.read(size)
 
-    def readable(self):
-        # type: () -> bool
+    def readable(self) -> bool:
         """Return whether the file is readable, which is True."""
         return True
 
-    def seek(self, offset, whence=0):
-        # type: (int, int) -> int
+    def seek(self, offset: int, whence: int = 0) -> int:
         """Change stream position and return the new absolute position.
 
         Seek to offset relative position indicated by whence:
@@ -121,13 +113,11 @@ class LazyZipOverHTTP:
         """
         return self._file.seek(offset, whence)
 
-    def tell(self):
-        # type: () -> int
-        """Return the current possition."""
+    def tell(self) -> int:
+        """Return the current position."""
         return self._file.tell()
 
-    def truncate(self, size=None):
-        # type: (Optional[int]) -> int
+    def truncate(self, size: Optional[int] = None) -> int:
         """Resize the stream to the given size in bytes.
 
         If size is unspecified resize to the current position.
@@ -137,23 +127,19 @@ class LazyZipOverHTTP:
         """
         return self._file.truncate(size)
 
-    def writable(self):
-        # type: () -> bool
+    def writable(self) -> bool:
         """Return False."""
         return False
 
-    def __enter__(self):
-        # type: () -> LazyZipOverHTTP
+    def __enter__(self) -> "LazyZipOverHTTP":
         self._file.__enter__()
         return self
 
-    def __exit__(self, *exc):
-        # type: (*Any) -> Optional[bool]
-        return self._file.__exit__(*exc)
+    def __exit__(self, *exc: Any) -> None:
+        self._file.__exit__(*exc)
 
     @contextmanager
-    def _stay(self):
-        # type: ()-> Iterator[None]
+    def _stay(self) -> Generator[None, None, None]:
         """Return a context manager keeping the position.
 
         At the end of the block, seek back to original position.
@@ -164,8 +150,7 @@ class LazyZipOverHTTP:
         finally:
             self.seek(pos)
 
-    def _check_zip(self):
-        # type: () -> None
+    def _check_zip(self) -> None:
         """Check and download until the file is a valid ZIP."""
         end = self._length - 1
         for start in reversed(range(0, end, self._chunk_size)):
@@ -175,23 +160,25 @@ class LazyZipOverHTTP:
                     # For read-only ZIP files, ZipFile only needs
                     # methods read, seek, seekable and tell.
                     ZipFile(self)  # type: ignore
-                except BadZipfile:
+                except BadZipFile:
                     pass
                 else:
                     break
 
-    def _stream_response(self, start, end, base_headers=HEADERS):
-        # type: (int, int, Dict[str, str]) -> Response
+    def _stream_response(
+        self, start: int, end: int, base_headers: Dict[str, str] = HEADERS
+    ) -> Response:
         """Return HTTP response to a range request from start to end."""
         headers = base_headers.copy()
-        headers['Range'] = f'bytes={start}-{end}'
+        headers["Range"] = f"bytes={start}-{end}"
         # TODO: Get range requests to be correctly cached
-        headers['Cache-Control'] = 'no-cache'
+        headers["Cache-Control"] = "no-cache"
         return self._session.get(self._url, headers=headers, stream=True)
 
-    def _merge(self, start, end, left, right):
-        # type: (int, int, int, int) -> Iterator[Tuple[int, int]]
-        """Return an iterator of intervals to be fetched.
+    def _merge(
+        self, start: int, end: int, left: int, right: int
+    ) -> Generator[Tuple[int, int], None, None]:
+        """Return a generator of intervals to be fetched.
 
         Args:
             start (int): Start of needed interval
@@ -200,18 +187,17 @@ class LazyZipOverHTTP:
             right (int): Index after last overlapping downloaded data
         """
         lslice, rslice = self._left[left:right], self._right[left:right]
-        i = start = min([start]+lslice[:1])
-        end = max([end]+rslice[-1:])
+        i = start = min([start] + lslice[:1])
+        end = max([end] + rslice[-1:])
         for j, k in zip(lslice, rslice):
             if j > i:
-                yield i, j-1
+                yield i, j - 1
             i = k + 1
         if i <= end:
             yield i, end
         self._left[left:right], self._right[left:right] = [start], [end]
 
-    def _download(self, start, end):
-        # type: (int, int) -> None
+    def _download(self, start: int, end: int) -> None:
         """Download bytes from start to end inclusively."""
         with self._stay():
             left = bisect_left(self._right, start)
diff --git a/env/Lib/site-packages/pip/_internal/network/session.py b/env/Lib/site-packages/pip/_internal/network/session.py
index 4af800f1..887dc14e 100644
--- a/env/Lib/site-packages/pip/_internal/network/session.py
+++ b/env/Lib/site-packages/pip/_internal/network/session.py
@@ -2,31 +2,36 @@
 network request configuration and behavior.
 """
 
-# When mypy runs on Windows the call to distro.linux_distribution() is skipped
-# resulting in the failure:
-#
-#     error: unused 'type: ignore' comment
-#
-# If the upstream module adds typing, this comment should be removed. See
-# https://github.com/nir0s/distro/pull/269
-#
-# mypy: warn-unused-ignores=False
-
 import email.utils
+import io
 import ipaddress
 import json
 import logging
 import mimetypes
 import os
 import platform
+import shutil
+import subprocess
 import sys
 import urllib.parse
 import warnings
-from typing import Any, Dict, Iterator, List, Mapping, Optional, Sequence, Tuple, Union
+from typing import (
+    TYPE_CHECKING,
+    Any,
+    Dict,
+    Generator,
+    List,
+    Mapping,
+    Optional,
+    Sequence,
+    Tuple,
+    Union,
+)
 
 from pip._vendor import requests, urllib3
-from pip._vendor.cachecontrol import CacheControlAdapter
-from pip._vendor.requests.adapters import BaseAdapter, HTTPAdapter
+from pip._vendor.cachecontrol import CacheControlAdapter as _BaseCacheControlAdapter
+from pip._vendor.requests.adapters import DEFAULT_POOLBLOCK, BaseAdapter
+from pip._vendor.requests.adapters import HTTPAdapter as _BaseHTTPAdapter
 from pip._vendor.requests.models import PreparedRequest, Response
 from pip._vendor.requests.structures import CaseInsensitiveDict
 from pip._vendor.urllib3.connectionpool import ConnectionPool
@@ -44,6 +49,12 @@ from pip._internal.utils.glibc import libc_ver
 from pip._internal.utils.misc import build_url_from_netloc, parse_netloc
 from pip._internal.utils.urls import url_to_path
 
+if TYPE_CHECKING:
+    from ssl import SSLContext
+
+    from pip._vendor.urllib3.poolmanager import PoolManager
+
+
 logger = logging.getLogger(__name__)
 
 SecureOrigin = Tuple[str, str, Optional[Union[int, str]]]
@@ -53,7 +64,7 @@ SecureOrigin = Tuple[str, str, Optional[Union[int, str]]]
 warnings.filterwarnings("ignore", category=InsecureRequestWarning)
 
 
-SECURE_ORIGINS = [
+SECURE_ORIGINS: List[SecureOrigin] = [
     # protocol, hostname, port
     # Taken from Chrome's list of secure origins (See: http://bit.ly/1qrySKC)
     ("https", "*", "*"),
@@ -63,7 +74,7 @@ SECURE_ORIGINS = [
     ("file", "*", None),
     # ssh is always secure.
     ("ssh", "*", "*"),
-]  # type: List[SecureOrigin]
+]
 
 
 # These are environment variables present when running under various
@@ -75,18 +86,17 @@ SECURE_ORIGINS = [
 # For more background, see: https://github.com/pypa/pip/issues/5499
 CI_ENVIRONMENT_VARIABLES = (
     # Azure Pipelines
-    'BUILD_BUILDID',
+    "BUILD_BUILDID",
     # Jenkins
-    'BUILD_ID',
+    "BUILD_ID",
     # AppVeyor, CircleCI, Codeship, Gitlab CI, Shippable, Travis CI
-    'CI',
+    "CI",
     # Explicit environment variable.
-    'PIP_IS_CI',
+    "PIP_IS_CI",
 )
 
 
-def looks_like_ci():
-    # type: () -> bool
+def looks_like_ci() -> bool:
     """
     Return whether it looks like pip is running under CI.
     """
@@ -96,48 +106,50 @@ def looks_like_ci():
     return any(name in os.environ for name in CI_ENVIRONMENT_VARIABLES)
 
 
-def user_agent():
-    # type: () -> str
+def user_agent() -> str:
     """
     Return a string representing the user agent.
     """
-    data = {
+    data: Dict[str, Any] = {
         "installer": {"name": "pip", "version": __version__},
         "python": platform.python_version(),
         "implementation": {
             "name": platform.python_implementation(),
         },
-    }  # type: Dict[str, Any]
+    }
 
-    if data["implementation"]["name"] == 'CPython':
+    if data["implementation"]["name"] == "CPython":
         data["implementation"]["version"] = platform.python_version()
-    elif data["implementation"]["name"] == 'PyPy':
+    elif data["implementation"]["name"] == "PyPy":
         pypy_version_info = sys.pypy_version_info  # type: ignore
-        if pypy_version_info.releaselevel == 'final':
+        if pypy_version_info.releaselevel == "final":
             pypy_version_info = pypy_version_info[:3]
         data["implementation"]["version"] = ".".join(
             [str(x) for x in pypy_version_info]
         )
-    elif data["implementation"]["name"] == 'Jython':
+    elif data["implementation"]["name"] == "Jython":
         # Complete Guess
         data["implementation"]["version"] = platform.python_version()
-    elif data["implementation"]["name"] == 'IronPython':
+    elif data["implementation"]["name"] == "IronPython":
         # Complete Guess
         data["implementation"]["version"] = platform.python_version()
 
     if sys.platform.startswith("linux"):
         from pip._vendor import distro
 
-        # https://github.com/nir0s/distro/pull/269
-        linux_distribution = distro.linux_distribution()  # type: ignore
-        distro_infos = dict(filter(
-            lambda x: x[1],
-            zip(["name", "version", "id"], linux_distribution),
-        ))
-        libc = dict(filter(
-            lambda x: x[1],
-            zip(["lib", "version"], libc_ver()),
-        ))
+        linux_distribution = distro.name(), distro.version(), distro.codename()
+        distro_infos: Dict[str, Any] = dict(
+            filter(
+                lambda x: x[1],
+                zip(["name", "version", "id"], linux_distribution),
+            )
+        )
+        libc = dict(
+            filter(
+                lambda x: x[1],
+                zip(["lib", "version"], libc_ver()),
+            )
+        )
         if libc:
             distro_infos["libc"] = libc
         if distro_infos:
@@ -157,12 +169,28 @@ def user_agent():
 
     if has_tls():
         import _ssl as ssl
+
         data["openssl_version"] = ssl.OPENSSL_VERSION
 
     setuptools_dist = get_default_environment().get_distribution("setuptools")
     if setuptools_dist is not None:
         data["setuptools_version"] = str(setuptools_dist.version)
 
+    if shutil.which("rustc") is not None:
+        # If for any reason `rustc --version` fails, silently ignore it
+        try:
+            rustc_output = subprocess.check_output(
+                ["rustc", "--version"], stderr=subprocess.STDOUT, timeout=0.5
+            )
+        except Exception:
+            pass
+        else:
+            if rustc_output.startswith(b"rustc "):
+                # The format of `rustc --version` is:
+                # `b'rustc 1.52.1 (9bc8c42bb 2021-05-09)\n'`
+                # We extract just the middle (1.52.1) part
+                data["rustc_version"] = rustc_output.split(b" ")[1].decode()
+
     # Use None rather than False so as not to give the impression that
     # pip knows it is not being run under CI.  Rather, it is a null or
     # inconclusive result.  Also, we include some value rather than no
@@ -180,17 +208,15 @@ def user_agent():
 
 
 class LocalFSAdapter(BaseAdapter):
-
     def send(
         self,
-        request,  # type: PreparedRequest
-        stream=False,  # type: bool
-        timeout=None,  # type: Optional[Union[float, Tuple[float, float]]]
-        verify=True,  # type: Union[bool, str]
-        cert=None,  # type: Optional[Union[str, Tuple[str, str]]]
-        proxies=None,  # type:Optional[Mapping[str, str]]
-    ):
-        # type: (...) -> Response
+        request: PreparedRequest,
+        stream: bool = False,
+        timeout: Optional[Union[float, Tuple[float, float]]] = None,
+        verify: Union[bool, str] = True,
+        cert: Optional[Union[str, Tuple[str, str]]] = None,
+        proxies: Optional[Mapping[str, str]] = None,
+    ) -> Response:
         pathname = url_to_path(request.url)
 
         resp = Response()
@@ -200,67 +226,108 @@ class LocalFSAdapter(BaseAdapter):
         try:
             stats = os.stat(pathname)
         except OSError as exc:
+            # format the exception raised as a io.BytesIO object,
+            # to return a better error message:
             resp.status_code = 404
-            resp.raw = exc
+            resp.reason = type(exc).__name__
+            resp.raw = io.BytesIO(f"{resp.reason}: {exc}".encode("utf8"))
         else:
             modified = email.utils.formatdate(stats.st_mtime, usegmt=True)
             content_type = mimetypes.guess_type(pathname)[0] or "text/plain"
-            resp.headers = CaseInsensitiveDict({
-                "Content-Type": content_type,
-                "Content-Length": stats.st_size,
-                "Last-Modified": modified,
-            })
+            resp.headers = CaseInsensitiveDict(
+                {
+                    "Content-Type": content_type,
+                    "Content-Length": stats.st_size,
+                    "Last-Modified": modified,
+                }
+            )
 
             resp.raw = open(pathname, "rb")
             resp.close = resp.raw.close
 
         return resp
 
-    def close(self):
-        # type: () -> None
+    def close(self) -> None:
         pass
 
 
-class InsecureHTTPAdapter(HTTPAdapter):
+class _SSLContextAdapterMixin:
+    """Mixin to add the ``ssl_context`` constructor argument to HTTP adapters.
+
+    The additional argument is forwarded directly to the pool manager. This allows us
+    to dynamically decide what SSL store to use at runtime, which is used to implement
+    the optional ``truststore`` backend.
+    """
+
+    def __init__(
+        self,
+        *,
+        ssl_context: Optional["SSLContext"] = None,
+        **kwargs: Any,
+    ) -> None:
+        self._ssl_context = ssl_context
+        super().__init__(**kwargs)
+
+    def init_poolmanager(
+        self,
+        connections: int,
+        maxsize: int,
+        block: bool = DEFAULT_POOLBLOCK,
+        **pool_kwargs: Any,
+    ) -> "PoolManager":
+        if self._ssl_context is not None:
+            pool_kwargs.setdefault("ssl_context", self._ssl_context)
+        return super().init_poolmanager(  # type: ignore[misc]
+            connections=connections,
+            maxsize=maxsize,
+            block=block,
+            **pool_kwargs,
+        )
+
+
+class HTTPAdapter(_SSLContextAdapterMixin, _BaseHTTPAdapter):
+    pass
+
 
+class CacheControlAdapter(_SSLContextAdapterMixin, _BaseCacheControlAdapter):
+    pass
+
+
+class InsecureHTTPAdapter(HTTPAdapter):
     def cert_verify(
         self,
-        conn,  # type: ConnectionPool
-        url,  # type: str
-        verify,  # type: Union[bool, str]
-        cert,  # type: Optional[Union[str, Tuple[str, str]]]
-    ):
-        # type: (...) -> None
+        conn: ConnectionPool,
+        url: str,
+        verify: Union[bool, str],
+        cert: Optional[Union[str, Tuple[str, str]]],
+    ) -> None:
         super().cert_verify(conn=conn, url=url, verify=False, cert=cert)
 
 
 class InsecureCacheControlAdapter(CacheControlAdapter):
-
     def cert_verify(
         self,
-        conn,  # type: ConnectionPool
-        url,  # type: str
-        verify,  # type: Union[bool, str]
-        cert,  # type: Optional[Union[str, Tuple[str, str]]]
-    ):
-        # type: (...) -> None
+        conn: ConnectionPool,
+        url: str,
+        verify: Union[bool, str],
+        cert: Optional[Union[str, Tuple[str, str]]],
+    ) -> None:
         super().cert_verify(conn=conn, url=url, verify=False, cert=cert)
 
 
 class PipSession(requests.Session):
-
-    timeout = None  # type: Optional[int]
+    timeout: Optional[int] = None
 
     def __init__(
         self,
-        *args,  # type: Any
-        retries=0,  # type: int
-        cache=None,  # type: Optional[str]
-        trusted_hosts=(),  # type: Sequence[str]
-        index_urls=None,  # type: Optional[List[str]]
-        **kwargs,  # type: Any
-    ):
-        # type: (...) -> None
+        *args: Any,
+        retries: int = 0,
+        cache: Optional[str] = None,
+        trusted_hosts: Sequence[str] = (),
+        index_urls: Optional[List[str]] = None,
+        ssl_context: Optional["SSLContext"] = None,
+        **kwargs: Any,
+    ) -> None:
         """
         :param trusted_hosts: Domains not to emit warnings for when not using
             HTTPS.
@@ -269,7 +336,7 @@ class PipSession(requests.Session):
 
         # Namespace the attribute with "pip_" just in case to prevent
         # possible conflicts with the base class.
-        self.pip_trusted_origins = []  # type: List[Tuple[str, Optional[int]]]
+        self.pip_trusted_origins: List[Tuple[str, Optional[int]]] = []
 
         # Attach our User Agent to the request
         self.headers["User-Agent"] = user_agent()
@@ -283,7 +350,6 @@ class PipSession(requests.Session):
             # Set the total number of retries that a particular request can
             # have.
             total=retries,
-
             # A 503 error from PyPI typically means that the Fastly -> Origin
             # connection got interrupted in some way. A 503 error in general
             # is typically considered a transient error so we'll go ahead and
@@ -291,7 +357,6 @@ class PipSession(requests.Session):
             # A 500 may indicate transient error in Amazon S3
             # A 520 or 527 - may indicate transient error in CloudFlare
             status_forcelist=[500, 503, 520, 527],
-
             # Add a small amount of back off between failed requests in
             # order to prevent hammering the service.
             backoff_factor=0.25,
@@ -313,13 +378,14 @@ class PipSession(requests.Session):
             secure_adapter = CacheControlAdapter(
                 cache=SafeFileCache(cache),
                 max_retries=retries,
+                ssl_context=ssl_context,
             )
             self._trusted_host_adapter = InsecureCacheControlAdapter(
                 cache=SafeFileCache(cache),
                 max_retries=retries,
             )
         else:
-            secure_adapter = HTTPAdapter(max_retries=retries)
+            secure_adapter = HTTPAdapter(max_retries=retries, ssl_context=ssl_context)
             self._trusted_host_adapter = insecure_adapter
 
         self.mount("https://", secure_adapter)
@@ -331,16 +397,16 @@ class PipSession(requests.Session):
         for host in trusted_hosts:
             self.add_trusted_host(host, suppress_logging=True)
 
-    def update_index_urls(self, new_index_urls):
-        # type: (List[str]) -> None
+    def update_index_urls(self, new_index_urls: List[str]) -> None:
         """
         :param new_index_urls: New index urls to update the authentication
             handler with.
         """
         self.auth.index_urls = new_index_urls
 
-    def add_trusted_host(self, host, source=None, suppress_logging=False):
-        # type: (str, Optional[str], bool) -> None
+    def add_trusted_host(
+        self, host: str, source: Optional[str] = None, suppress_logging: bool = False
+    ) -> None:
         """
         :param host: It is okay to provide a host that has previously been
             added.
@@ -348,45 +414,48 @@ class PipSession(requests.Session):
             string came from.
         """
         if not suppress_logging:
-            msg = f'adding trusted host: {host!r}'
+            msg = f"adding trusted host: {host!r}"
             if source is not None:
-                msg += f' (from {source})'
+                msg += f" (from {source})"
             logger.info(msg)
 
-        host_port = parse_netloc(host)
-        if host_port not in self.pip_trusted_origins:
-            self.pip_trusted_origins.append(host_port)
+        parsed_host, parsed_port = parse_netloc(host)
+        if parsed_host is None:
+            raise ValueError(f"Trusted host URL must include a host part: {host!r}")
+        if (parsed_host, parsed_port) not in self.pip_trusted_origins:
+            self.pip_trusted_origins.append((parsed_host, parsed_port))
 
         self.mount(
-            build_url_from_netloc(host) + '/',
-            self._trusted_host_adapter
+            build_url_from_netloc(host, scheme="http") + "/", self._trusted_host_adapter
         )
-        if not host_port[1]:
-            # Mount wildcard ports for the same host.
+        self.mount(build_url_from_netloc(host) + "/", self._trusted_host_adapter)
+        if not parsed_port:
             self.mount(
-                build_url_from_netloc(host) + ':',
-                self._trusted_host_adapter
+                build_url_from_netloc(host, scheme="http") + ":",
+                self._trusted_host_adapter,
             )
+            # Mount wildcard ports for the same host.
+            self.mount(build_url_from_netloc(host) + ":", self._trusted_host_adapter)
 
-    def iter_secure_origins(self):
-        # type: () -> Iterator[SecureOrigin]
+    def iter_secure_origins(self) -> Generator[SecureOrigin, None, None]:
         yield from SECURE_ORIGINS
         for host, port in self.pip_trusted_origins:
-            yield ('*', host, '*' if port is None else port)
+            yield ("*", host, "*" if port is None else port)
 
-    def is_secure_origin(self, location):
-        # type: (Link) -> bool
+    def is_secure_origin(self, location: Link) -> bool:
         # Determine if this url used a secure transport mechanism
         parsed = urllib.parse.urlparse(str(location))
         origin_protocol, origin_host, origin_port = (
-            parsed.scheme, parsed.hostname, parsed.port,
+            parsed.scheme,
+            parsed.hostname,
+            parsed.port,
         )
 
         # The protocol to use to see if the protocol matches.
         # Don't count the repository type as part of the protocol: in
         # cases such as "git+ssh", only use "ssh". (I.e., Only verify against
         # the last scheme.)
-        origin_protocol = origin_protocol.rsplit('+', 1)[-1]
+        origin_protocol = origin_protocol.rsplit("+", 1)[-1]
 
         # Determine if our origin is a secure origin by looking through our
         # hardcoded list of secure origins, as well as any additional ones
@@ -397,15 +466,15 @@ class PipSession(requests.Session):
                 continue
 
             try:
-                addr = ipaddress.ip_address(origin_host)
+                addr = ipaddress.ip_address(origin_host or "")
                 network = ipaddress.ip_network(secure_host)
             except ValueError:
                 # We don't have both a valid address or a valid network, so
                 # we'll check this origin against hostnames.
                 if (
-                    origin_host and
-                    origin_host.lower() != secure_host.lower() and
-                    secure_host != "*"
+                    origin_host
+                    and origin_host.lower() != secure_host.lower()
+                    and secure_host != "*"
                 ):
                     continue
             else:
@@ -416,9 +485,9 @@ class PipSession(requests.Session):
 
             # Check to see if the port matches.
             if (
-                origin_port != secure_port and
-                secure_port != "*" and
-                secure_port is not None
+                origin_port != secure_port
+                and secure_port != "*"
+                and secure_port is not None
             ):
                 continue
 
@@ -440,10 +509,11 @@ class PipSession(requests.Session):
 
         return False
 
-    def request(self, method, url, *args, **kwargs):
-        # type: (str, str, *Any, **Any) -> Response
+    def request(self, method: str, url: str, *args: Any, **kwargs: Any) -> Response:
         # Allow setting a default timeout on a session
         kwargs.setdefault("timeout", self.timeout)
+        # Allow setting a default proxies on a session
+        kwargs.setdefault("proxies", self.proxies)
 
         # Dispatch the actual request
         return super().request(method, url, *args, **kwargs)
diff --git a/env/Lib/site-packages/pip/_internal/network/utils.py b/env/Lib/site-packages/pip/_internal/network/utils.py
index 6e5cf0d1..134848ae 100644
--- a/env/Lib/site-packages/pip/_internal/network/utils.py
+++ b/env/Lib/site-packages/pip/_internal/network/utils.py
@@ -1,4 +1,4 @@
-from typing import Dict, Iterator
+from typing import Dict, Generator
 
 from pip._vendor.requests.models import CONTENT_CHUNK_SIZE, Response
 
@@ -23,40 +23,41 @@ from pip._internal.exceptions import NetworkConnectionError
 # you're not asking for a compressed file and will then decompress it
 # before sending because if that's the case I don't think it'll ever be
 # possible to make this work.
-HEADERS = {'Accept-Encoding': 'identity'}  # type: Dict[str, str]
+HEADERS: Dict[str, str] = {"Accept-Encoding": "identity"}
 
 
-def raise_for_status(resp):
-    # type: (Response) -> None
-    http_error_msg = ''
+def raise_for_status(resp: Response) -> None:
+    http_error_msg = ""
     if isinstance(resp.reason, bytes):
         # We attempt to decode utf-8 first because some servers
         # choose to localize their reason strings. If the string
         # isn't utf-8, we fall back to iso-8859-1 for all other
         # encodings.
         try:
-            reason = resp.reason.decode('utf-8')
+            reason = resp.reason.decode("utf-8")
         except UnicodeDecodeError:
-            reason = resp.reason.decode('iso-8859-1')
+            reason = resp.reason.decode("iso-8859-1")
     else:
         reason = resp.reason
 
     if 400 <= resp.status_code < 500:
         http_error_msg = (
-            f'{resp.status_code} Client Error: {reason} for url: {resp.url}')
+            f"{resp.status_code} Client Error: {reason} for url: {resp.url}"
+        )
 
     elif 500 <= resp.status_code < 600:
         http_error_msg = (
-            f'{resp.status_code} Server Error: {reason} for url: {resp.url}')
+            f"{resp.status_code} Server Error: {reason} for url: {resp.url}"
+        )
 
     if http_error_msg:
         raise NetworkConnectionError(http_error_msg, response=resp)
 
 
-def response_chunks(response, chunk_size=CONTENT_CHUNK_SIZE):
-    # type: (Response, int) -> Iterator[bytes]
-    """Given a requests Response, provide the data chunks.
-    """
+def response_chunks(
+    response: Response, chunk_size: int = CONTENT_CHUNK_SIZE
+) -> Generator[bytes, None, None]:
+    """Given a requests Response, provide the data chunks."""
     try:
         # Special case for urllib3.
         for chunk in response.raw.stream(
diff --git a/env/Lib/site-packages/pip/_internal/network/xmlrpc.py b/env/Lib/site-packages/pip/_internal/network/xmlrpc.py
index b92b8d9a..4a7d55d0 100644
--- a/env/Lib/site-packages/pip/_internal/network/xmlrpc.py
+++ b/env/Lib/site-packages/pip/_internal/network/xmlrpc.py
@@ -21,22 +21,32 @@ class PipXmlrpcTransport(xmlrpc.client.Transport):
     object.
     """
 
-    def __init__(self, index_url, session, use_datetime=False):
-        # type: (str, PipSession, bool) -> None
+    def __init__(
+        self, index_url: str, session: PipSession, use_datetime: bool = False
+    ) -> None:
         super().__init__(use_datetime)
         index_parts = urllib.parse.urlparse(index_url)
         self._scheme = index_parts.scheme
         self._session = session
 
-    def request(self, host, handler, request_body, verbose=False):
-        # type: (_HostType, str, bytes, bool) -> Tuple[_Marshallable, ...]
+    def request(
+        self,
+        host: "_HostType",
+        handler: str,
+        request_body: bytes,
+        verbose: bool = False,
+    ) -> Tuple["_Marshallable", ...]:
         assert isinstance(host, str)
         parts = (self._scheme, host, handler, None, None, None)
         url = urllib.parse.urlunparse(parts)
         try:
-            headers = {'Content-Type': 'text/xml'}
-            response = self._session.post(url, data=request_body,
-                                          headers=headers, stream=True)
+            headers = {"Content-Type": "text/xml"}
+            response = self._session.post(
+                url,
+                data=request_body,
+                headers=headers,
+                stream=True,
+            )
             raise_for_status(response)
             self.verbose = verbose
             return self.parse_response(response.raw)
@@ -44,6 +54,7 @@ class PipXmlrpcTransport(xmlrpc.client.Transport):
             assert exc.response
             logger.critical(
                 "HTTP error %s while getting %s",
-                exc.response.status_code, url,
+                exc.response.status_code,
+                url,
             )
             raise
diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 9b3650d70ccb7cd60366b139be73e1c1fd16aa2c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 224
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<YIU}X
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP
u%1g}A&o4+VN-W9D&nwoCkI&4@EQycTE2zB1VUwGmQks)$2XfwLkT(G3s65C3

diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/check.cpython-39.pyc
deleted file mode 100644
index c9bff16da90f9ed06485345cadb99f8bcf3e37ee..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3720
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
Ti~@`x89rtS5iT7LQ4TQxIzs1C

diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/freeze.cpython-39.pyc
deleted file mode 100644
index a7c7c055be58a6aa126398cec987675c806e7270..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/__pycache__/prepare.cpython-39.pyc
deleted file mode 100644
index 98a20e7d0c02fcf50ad8cf66ec00f1f39afe7dad..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 35a76848c3e474c4d27d88a3291cfd8b52114671..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 230
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>UOq@
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP
z%1g}A&o4+VN-W9D&nwnXD$UGE(T|VM%*!l^kJl@xyv1RYo1apelWGTY<Y$m)0Bcx3
A4FCWD

diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata.cpython-39.pyc
deleted file mode 100644
index 5e73fc27fc6968fb21520c744d820ce87a4dcd45..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1176
zcmYe~<>g{vU|^UdaWJ))g@NHQh=Yuo7#J8F7#J9eJs21mQW&BbQW#U1au}l+Qy5d2
zbC`0OqnH^%Vk|i<xvWvFU^Z(GTP}MPJDAOu!;#Aw#mUH!!k)s>!Vtxk!W7J)$ysIM
zn_7~Xl30?cke-^CT9jClnV+YSlb@cMtdN#pq)?n+T9llskdj$kQk0og3X(0><9Z2l
znV%-(ErEd40#ieCkNo^>=fs?x)FP0WQ)y;Sifdk3W>J1#ZfahMCgUyXqSCy))S~$E
z%#w`w;(|;tCpWdYI59m{lkpaBNNR3@OJ-4Oa!GzsWirUGAR9oKje&uIlYxQ38RYi{
z1_p)_kT021n0uLOnQEA_7;Bkp82Wt}8A_N^SehAYS!x&;FxRjwWbBt>WT;_Wz*57!
zkg=9EoFRpkg@J{knVFFxPr#6&*vo){5ey?47#T2RGmvFVShE-xu+=cvur36J8CzA3
zJ0z%56>?#LS6ZBzm#&bTnw*iCmsy-!tdNpgoLrQdl$xTDnWqro8lYfmXs*Y_rJ$go
z5R_U{T9j9;P?C`f3-r_!gi$H5aL@y*uHw(lPf0Dx(}md;qRDiNB|9@O<(5EtPJU8i
zPEKWfZem_ydTL6QL_kq$L1GceE#(=hsX1^{{WRH&SQ!`?Zm|?3mShyMfS7{CrAY-v
z`N^rp#qp5%xusA5)}I;=vn)O>zbHNl6ru5818*_q7vEyZ%FoQxWV^))kx0!eyTzWA
zn4F!OmvW0AuCpY!ASJWt77tti#AAb6!~;rEnR#jX@hO=_D;bJ}85kITbvs+dgche3
z700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~xdwYW#ss_ix(0{11}T`u
z1O)iRB%0`gQf_fcW_C<!URjJ!W>QRXW=X1UL1J=tVtQ(EOhIOWetc$LNorAEVvc@(
z0W`rE>w|rw4|A$sLFFw$XnsJ11urNGih&a)6C=xiHWoG}HWm&>9!3^MrvDBsMWPH0
z44T}x*yH0<@{{A^i?|sW7^0*LG7I$L%Tn`F@{9Bez_~@QyeP4tAhoEt2$axoiGx+Z
z9Hj?#NqlNvSrIcRlH^cjOG`3yiuDi?2Z>1;Y>G-!a|=MB3yycN<G`VeM2LVa;IPTf
dPbtkwwPOT%kB5PQfrXiaiHC`Yk%y6o832h-S^WS2

diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/metadata_legacy.cpython-39.pyc
deleted file mode 100644
index 55bb6d5b7d49abf688c5744d72ce164be203ece5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1950
zcmYe~<>g{vU|^UdaWJ)(oq^#oh=Yuo85kHG7#J9e^B5QyQW&BbQW#U1au}l+!8B78
zQwn1Wa}IMZOB4$uNRB0kHJ2@l4a{cEVbA4=;sCSRayWCjqPW0p_8jh9o+uthhE&D{
zys3N(8Kd}9I8r!U7@`DHxKg-V7@`DIn1UHJd8({^Q%e$45=#;l(o^$NixNvR^YavP
z^3yYu71HvH6mnA26O$_yit|g0l2a8@GK))!GLuR{ii-8PUV^;gr^$Frz^ODdC&e|d
zEVC#-FE=%>M3eEBpl4ojNn%b8*hJT&qWmIF##^$viP@>~#i=Ew1tt0UImPj*>FM#A
zd1?9aiACwfnvA#jlM{1t;)_d@3X1ZRQ;R`DydkN%1umIIsmUezMU}~nAWNZ`iGhKE
zm4Si585Dd$px|RnVQOJ0VOYRe!?2Lig`t_Tma&GhSgnL9g}H`dHp5(|X2vGQ66PAl
zX2ukjY?dO25~dW^1uP)dU>Sxi)&*=e3^j}?Y?2HMK|#b`W$c!jm!goEr=XXbo~{dW
ztwM2WQVPsP3YmEd32<J59+!fGf&x}&27{a_#lXOj&QQY;D+F@d0)`ZZg^WckHH;IP
z3R!{~G#RTn;nrv}-r`8jODQhTEXmMhy2YetaEmc*B|{M?J^h;GY!wq)oLW>IlbVx~
zSrp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p9O4?JU=|Y);1iQ*
zq6>=V;*!klnAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%R%)FA+qP)Z${rm!G>L}Jv
z0>!p|E;Ql9L(+&|LFFwjo1DzzlH~l{0y`0qUqSK1##p5kpO%@I0*`Awo1FaQ#GGO~
zJ%sWq1;2cx@P!AbLRx-lUJ59PUxFgOO4m2PC{>{(BQZ}QKQ9%(j_TSXkRDC;TTJ=I
zx7a~WOUW!M0_C?`%sHufx7gD1i*gf7Zm|?3mSo&w$;!{n(`35E3Ag+fXIf@XYF=V)
zYB4y>Ap|!A1H&yoR4)mDd@BP=l`L$G9RJx^SQwcYIsUV-@GvqlvM@6JXZp{=RwTy2
zz>o||uONjW%+A2TzyV9YDGUtYl$*j>!&t+zkeQL8geiq7g*k<#mnn<6mbHYXhOvgV
zhB<|`m${a$hM`}Mk)edOhOLGvg)N1>mzj|voFRpSg@J{knVFFxPr#6&ILLs35ey?4
z7#T{~YFL{YgBdhAtMc3-c|BDD7KsX_#hH2O3gDcnS5T>&lvtdaqL7lBmY7_UuaKLX
zoROH9S)5y}#|2K_L8&FBMR~;vB^jx(aw9bbVHi9FA(^4dD5x|q57~SL4N#C<sTON0
zz)ApcaRW_z3aZ6bJO!Bry08ovqRDiNB|9@O<(5EtPJU8iPEKWfZem_ydTNR$(=8sD
z8SyEZMYs6!^5aX3Q;Xu0^YhX&)2k#3DoZl*^Wc7i+o;KOi#fSG<rYtJer|4JUP^pQ
zYH_lkCi^Y6oc#3k)S_FgDXB@N=|yY|3=Bm=Ac6%%fFckam746gIKf#VJ~glG7B4vL
z;tML{L0-GX1t~JYF5<{6&d*6KNlm%Mo|0OUn3+>tBne7HETBRUlBhsgx(J-I1fk_{
zYCJ4%)Io_$4U}GZK*@^b9}6oJBg=md7A8h8{L9A124OKW{Z(NvQe|LZ&=k7G9v`2Q
zpBx{5iyh>h%)Im>K9Hs21(^kU@NBII_dpRSv)+<Gl})WkPAveJ_K<9&f+}5Fl9^Mi
z2lhCmI0u_n1PZ2Ga#)qZ3-%&VFy4~Erl=$}w*VAw;DEoynVwqW1Bnlg_;^rejE^sp
u1w{lXJAplm6oiOy<gm%jPbtkwwF8v_#h~Jdg_(nqgNcU`3YoZ=Im7{_CNPKq

diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index 2fd533621cbb12b4c57302b3581c1e95a5beba31..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1155
zcmYe~<>g{vU|^UdaWFNAg@NHQh=Yuo85kHG7#J9ey%-o6QW#Pga~Pr^G-DKF3PTE0
z4pT036f+}8j5&uTmo<tN%x1}9%Vm#ZXJklaSiq6WxsWl6D}^<Mt%V_qJB2ZrL6iL@
z$QD0M##<cz1tppJd5JlijJE^=QVUEC%{}t-vz-%ja#D*l8E;7!mFDH87R8rmmSn^i
z7i5Atxv9m)iRr1yEFe>$n2mvffrEj8!5QS-DGUq@HB2dtrHsWqUJOl)RS_i&3m8+F
zYM2)?F*1}er7+hp%w|YonakYFSj$qwxPZBaWg%m~93w*wV-`yda}84pYcEqRYdAv+
zBMSoyLo+iYL!N*kLve%w10xtlGB7fPGvq0-FqE)Xwm`&67#6Ulu+=bt?1*FldDMWR
zgguL60cQ<!4eLTCkjJZfok}xvQWWy@QWZS&ic1o6a)MF|OEZg7b5rw56iSOT^U@Vc
zGEx-+TmuwL4b2sjz{(4X@{?1Gi}kp;6ciK`f>KLLi}H#U3KB~)6iV_H$}>_^a}+Yu
z6pBleLCVrfb8;%dI!p8v{7W)Yi^?;LQ*{)Ip!)ps^HTM|CizuKx}+ADWacG;VnHD#
zvnVyWB)_QAN<p=_N*L@^kb@u=q~#YWRB<V2K%J(k$#_dBH?<@&C9xzi9<H@Y#w{^3
zCp86Ze+sH@)nZMqTWmS`>FKFOw^&nBlS<QzK#_P$u(&h{>c@CUjNjr0`#c_O^({`<
zisV#qO1Z_FT2z!@bc-p!_!bK&0B*5l<!9z;vfX0IOUzBZ#h#RyoSmANQpC!@z;KJT
zBsI4n<rW*%OfIl#@gRjO8Hz+07#MzaI9tVp7N-^!$E4<@WEREv=cT$7WtOEX=qiNz
zd4{<L1$%}#1}k{_x%m6J275Zj1iSjW28Xx?DVW6s1o*@xn&{@_r)L(IWM;>t=9R_x
zWG2NFXO^Vu79=KTC#I(s#}s51=*MT~m82HsCFbbo7o-+}1G`us>_L67lk^HIZwZ0<
z5D&)}fU^P*C^5@{QaCpcBNHPJ6B8rXe->sQMixdUMy7unEIf=nj2w(bVhjunnmo7I
zK_Q!&mtF+YcZ;p0vH-+kVqjp1k}k+B(2Fli%}dEI(t{YTS6-A@P>@<wTm;JIx8%So
zVD8i_Ey>I&)<Z-KB%V0aQ%igx(Z>-F4#)WTB2d-?I{_S`NQ5XT3OH<X^HWN5QtcQ)
Ro&mXxgOP)ghY19^m;uAYNl5?z

diff --git a/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/build/__pycache__/wheel_legacy.cpython-39.pyc
deleted file mode 100644
index 8cbc897aa17d9f341649b692ddbc97733a75da83..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2549
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
I4p9y{0OuvnxBvhE

diff --git a/env/Lib/site-packages/pip/_internal/operations/build/metadata.py b/env/Lib/site-packages/pip/_internal/operations/build/metadata.py
index 1c826835..c66ac354 100644
--- a/env/Lib/site-packages/pip/_internal/operations/build/metadata.py
+++ b/env/Lib/site-packages/pip/_internal/operations/build/metadata.py
@@ -3,33 +3,37 @@
 
 import os
 
-from pip._vendor.pep517.wrappers import Pep517HookCaller
+from pip._vendor.pyproject_hooks import BuildBackendHookCaller
 
 from pip._internal.build_env import BuildEnvironment
+from pip._internal.exceptions import (
+    InstallationSubprocessError,
+    MetadataGenerationFailed,
+)
 from pip._internal.utils.subprocess import runner_with_spinner_message
 from pip._internal.utils.temp_dir import TempDirectory
 
 
-def generate_metadata(build_env, backend):
-    # type: (BuildEnvironment, Pep517HookCaller) -> str
+def generate_metadata(
+    build_env: BuildEnvironment, backend: BuildBackendHookCaller, details: str
+) -> str:
     """Generate metadata using mechanisms described in PEP 517.
 
     Returns the generated metadata directory.
     """
-    metadata_tmpdir = TempDirectory(
-        kind="modern-metadata", globally_managed=True
-    )
+    metadata_tmpdir = TempDirectory(kind="modern-metadata", globally_managed=True)
 
     metadata_dir = metadata_tmpdir.path
 
     with build_env:
-        # Note that Pep517HookCaller implements a fallback for
+        # Note that BuildBackendHookCaller implements a fallback for
         # prepare_metadata_for_build_wheel, so we don't have to
         # consider the possibility that this hook doesn't exist.
-        runner = runner_with_spinner_message("Preparing wheel metadata")
+        runner = runner_with_spinner_message("Preparing metadata (pyproject.toml)")
         with backend.subprocess_runner(runner):
-            distinfo_dir = backend.prepare_metadata_for_build_wheel(
-                metadata_dir
-            )
+            try:
+                distinfo_dir = backend.prepare_metadata_for_build_wheel(metadata_dir)
+            except InstallationSubprocessError as error:
+                raise MetadataGenerationFailed(package_details=details) from error
 
     return os.path.join(metadata_dir, distinfo_dir)
diff --git a/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py b/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py
index f46538a0..e60988d6 100644
--- a/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py
+++ b/env/Lib/site-packages/pip/_internal/operations/build/metadata_legacy.py
@@ -5,7 +5,12 @@ import logging
 import os
 
 from pip._internal.build_env import BuildEnvironment
-from pip._internal.exceptions import InstallationError
+from pip._internal.cli.spinners import open_spinner
+from pip._internal.exceptions import (
+    InstallationError,
+    InstallationSubprocessError,
+    MetadataGenerationFailed,
+)
 from pip._internal.utils.setuptools_build import make_setuptools_egg_info_args
 from pip._internal.utils.subprocess import call_subprocess
 from pip._internal.utils.temp_dir import TempDirectory
@@ -13,49 +18,39 @@ from pip._internal.utils.temp_dir import TempDirectory
 logger = logging.getLogger(__name__)
 
 
-def _find_egg_info(directory):
-    # type: (str) -> str
-    """Find an .egg-info subdirectory in `directory`.
-    """
-    filenames = [
-        f for f in os.listdir(directory) if f.endswith(".egg-info")
-    ]
+def _find_egg_info(directory: str) -> str:
+    """Find an .egg-info subdirectory in `directory`."""
+    filenames = [f for f in os.listdir(directory) if f.endswith(".egg-info")]
 
     if not filenames:
-        raise InstallationError(
-            f"No .egg-info directory found in {directory}"
-        )
+        raise InstallationError(f"No .egg-info directory found in {directory}")
 
     if len(filenames) > 1:
         raise InstallationError(
-            "More than one .egg-info directory found in {}".format(
-                directory
-            )
+            "More than one .egg-info directory found in {}".format(directory)
         )
 
     return os.path.join(directory, filenames[0])
 
 
 def generate_metadata(
-    build_env,  # type: BuildEnvironment
-    setup_py_path,  # type: str
-    source_dir,  # type: str
-    isolated,  # type: bool
-    details,  # type: str
-):
-    # type: (...) -> str
+    build_env: BuildEnvironment,
+    setup_py_path: str,
+    source_dir: str,
+    isolated: bool,
+    details: str,
+) -> str:
     """Generate metadata using setup.py-based defacto mechanisms.
 
     Returns the generated metadata directory.
     """
     logger.debug(
-        'Running setup.py (path:%s) egg_info for package %s',
-        setup_py_path, details,
+        "Running setup.py (path:%s) egg_info for package %s",
+        setup_py_path,
+        details,
     )
 
-    egg_info_dir = TempDirectory(
-        kind="pip-egg-info", globally_managed=True
-    ).path
+    egg_info_dir = TempDirectory(kind="pip-egg-info", globally_managed=True).path
 
     args = make_setuptools_egg_info_args(
         setup_py_path,
@@ -64,11 +59,16 @@ def generate_metadata(
     )
 
     with build_env:
-        call_subprocess(
-            args,
-            cwd=source_dir,
-            command_desc='python setup.py egg_info',
-        )
+        with open_spinner("Preparing metadata (setup.py)") as spinner:
+            try:
+                call_subprocess(
+                    args,
+                    cwd=source_dir,
+                    command_desc="python setup.py egg_info",
+                    spinner=spinner,
+                )
+            except InstallationSubprocessError as error:
+                raise MetadataGenerationFailed(package_details=details) from error
 
     # Return the .egg-info directory.
     return _find_egg_info(egg_info_dir)
diff --git a/env/Lib/site-packages/pip/_internal/operations/build/wheel.py b/env/Lib/site-packages/pip/_internal/operations/build/wheel.py
index 903bd7a0..064811ad 100644
--- a/env/Lib/site-packages/pip/_internal/operations/build/wheel.py
+++ b/env/Lib/site-packages/pip/_internal/operations/build/wheel.py
@@ -2,7 +2,7 @@ import logging
 import os
 from typing import Optional
 
-from pip._vendor.pep517.wrappers import Pep517HookCaller
+from pip._vendor.pyproject_hooks import BuildBackendHookCaller
 
 from pip._internal.utils.subprocess import runner_with_spinner_message
 
@@ -10,22 +10,21 @@ logger = logging.getLogger(__name__)
 
 
 def build_wheel_pep517(
-    name,  # type: str
-    backend,  # type: Pep517HookCaller
-    metadata_directory,  # type: str
-    tempd,  # type: str
-):
-    # type: (...) -> Optional[str]
+    name: str,
+    backend: BuildBackendHookCaller,
+    metadata_directory: str,
+    tempd: str,
+) -> Optional[str]:
     """Build one InstallRequirement using the PEP 517 build process.
 
     Returns path to wheel if successfully built. Otherwise, returns None.
     """
     assert metadata_directory is not None
     try:
-        logger.debug('Destination directory: %s', tempd)
+        logger.debug("Destination directory: %s", tempd)
 
         runner = runner_with_spinner_message(
-            f'Building wheel for {name} (PEP 517)'
+            f"Building wheel for {name} (pyproject.toml)"
         )
         with backend.subprocess_runner(runner):
             wheel_name = backend.build_wheel(
@@ -33,6 +32,6 @@ def build_wheel_pep517(
                 metadata_directory=metadata_directory,
             )
     except Exception:
-        logger.error('Failed building wheel for %s', name)
+        logger.error("Failed building wheel for %s", name)
         return None
     return os.path.join(tempd, wheel_name)
diff --git a/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py b/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py
index 755c3bc8..c5f0492c 100644
--- a/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py
+++ b/env/Lib/site-packages/pip/_internal/operations/build/wheel_legacy.py
@@ -4,59 +4,51 @@ from typing import List, Optional
 
 from pip._internal.cli.spinners import open_spinner
 from pip._internal.utils.setuptools_build import make_setuptools_bdist_wheel_args
-from pip._internal.utils.subprocess import (
-    LOG_DIVIDER,
-    call_subprocess,
-    format_command_args,
-)
+from pip._internal.utils.subprocess import call_subprocess, format_command_args
 
 logger = logging.getLogger(__name__)
 
 
 def format_command_result(
-    command_args,  # type: List[str]
-    command_output,  # type: str
-):
-    # type: (...) -> str
+    command_args: List[str],
+    command_output: str,
+) -> str:
     """Format command information for logging."""
     command_desc = format_command_args(command_args)
-    text = f'Command arguments: {command_desc}\n'
+    text = f"Command arguments: {command_desc}\n"
 
     if not command_output:
-        text += 'Command output: None'
+        text += "Command output: None"
     elif logger.getEffectiveLevel() > logging.DEBUG:
-        text += 'Command output: [use --verbose to show]'
+        text += "Command output: [use --verbose to show]"
     else:
-        if not command_output.endswith('\n'):
-            command_output += '\n'
-        text += f'Command output:\n{command_output}{LOG_DIVIDER}'
+        if not command_output.endswith("\n"):
+            command_output += "\n"
+        text += f"Command output:\n{command_output}"
 
     return text
 
 
 def get_legacy_build_wheel_path(
-    names,  # type: List[str]
-    temp_dir,  # type: str
-    name,  # type: str
-    command_args,  # type: List[str]
-    command_output,  # type: str
-):
-    # type: (...) -> Optional[str]
+    names: List[str],
+    temp_dir: str,
+    name: str,
+    command_args: List[str],
+    command_output: str,
+) -> Optional[str]:
     """Return the path to the wheel in the temporary build directory."""
     # Sort for determinism.
     names = sorted(names)
     if not names:
-        msg = (
-            'Legacy build of wheel for {!r} created no files.\n'
-        ).format(name)
+        msg = ("Legacy build of wheel for {!r} created no files.\n").format(name)
         msg += format_command_result(command_args, command_output)
         logger.warning(msg)
         return None
 
     if len(names) > 1:
         msg = (
-            'Legacy build of wheel for {!r} created more than one file.\n'
-            'Filenames (choosing first): {}\n'
+            "Legacy build of wheel for {!r} created more than one file.\n"
+            "Filenames (choosing first): {}\n"
         ).format(name, names)
         msg += format_command_result(command_args, command_output)
         logger.warning(msg)
@@ -65,14 +57,13 @@ def get_legacy_build_wheel_path(
 
 
 def build_wheel_legacy(
-    name,  # type: str
-    setup_py_path,  # type: str
-    source_dir,  # type: str
-    global_options,  # type: List[str]
-    build_options,  # type: List[str]
-    tempd,  # type: str
-):
-    # type: (...) -> Optional[str]
+    name: str,
+    setup_py_path: str,
+    source_dir: str,
+    global_options: List[str],
+    build_options: List[str],
+    tempd: str,
+) -> Optional[str]:
     """Build one unpacked package using the "legacy" build process.
 
     Returns path to wheel if successfully built. Otherwise, returns None.
@@ -84,19 +75,20 @@ def build_wheel_legacy(
         destination_dir=tempd,
     )
 
-    spin_message = f'Building wheel for {name} (setup.py)'
+    spin_message = f"Building wheel for {name} (setup.py)"
     with open_spinner(spin_message) as spinner:
-        logger.debug('Destination directory: %s', tempd)
+        logger.debug("Destination directory: %s", tempd)
 
         try:
             output = call_subprocess(
                 wheel_args,
+                command_desc="python setup.py bdist_wheel",
                 cwd=source_dir,
                 spinner=spinner,
             )
         except Exception:
             spinner.finish("error")
-            logger.error('Failed building wheel for %s', name)
+            logger.error("Failed building wheel for %s", name)
             return None
 
         names = os.listdir(tempd)
diff --git a/env/Lib/site-packages/pip/_internal/operations/check.py b/env/Lib/site-packages/pip/_internal/operations/check.py
index 5699c0b9..26104592 100644
--- a/env/Lib/site-packages/pip/_internal/operations/check.py
+++ b/env/Lib/site-packages/pip/_internal/operations/check.py
@@ -2,87 +2,91 @@
 """
 
 import logging
-from collections import namedtuple
-from typing import TYPE_CHECKING, Any, Callable, Dict, List, Optional, Set, Tuple
+from typing import Callable, Dict, List, NamedTuple, Optional, Set, Tuple
 
-from pip._vendor.packaging.utils import canonicalize_name
-from pip._vendor.pkg_resources import RequirementParseError
+from pip._vendor.packaging.requirements import Requirement
+from pip._vendor.packaging.specifiers import LegacySpecifier
+from pip._vendor.packaging.utils import NormalizedName, canonicalize_name
+from pip._vendor.packaging.version import LegacyVersion
 
 from pip._internal.distributions import make_distribution_for_install_requirement
+from pip._internal.metadata import get_default_environment
+from pip._internal.metadata.base import DistributionVersion
 from pip._internal.req.req_install import InstallRequirement
-from pip._internal.utils.misc import get_installed_distributions
-
-if TYPE_CHECKING:
-    from pip._vendor.packaging.utils import NormalizedName
+from pip._internal.utils.deprecation import deprecated
 
 logger = logging.getLogger(__name__)
 
+
+class PackageDetails(NamedTuple):
+    version: DistributionVersion
+    dependencies: List[Requirement]
+
+
 # Shorthands
-PackageSet = Dict['NormalizedName', 'PackageDetails']
-Missing = Tuple[str, Any]
-Conflicting = Tuple[str, str, Any]
+PackageSet = Dict[NormalizedName, PackageDetails]
+Missing = Tuple[NormalizedName, Requirement]
+Conflicting = Tuple[NormalizedName, DistributionVersion, Requirement]
 
-MissingDict = Dict['NormalizedName', List[Missing]]
-ConflictingDict = Dict['NormalizedName', List[Conflicting]]
+MissingDict = Dict[NormalizedName, List[Missing]]
+ConflictingDict = Dict[NormalizedName, List[Conflicting]]
 CheckResult = Tuple[MissingDict, ConflictingDict]
 ConflictDetails = Tuple[PackageSet, CheckResult]
 
-PackageDetails = namedtuple('PackageDetails', ['version', 'requires'])
-
-
-def create_package_set_from_installed(**kwargs: Any) -> Tuple["PackageSet", bool]:
-    """Converts a list of distributions into a PackageSet.
-    """
-    # Default to using all packages installed on the system
-    if kwargs == {}:
-        kwargs = {"local_only": False, "skip": ()}
 
+def create_package_set_from_installed() -> Tuple[PackageSet, bool]:
+    """Converts a list of distributions into a PackageSet."""
     package_set = {}
     problems = False
-    for dist in get_installed_distributions(**kwargs):
-        name = canonicalize_name(dist.project_name)
+    env = get_default_environment()
+    for dist in env.iter_installed_distributions(local_only=False, skip=()):
+        name = dist.canonical_name
         try:
-            package_set[name] = PackageDetails(dist.version, dist.requires())
-        except (OSError, RequirementParseError) as e:
-            # Don't crash on unreadable or broken metadata
+            dependencies = list(dist.iter_dependencies())
+            package_set[name] = PackageDetails(dist.version, dependencies)
+        except (OSError, ValueError) as e:
+            # Don't crash on unreadable or broken metadata.
             logger.warning("Error parsing requirements for %s: %s", name, e)
             problems = True
     return package_set, problems
 
 
-def check_package_set(package_set, should_ignore=None):
-    # type: (PackageSet, Optional[Callable[[str], bool]]) -> CheckResult
+def check_package_set(
+    package_set: PackageSet, should_ignore: Optional[Callable[[str], bool]] = None
+) -> CheckResult:
     """Check if a package set is consistent
 
     If should_ignore is passed, it should be a callable that takes a
     package name and returns a boolean.
     """
 
+    warn_legacy_versions_and_specifiers(package_set)
+
     missing = {}
     conflicting = {}
 
     for package_name, package_detail in package_set.items():
         # Info about dependencies of package_name
-        missing_deps = set()  # type: Set[Missing]
-        conflicting_deps = set()  # type: Set[Conflicting]
+        missing_deps: Set[Missing] = set()
+        conflicting_deps: Set[Conflicting] = set()
 
         if should_ignore and should_ignore(package_name):
             continue
 
-        for req in package_detail.requires:
-            name = canonicalize_name(req.project_name)
+        for req in package_detail.dependencies:
+            name = canonicalize_name(req.name)
 
             # Check if it's missing
             if name not in package_set:
                 missed = True
                 if req.marker is not None:
-                    missed = req.marker.evaluate()
+                    missed = req.marker.evaluate({"extra": ""})
                 if missed:
                     missing_deps.add((name, req))
                 continue
 
             # Check if there's a conflict
-            version = package_set[name].version  # type: str
+            version = package_set[name].version
             if not req.specifier.contains(version, prereleases=True):
                 conflicting_deps.add((name, version, req))
 
@@ -94,8 +98,7 @@ def check_package_set(package_set, should_ignore=None):
     return missing, conflicting
 
 
-def check_install_conflicts(to_install):
-    # type: (List[InstallRequirement]) -> ConflictDetails
+def check_install_conflicts(to_install: List[InstallRequirement]) -> ConflictDetails:
     """For checking if the dependency graph would be consistent after \
     installing given requirements
     """
@@ -111,43 +114,74 @@ def check_install_conflicts(to_install):
         package_set,
         check_package_set(
             package_set, should_ignore=lambda name: name not in whitelist
-        )
+        ),
     )
 
 
-def _simulate_installation_of(to_install, package_set):
-    # type: (List[InstallRequirement], PackageSet) -> Set[NormalizedName]
-    """Computes the version of packages after installing to_install.
-    """
-
+def _simulate_installation_of(
+    to_install: List[InstallRequirement], package_set: PackageSet
+) -> Set[NormalizedName]:
+    """Computes the version of packages after installing to_install."""
     # Keep track of packages that were installed
     installed = set()
 
     # Modify it as installing requirement_set would (assuming no errors)
     for inst_req in to_install:
         abstract_dist = make_distribution_for_install_requirement(inst_req)
-        dist = abstract_dist.get_pkg_resources_distribution()
-
-        assert dist is not None
-        name = canonicalize_name(dist.key)
-        package_set[name] = PackageDetails(dist.version, dist.requires())
+        dist = abstract_dist.get_metadata_distribution()
+        name = dist.canonical_name
+        package_set[name] = PackageDetails(dist.version, list(dist.iter_dependencies()))
 
         installed.add(name)
 
     return installed
 
 
-def _create_whitelist(would_be_installed, package_set):
-    # type: (Set[NormalizedName], PackageSet) -> Set[NormalizedName]
+def _create_whitelist(
+    would_be_installed: Set[NormalizedName], package_set: PackageSet
+) -> Set[NormalizedName]:
     packages_affected = set(would_be_installed)
 
     for package_name in package_set:
         if package_name in packages_affected:
             continue
 
-        for req in package_set[package_name].requires:
+        for req in package_set[package_name].dependencies:
             if canonicalize_name(req.name) in packages_affected:
                 packages_affected.add(package_name)
                 break
 
     return packages_affected
+
+
+def warn_legacy_versions_and_specifiers(package_set: PackageSet) -> None:
+    for project_name, package_details in package_set.items():
+        if isinstance(package_details.version, LegacyVersion):
+            deprecated(
+                reason=(
+                    f"{project_name} {package_details.version} "
+                    f"has a non-standard version number."
+                ),
+                replacement=(
+                    f"to upgrade to a newer version of {project_name} "
+                    f"or contact the author to suggest that they "
+                    f"release a version with a conforming version number"
+                ),
+                issue=12063,
+                gone_in="23.3",
+            )
+        for dep in package_details.dependencies:
+            if any(isinstance(spec, LegacySpecifier) for spec in dep.specifier):
+                deprecated(
+                    reason=(
+                        f"{project_name} {package_details.version} "
+                        f"has a non-standard dependency specifier {dep}."
+                    ),
+                    replacement=(
+                        f"to upgrade to a newer version of {project_name} "
+                        f"or contact the author to suggest that they "
+                        f"release a version with a conforming dependency specifiers"
+                    ),
+                    issue=12063,
+                    gone_in="23.3",
+                )
diff --git a/env/Lib/site-packages/pip/_internal/operations/freeze.py b/env/Lib/site-packages/pip/_internal/operations/freeze.py
index f34a9d4b..35445684 100644
--- a/env/Lib/site-packages/pip/_internal/operations/freeze.py
+++ b/env/Lib/site-packages/pip/_internal/operations/freeze.py
@@ -1,73 +1,46 @@
 import collections
 import logging
 import os
-from typing import (
-    Container,
-    Dict,
-    Iterable,
-    Iterator,
-    List,
-    Optional,
-    Set,
-    Tuple,
-    Union,
-)
+from typing import Container, Dict, Generator, Iterable, List, NamedTuple, Optional, Set
 
 from pip._vendor.packaging.utils import canonicalize_name
-from pip._vendor.pkg_resources import Distribution, Requirement, RequirementParseError
+from pip._vendor.packaging.version import Version
 
 from pip._internal.exceptions import BadCommand, InstallationError
+from pip._internal.metadata import BaseDistribution, get_environment
 from pip._internal.req.constructors import (
     install_req_from_editable,
     install_req_from_line,
 )
 from pip._internal.req.req_file import COMMENT_RE
-from pip._internal.utils.direct_url_helpers import (
-    direct_url_as_pep440_direct_reference,
-    dist_get_direct_url,
-)
-from pip._internal.utils.misc import dist_is_editable, get_installed_distributions
+from pip._internal.utils.direct_url_helpers import direct_url_as_pep440_direct_reference
 
 logger = logging.getLogger(__name__)
 
-RequirementInfo = Tuple[Optional[Union[str, Requirement]], bool, List[str]]
-
 
-def freeze(
-    requirement=None,  # type: Optional[List[str]]
-    find_links=None,  # type: Optional[List[str]]
-    local_only=False,  # type: bool
-    user_only=False,  # type: bool
-    paths=None,  # type: Optional[List[str]]
-    isolated=False,  # type: bool
-    exclude_editable=False,  # type: bool
-    skip=()  # type: Container[str]
-):
-    # type: (...) -> Iterator[str]
-    find_links = find_links or []
+class _EditableInfo(NamedTuple):
+    requirement: str
+    comments: List[str]
 
-    for link in find_links:
-        yield f'-f {link}'
-    installations = {}  # type: Dict[str, FrozenRequirement]
 
-    for dist in get_installed_distributions(
-            local_only=local_only,
-            skip=(),
-            user_only=user_only,
-            paths=paths
-    ):
-        try:
-            req = FrozenRequirement.from_dist(dist)
-        except RequirementParseError as exc:
-            # We include dist rather than dist.project_name because the
-            # dist string includes more information, like the version and
-            # location. We also include the exception message to aid
-            # troubleshooting.
-            logger.warning(
-                'Could not generate requirement for distribution %r: %s',
-                dist, exc
-            )
-            continue
+def freeze(
+    requirement: Optional[List[str]] = None,
+    local_only: bool = False,
+    user_only: bool = False,
+    paths: Optional[List[str]] = None,
+    isolated: bool = False,
+    exclude_editable: bool = False,
+    skip: Container[str] = (),
+) -> Generator[str, None, None]:
+    installations: Dict[str, FrozenRequirement] = {}
+
+    dists = get_environment(paths).iter_installed_distributions(
+        local_only=local_only,
+        skip=(),
+        user_only=user_only,
+    )
+    for dist in dists:
+        req = FrozenRequirement.from_dist(dist)
         if exclude_editable and req.editable:
             continue
         installations[req.canonical_name] = req
@@ -77,42 +50,50 @@ def freeze(
         # should only be emitted once, even if the same option is in multiple
         # requirements files, so we need to keep track of what has been emitted
         # so that we don't emit it again if it's seen again
-        emitted_options = set()  # type: Set[str]
+        emitted_options: Set[str] = set()
         # keep track of which files a requirement is in so that we can
         # give an accurate warning if a requirement appears multiple times.
-        req_files = collections.defaultdict(list)  # type: Dict[str, List[str]]
+        req_files: Dict[str, List[str]] = collections.defaultdict(list)
         for req_file_path in requirement:
             with open(req_file_path) as req_file:
                 for line in req_file:
-                    if (not line.strip() or
-                            line.strip().startswith('#') or
-                            line.startswith((
-                                '-r', '--requirement',
-                                '-f', '--find-links',
-                                '-i', '--index-url',
-                                '--pre',
-                                '--trusted-host',
-                                '--process-dependency-links',
-                                '--extra-index-url',
-                                '--use-feature'))):
+                    if (
+                        not line.strip()
+                        or line.strip().startswith("#")
+                        or line.startswith(
+                            (
+                                "-r",
+                                "--requirement",
+                                "-f",
+                                "--find-links",
+                                "-i",
+                                "--index-url",
+                                "--pre",
+                                "--trusted-host",
+                                "--process-dependency-links",
+                                "--extra-index-url",
+                                "--use-feature",
+                            )
+                        )
+                    ):
                         line = line.rstrip()
                         if line not in emitted_options:
                             emitted_options.add(line)
                             yield line
                         continue
 
-                    if line.startswith('-e') or line.startswith('--editable'):
-                        if line.startswith('-e'):
+                    if line.startswith("-e") or line.startswith("--editable"):
+                        if line.startswith("-e"):
                             line = line[2:].strip()
                         else:
-                            line = line[len('--editable'):].strip().lstrip('=')
+                            line = line[len("--editable") :].strip().lstrip("=")
                         line_req = install_req_from_editable(
                             line,
                             isolated=isolated,
                         )
                     else:
                         line_req = install_req_from_line(
-                            COMMENT_RE.sub('', line).strip(),
+                            COMMENT_RE.sub("", line).strip(),
                             isolated=isolated,
                         )
 
@@ -120,15 +101,15 @@ def freeze(
                         logger.info(
                             "Skipping line in requirement file [%s] because "
                             "it's not clear what it would install: %s",
-                            req_file_path, line.strip(),
+                            req_file_path,
+                            line.strip(),
                         )
                         logger.info(
                             "  (add #egg=PackageName to the URL to avoid"
                             " this warning)"
                         )
                     else:
-                        line_req_canonical_name = canonicalize_name(
-                            line_req.name)
+                        line_req_canonical_name = canonicalize_name(line_req.name)
                         if line_req_canonical_name not in installations:
                             # either it's not installed, or it is installed
                             # but has been processed already
@@ -137,14 +118,13 @@ def freeze(
                                     "Requirement file [%s] contains %s, but "
                                     "package %r is not installed",
                                     req_file_path,
-                                    COMMENT_RE.sub('', line).strip(),
-                                    line_req.name
+                                    COMMENT_RE.sub("", line).strip(),
+                                    line_req.name,
                                 )
                             else:
                                 req_files[line_req.name].append(req_file_path)
                         else:
-                            yield str(installations[
-                                line_req_canonical_name]).rstrip()
+                            yield str(installations[line_req_canonical_name]).rstrip()
                             del installations[line_req_canonical_name]
                             req_files[line_req.name].append(req_file_path)
 
@@ -152,83 +132,99 @@ def freeze(
         # single requirements file or in different requirements files).
         for name, files in req_files.items():
             if len(files) > 1:
-                logger.warning("Requirement %s included multiple times [%s]",
-                               name, ', '.join(sorted(set(files))))
+                logger.warning(
+                    "Requirement %s included multiple times [%s]",
+                    name,
+                    ", ".join(sorted(set(files))),
+                )
 
-        yield(
-            '## The following requirements were added by '
-            'pip freeze:'
-        )
-    for installation in sorted(
-            installations.values(), key=lambda x: x.name.lower()):
+        yield ("## The following requirements were added by pip freeze:")
+    for installation in sorted(installations.values(), key=lambda x: x.name.lower()):
         if installation.canonical_name not in skip:
             yield str(installation).rstrip()
 
 
-def get_requirement_info(dist):
-    # type: (Distribution) -> RequirementInfo
+def _format_as_name_version(dist: BaseDistribution) -> str:
+    dist_version = dist.version
+    if isinstance(dist_version, Version):
+        return f"{dist.raw_name}=={dist_version}"
+    return f"{dist.raw_name}==={dist_version}"
+
+
+def _get_editable_info(dist: BaseDistribution) -> _EditableInfo:
     """
-    Compute and return values (req, editable, comments) for use in
+    Compute and return values (req, comments) for use in
     FrozenRequirement.from_dist().
     """
-    if not dist_is_editable(dist):
-        return (None, False, [])
+    editable_project_location = dist.editable_project_location
+    assert editable_project_location
+    location = os.path.normcase(os.path.abspath(editable_project_location))
 
-    location = os.path.normcase(os.path.abspath(dist.location))
+    from pip._internal.vcs import RemoteNotFoundError, RemoteNotValidError, vcs
 
-    from pip._internal.vcs import RemoteNotFoundError, vcs
     vcs_backend = vcs.get_backend_for_dir(location)
 
     if vcs_backend is None:
-        req = dist.as_requirement()
+        display = _format_as_name_version(dist)
         logger.debug(
-            'No VCS found for editable requirement "%s" in: %r', req,
+            'No VCS found for editable requirement "%s" in: %r',
+            display,
             location,
         )
-        comments = [
-            f'# Editable install with no version control ({req})'
-        ]
-        return (location, True, comments)
+        return _EditableInfo(
+            requirement=location,
+            comments=[f"# Editable install with no version control ({display})"],
+        )
+
+    vcs_name = type(vcs_backend).__name__
 
     try:
-        req = vcs_backend.get_src_requirement(location, dist.project_name)
+        req = vcs_backend.get_src_requirement(location, dist.raw_name)
     except RemoteNotFoundError:
-        req = dist.as_requirement()
-        comments = [
-            '# Editable {} install with no remote ({})'.format(
-                type(vcs_backend).__name__, req,
-            )
-        ]
-        return (location, True, comments)
-
+        display = _format_as_name_version(dist)
+        return _EditableInfo(
+            requirement=location,
+            comments=[f"# Editable {vcs_name} install with no remote ({display})"],
+        )
+    except RemoteNotValidError as ex:
+        display = _format_as_name_version(dist)
+        return _EditableInfo(
+            requirement=location,
+            comments=[
+                f"# Editable {vcs_name} install ({display}) with either a deleted "
+                f"local remote or invalid URI:",
+                f"# '{ex.url}'",
+            ],
+        )
     except BadCommand:
         logger.warning(
-            'cannot determine version of editable source in %s '
-            '(%s command not found in path)',
+            "cannot determine version of editable source in %s "
+            "(%s command not found in path)",
             location,
             vcs_backend.name,
         )
-        return (None, True, [])
-
+        return _EditableInfo(requirement=location, comments=[])
     except InstallationError as exc:
-        logger.warning(
-            "Error when trying to get requirement for VCS system %s, "
-            "falling back to uneditable format", exc
-        )
+        logger.warning("Error when trying to get requirement for VCS system %s", exc)
     else:
-        return (req, True, [])
+        return _EditableInfo(requirement=req, comments=[])
 
-    logger.warning(
-        'Could not determine repository location of %s', location
-    )
-    comments = ['## !! Could not determine repository location']
+    logger.warning("Could not determine repository location of %s", location)
 
-    return (None, False, comments)
+    return _EditableInfo(
+        requirement=location,
+        comments=["## !! Could not determine repository location"],
+    )
 
 
 class FrozenRequirement:
-    def __init__(self, name, req, editable, comments=()):
-        # type: (str, Union[str, Requirement], bool, Iterable[str]) -> None
+    def __init__(
+        self,
+        name: str,
+        req: str,
+        editable: bool,
+        comments: Iterable[str] = (),
+    ) -> None:
         self.name = name
         self.canonical_name = canonicalize_name(name)
         self.req = req
@@ -236,29 +232,24 @@ class FrozenRequirement:
         self.comments = comments
 
     @classmethod
-    def from_dist(cls, dist):
-        # type: (Distribution) -> FrozenRequirement
-        # TODO `get_requirement_info` is taking care of editable requirements.
-        # TODO This should be refactored when we will add detection of
-        #      editable that provide .dist-info metadata.
-        req, editable, comments = get_requirement_info(dist)
-        if req is None and not editable:
-            # if PEP 610 metadata is present, attempt to use it
-            direct_url = dist_get_direct_url(dist)
+    def from_dist(cls, dist: BaseDistribution) -> "FrozenRequirement":
+        editable = dist.editable
+        if editable:
+            req, comments = _get_editable_info(dist)
+        else:
+            comments = []
+            direct_url = dist.direct_url
             if direct_url:
-                req = direct_url_as_pep440_direct_reference(
-                    direct_url, dist.project_name
-                )
-                comments = []
-        if req is None:
-            # name==version requirement
-            req = dist.as_requirement()
+                # if PEP 610 metadata is present, use it
+                req = direct_url_as_pep440_direct_reference(direct_url, dist.raw_name)
+            else:
+                # name==version requirement
+                req = _format_as_name_version(dist)
 
-        return cls(dist.project_name, req, editable, comments=comments)
+        return cls(dist.raw_name, req, editable, comments=comments)
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         req = self.req
         if self.editable:
-            req = f'-e {req}'
-        return '\n'.join(list(self.comments) + [str(req)]) + '\n'
+            req = f"-e {req}"
+        return "\n".join(list(self.comments) + [str(req)]) + "\n"
diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 9a65ac0c0f5bbfdfe368092284022fe9c568d9b6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 288
zcmYe~<>g{vU|^UdaWK`Gfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}V&-13VQ
za`RJ4b5e^Hic)hDOHxx5O7ayl^NLFnb8<5C(iI94ld}`kQ;YSu{4^PFvB$@!<R{0+
zuVg4<Vqky}zj~dmVnT~ki;81Xb5b&kV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!
z{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgvZ=#}s51
z=*MT~m82HsCFbbo7o-*?mSpDV73)JCsvjSpnU`4-AFo$Xd5gma;v+kduRnu=0RRrE
BRSy6F

diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/editable_legacy.cpython-39.pyc
deleted file mode 100644
index cee2f90ad4a6ea80e854079da5d3fd9c0f8cdbf9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1331
zcmYe~<>g{vU|^UdaWJ)nm4V?gh=Yuo85kHG7#J9e(-;^SQW&BbQW#U1au}l+Qy5d2
zbC`0OqnLA9qF8cSqgWY1ax6J)x$IHwU^Z(GM=oa+Cz#Ea!<EY&#SLb&=kVn6M)5K-
zq%tnxOXXk47$uOxk;2)+5G9zx6wIK>Rb}s!nx2?ksgRnIS(2EPld6!JS6q^qlapAI
znV+XnP?VpXT3oE7kg1odr;t#bT2fk|S5T>tl3JFUlV6aa$Mq8A1wT#ZTP!}A#U-~m
z{0l%D6LW5H1g933rsgH5YBJsua4OBrNpa09%Ph*z%T3KI(PX^Em6?~4npYB^lb^21
zcuOWXF*`LLY<@|8eok>b)Q0%PqV!@-##{W!i8(p(#idD57bSzk5@a_60|Pe$0|O@m
z1A{Xt^lBIw7)lrxFs3lpur6d`WGG>(VXI-RVW?rRVX9%SVM$@?Wv}HbVQyyVcVJ|w
z;pmrPWGG>&;i}<GVeVyOWC&+SVPRolVQ6M%WXKaRWGD_WU|<BpNCqsjdC0OUEWr$#
ztX0vTkT6t8R47PH&Q44Rg(@P1bMsSD^%Q*bi%S#|i_%L$;ZdxRSd^+zkXT%-Tar<f
zUz(o5rJ$goP?E2J2ogQ8P?da8X<lAtUOGeuDKZq&@{1Hyi#6G9@ulbFCne^@=Y!*-
z_!d7jPT>N4dHM0B#i>Q{$@zI{nd!IK3W`$GGAnMeWaQ_j-r_ASPK8JpXO@7Xk2$$K
z#ZQy<7F$k!dU|TnEtbr@wEQA=1_p*AHW0zVz`&r%T?C4fB2YXO@qk2mK?ENI1H&zr
zyhM<(V6Vg%RK^!1mSo)G$Sls!Ni0cCxy6|TN*(d3d1bdGOY=Y>mYNb@oL^d$oEo2!
zS(KVwl3!GLiv^StRx%VxFfcIun&NB~6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e
z8Wijq;ux&p>F46_=Njzk7!&O3>lz&58l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>b
z1M;jc$o9na)Z&<e%mV%R%)FA+qP)Z${rrN|B5;l<)`y0rJ}kq;=YTViUP0w80jOL&
zOb+DxVg*nt72siFVnl&I*|<0u*&t&7iljh6D0GWGK0YNsIX?atJ1D3#^U`mzl~fjF
z=A{=gfkG2hL=>@rf>gX9vp^5-K0SB{7O{e4rBP)|OEPnc^`It#qwJOnHWlCqf@D9i
zf#4{<C5KfhJSP@`V*eIrdTNOeBz17a$AjWKKE6l*<Yti1z>$VTNP-;6VUwGmQks)$
X#|X-{Ahj$^9E>7NJd9w-#KjB%Y~g}0

diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/legacy.cpython-39.pyc
deleted file mode 100644
index 169e89e976b5a41b8890758f11cda62494d5cc2f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/operations/install/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index 7e73e396d930cefd1f44f6945a056b33128e6174..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 20841
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
Vd&9`^gR7pQp23NQkxKw30szjCOLPDL

diff --git a/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py b/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py
index 6882c475..bebe24e6 100644
--- a/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py
+++ b/env/Lib/site-packages/pip/_internal/operations/install/editable_legacy.py
@@ -1,7 +1,7 @@
 """Legacy editable installation process, i.e. `setup.py develop`.
 """
 import logging
-from typing import List, Optional, Sequence
+from typing import Optional, Sequence
 
 from pip._internal.build_env import BuildEnvironment
 from pip._internal.utils.logging import indent_log
@@ -12,27 +12,25 @@ logger = logging.getLogger(__name__)
 
 
 def install_editable(
-    install_options,  # type: List[str]
-    global_options,  # type: Sequence[str]
-    prefix,  # type: Optional[str]
-    home,  # type: Optional[str]
-    use_user_site,  # type: bool
-    name,  # type: str
-    setup_py_path,  # type: str
-    isolated,  # type: bool
-    build_env,  # type: BuildEnvironment
-    unpacked_source_directory,  # type: str
-):
-    # type: (...) -> None
+    *,
+    global_options: Sequence[str],
+    prefix: Optional[str],
+    home: Optional[str],
+    use_user_site: bool,
+    name: str,
+    setup_py_path: str,
+    isolated: bool,
+    build_env: BuildEnvironment,
+    unpacked_source_directory: str,
+) -> None:
     """Install a package in editable mode. Most arguments are pass-through
     to setuptools.
     """
-    logger.info('Running setup.py develop for %s', name)
+    logger.info("Running setup.py develop for %s", name)
 
     args = make_setuptools_develop_args(
         setup_py_path,
         global_options=global_options,
-        install_options=install_options,
         no_user_config=isolated,
         prefix=prefix,
         home=home,
@@ -43,5 +41,6 @@ def install_editable(
         with build_env:
             call_subprocess(
                 args,
+                command_desc="python setup.py develop",
                 cwd=unpacked_source_directory,
             )
diff --git a/env/Lib/site-packages/pip/_internal/operations/install/legacy.py b/env/Lib/site-packages/pip/_internal/operations/install/legacy.py
deleted file mode 100644
index 41d0c1f9..00000000
--- a/env/Lib/site-packages/pip/_internal/operations/install/legacy.py
+++ /dev/null
@@ -1,125 +0,0 @@
-"""Legacy installation process, i.e. `setup.py install`.
-"""
-
-import logging
-import os
-import sys
-from distutils.util import change_root
-from typing import List, Optional, Sequence
-
-from pip._internal.build_env import BuildEnvironment
-from pip._internal.exceptions import InstallationError
-from pip._internal.models.scheme import Scheme
-from pip._internal.utils.logging import indent_log
-from pip._internal.utils.misc import ensure_dir
-from pip._internal.utils.setuptools_build import make_setuptools_install_args
-from pip._internal.utils.subprocess import runner_with_spinner_message
-from pip._internal.utils.temp_dir import TempDirectory
-
-logger = logging.getLogger(__name__)
-
-
-class LegacyInstallFailure(Exception):
-    def __init__(self):
-        # type: () -> None
-        self.parent = sys.exc_info()
-
-
-def install(
-    install_options,  # type: List[str]
-    global_options,  # type: Sequence[str]
-    root,  # type: Optional[str]
-    home,  # type: Optional[str]
-    prefix,  # type: Optional[str]
-    use_user_site,  # type: bool
-    pycompile,  # type: bool
-    scheme,  # type: Scheme
-    setup_py_path,  # type: str
-    isolated,  # type: bool
-    req_name,  # type: str
-    build_env,  # type: BuildEnvironment
-    unpacked_source_directory,  # type: str
-    req_description,  # type: str
-):
-    # type: (...) -> bool
-
-    header_dir = scheme.headers
-
-    with TempDirectory(kind="record") as temp_dir:
-        try:
-            record_filename = os.path.join(temp_dir.path, 'install-record.txt')
-            install_args = make_setuptools_install_args(
-                setup_py_path,
-                global_options=global_options,
-                install_options=install_options,
-                record_filename=record_filename,
-                root=root,
-                prefix=prefix,
-                header_dir=header_dir,
-                home=home,
-                use_user_site=use_user_site,
-                no_user_config=isolated,
-                pycompile=pycompile,
-            )
-
-            runner = runner_with_spinner_message(
-                f"Running setup.py install for {req_name}"
-            )
-            with indent_log(), build_env:
-                runner(
-                    cmd=install_args,
-                    cwd=unpacked_source_directory,
-                )
-
-            if not os.path.exists(record_filename):
-                logger.debug('Record file %s not found', record_filename)
-                # Signal to the caller that we didn't install the new package
-                return False
-
-        except Exception:
-            # Signal to the caller that we didn't install the new package
-            raise LegacyInstallFailure
-
-        # At this point, we have successfully installed the requirement.
-
-        # We intentionally do not use any encoding to read the file because
-        # setuptools writes the file using distutils.file_util.write_file,
-        # which does not specify an encoding.
-        with open(record_filename) as f:
-            record_lines = f.read().splitlines()
-
-    def prepend_root(path):
-        # type: (str) -> str
-        if root is None or not os.path.isabs(path):
-            return path
-        else:
-            return change_root(root, path)
-
-    for line in record_lines:
-        directory = os.path.dirname(line)
-        if directory.endswith('.egg-info'):
-            egg_info_dir = prepend_root(directory)
-            break
-    else:
-        message = (
-            "{} did not indicate that it installed an "
-            ".egg-info directory. Only setup.py projects "
-            "generating .egg-info directories are supported."
-        ).format(req_description)
-        raise InstallationError(message)
-
-    new_lines = []
-    for line in record_lines:
-        filename = line.strip()
-        if os.path.isdir(filename):
-            filename += os.path.sep
-        new_lines.append(
-            os.path.relpath(prepend_root(filename), egg_info_dir)
-        )
-    new_lines.sort()
-    ensure_dir(egg_info_dir)
-    inst_files_path = os.path.join(egg_info_dir, 'installed-files.txt')
-    with open(inst_files_path, 'w') as f:
-        f.write('\n'.join(new_lines) + '\n')
-
-    return True
diff --git a/env/Lib/site-packages/pip/_internal/operations/install/wheel.py b/env/Lib/site-packages/pip/_internal/operations/install/wheel.py
index 10e5b15f..a8cd1330 100644
--- a/env/Lib/site-packages/pip/_internal/operations/install/wheel.py
+++ b/env/Lib/site-packages/pip/_internal/operations/install/wheel.py
@@ -22,6 +22,7 @@ from typing import (
     BinaryIO,
     Callable,
     Dict,
+    Generator,
     Iterable,
     Iterator,
     List,
@@ -35,14 +36,17 @@ from typing import (
 )
 from zipfile import ZipFile, ZipInfo
 
-from pip._vendor import pkg_resources
 from pip._vendor.distlib.scripts import ScriptMaker
 from pip._vendor.distlib.util import get_export_entry
-from pip._vendor.pkg_resources import Distribution
-from pip._vendor.six import ensure_str, ensure_text, reraise
+from pip._vendor.packaging.utils import canonicalize_name
 
 from pip._internal.exceptions import InstallationError
 from pip._internal.locations import get_major_minor_version
+from pip._internal.metadata import (
+    BaseDistribution,
+    FilesystemWheel,
+    get_wheel_distribution,
+)
 from pip._internal.models.direct_url import DIRECT_URL_METADATA_NAME, DirectUrl
 from pip._internal.models.scheme import SCHEME_KEYS, Scheme
 from pip._internal.utils.filesystem import adjacent_tmp_file, replace
@@ -53,98 +57,76 @@ from pip._internal.utils.unpacking import (
     set_extracted_file_to_default_mode_plus_executable,
     zip_item_is_executable,
 )
-from pip._internal.utils.wheel import parse_wheel, pkg_resources_distribution_for_wheel
+from pip._internal.utils.wheel import parse_wheel
 
 if TYPE_CHECKING:
     from typing import Protocol
 
     class File(Protocol):
-        src_record_path = None  # type: RecordPath
-        dest_path = None  # type: str
-        changed = None  # type: bool
+        src_record_path: "RecordPath"
+        dest_path: str
+        changed: bool
 
-        def save(self):
-            # type: () -> None
+        def save(self) -> None:
             pass
 
 
 logger = logging.getLogger(__name__)
 
-RecordPath = NewType('RecordPath', str)
+RecordPath = NewType("RecordPath", str)
 InstalledCSVRow = Tuple[RecordPath, str, Union[int, str]]
 
 
-def rehash(path, blocksize=1 << 20):
-    # type: (str, int) -> Tuple[str, str]
+def rehash(path: str, blocksize: int = 1 << 20) -> Tuple[str, str]:
     """Return (encoded_digest, length) for path using hashlib.sha256()"""
     h, length = hash_file(path, blocksize)
-    digest = 'sha256=' + urlsafe_b64encode(
-        h.digest()
-    ).decode('latin1').rstrip('=')
+    digest = "sha256=" + urlsafe_b64encode(h.digest()).decode("latin1").rstrip("=")
     return (digest, str(length))
 
 
-def csv_io_kwargs(mode):
-    # type: (str) -> Dict[str, Any]
+def csv_io_kwargs(mode: str) -> Dict[str, Any]:
     """Return keyword arguments to properly open a CSV file
     in the given mode.
     """
-    return {'mode': mode, 'newline': '', 'encoding': 'utf-8'}
+    return {"mode": mode, "newline": "", "encoding": "utf-8"}
 
 
-def fix_script(path):
-    # type: (str) -> bool
+def fix_script(path: str) -> bool:
     """Replace #!python with #!/path/to/python
     Return True if file was changed.
     """
     # XXX RECORD hashes will need to be updated
     assert os.path.isfile(path)
 
-    with open(path, 'rb') as script:
+    with open(path, "rb") as script:
         firstline = script.readline()
-        if not firstline.startswith(b'#!python'):
+        if not firstline.startswith(b"#!python"):
             return False
         exename = sys.executable.encode(sys.getfilesystemencoding())
-        firstline = b'#!' + exename + os.linesep.encode("ascii")
+        firstline = b"#!" + exename + os.linesep.encode("ascii")
         rest = script.read()
-    with open(path, 'wb') as script:
+    with open(path, "wb") as script:
         script.write(firstline)
         script.write(rest)
     return True
 
 
-def wheel_root_is_purelib(metadata):
-    # type: (Message) -> bool
+def wheel_root_is_purelib(metadata: Message) -> bool:
     return metadata.get("Root-Is-Purelib", "").lower() == "true"
 
 
-def get_entrypoints(distribution):
-    # type: (Distribution) -> Tuple[Dict[str, str], Dict[str, str]]
-    # get the entry points and then the script names
-    try:
-        console = distribution.get_entry_map('console_scripts')
-        gui = distribution.get_entry_map('gui_scripts')
-    except KeyError:
-        # Our dict-based Distribution raises KeyError if entry_points.txt
-        # doesn't exist.
-        return {}, {}
-
-    def _split_ep(s):
-        # type: (pkg_resources.EntryPoint) -> Tuple[str, str]
-        """get the string representation of EntryPoint,
-        remove space and split on '='
-        """
-        split_parts = str(s).replace(" ", "").split("=")
-        return split_parts[0], split_parts[1]
-
-    # convert the EntryPoint objects into strings with module:function
-    console = dict(_split_ep(v) for v in console.values())
-    gui = dict(_split_ep(v) for v in gui.values())
-    return console, gui
-
-
-def message_about_scripts_not_on_PATH(scripts):
-    # type: (Sequence[str]) -> Optional[str]
+def get_entrypoints(dist: BaseDistribution) -> Tuple[Dict[str, str], Dict[str, str]]:
+    console_scripts = {}
+    gui_scripts = {}
+    for entry_point in dist.iter_entry_points():
+        if entry_point.group == "console_scripts":
+            console_scripts[entry_point.name] = entry_point.value
+        elif entry_point.group == "gui_scripts":
+            gui_scripts[entry_point.name] = entry_point.value
+    return console_scripts, gui_scripts
+
+
+def message_about_scripts_not_on_PATH(scripts: Sequence[str]) -> Optional[str]:
     """Determine if any scripts are not on PATH and format a warning.
     Returns a warning message if one or more scripts are not on PATH,
     otherwise None.
@@ -153,7 +135,7 @@ def message_about_scripts_not_on_PATH(scripts):
         return None
 
     # Group scripts by the path they were installed in
-    grouped_by_dir = collections.defaultdict(set)  # type: Dict[str, Set[str]]
+    grouped_by_dir: Dict[str, Set[str]] = collections.defaultdict(set)
     for destfile in scripts:
         parent_dir = os.path.dirname(destfile)
         script_name = os.path.basename(destfile)
@@ -161,23 +143,26 @@ def message_about_scripts_not_on_PATH(scripts):
 
     # We don't want to warn for directories that are on PATH.
     not_warn_dirs = [
-        os.path.normcase(i).rstrip(os.sep) for i in
-        os.environ.get("PATH", "").split(os.pathsep)
+        os.path.normcase(os.path.normpath(i)).rstrip(os.sep)
+        for i in os.environ.get("PATH", "").split(os.pathsep)
     ]
     # If an executable sits with sys.executable, we don't warn for it.
     #     This covers the case of venv invocations without activating the venv.
-    not_warn_dirs.append(os.path.normcase(os.path.dirname(sys.executable)))
-    warn_for = {
-        parent_dir: scripts for parent_dir, scripts in grouped_by_dir.items()
-        if os.path.normcase(parent_dir) not in not_warn_dirs
-    }  # type: Dict[str, Set[str]]
+    not_warn_dirs.append(
+        os.path.normcase(os.path.normpath(os.path.dirname(sys.executable)))
+    )
+    warn_for: Dict[str, Set[str]] = {
+        parent_dir: scripts
+        for parent_dir, scripts in grouped_by_dir.items()
+        if os.path.normcase(os.path.normpath(parent_dir)) not in not_warn_dirs
+    }
     if not warn_for:
         return None
 
     # Format a message
     msg_lines = []
     for parent_dir, dir_scripts in warn_for.items():
-        sorted_scripts = sorted(dir_scripts)  # type: List[str]
+        sorted_scripts: List[str] = sorted(dir_scripts)
         if len(sorted_scripts) == 1:
             start_text = "script {} is".format(sorted_scripts[0])
         else:
@@ -186,8 +171,9 @@ def message_about_scripts_not_on_PATH(scripts):
             )
 
         msg_lines.append(
-            "The {} installed in '{}' which is not on PATH."
-            .format(start_text, parent_dir)
+            "The {} installed in '{}' which is not on PATH.".format(
+                start_text, parent_dir
+            )
         )
 
     last_line_fmt = (
@@ -214,8 +200,9 @@ def message_about_scripts_not_on_PATH(scripts):
     return "\n".join(msg_lines)
 
 
-def _normalized_outrows(outrows):
-    # type: (Iterable[InstalledCSVRow]) -> List[Tuple[str, str, str]]
+def _normalized_outrows(
+    outrows: Iterable[InstalledCSVRow],
+) -> List[Tuple[str, str, str]]:
     """Normalize the given rows of a RECORD file.
 
     Items in each row are converted into str. Rows are then sorted to make
@@ -235,69 +222,57 @@ def _normalized_outrows(outrows):
     # For additional background, see--
     # https://github.com/pypa/pip/issues/5868
     return sorted(
-        (ensure_str(record_path, encoding='utf-8'), hash_, str(size))
-        for record_path, hash_, size in outrows
+        (record_path, hash_, str(size)) for record_path, hash_, size in outrows
     )
 
 
-def _record_to_fs_path(record_path):
-    # type: (RecordPath) -> str
-    return record_path
-
+def _record_to_fs_path(record_path: RecordPath, lib_dir: str) -> str:
+    return os.path.join(lib_dir, record_path)
 
-def _fs_to_record_path(path, relative_to=None):
-    # type: (str, Optional[str]) -> RecordPath
-    if relative_to is not None:
-        # On Windows, do not handle relative paths if they belong to different
-        # logical disks
-        if os.path.splitdrive(path)[0].lower() == \
-                os.path.splitdrive(relative_to)[0].lower():
-            path = os.path.relpath(path, relative_to)
-    path = path.replace(os.path.sep, '/')
-    return cast('RecordPath', path)
 
+def _fs_to_record_path(path: str, lib_dir: str) -> RecordPath:
+    # On Windows, do not handle relative paths if they belong to different
+    # logical disks
+    if os.path.splitdrive(path)[0].lower() == os.path.splitdrive(lib_dir)[0].lower():
+        path = os.path.relpath(path, lib_dir)
 
-def _parse_record_path(record_column):
-    # type: (str) -> RecordPath
-    p = ensure_text(record_column, encoding='utf-8')
-    return cast('RecordPath', p)
+    path = path.replace(os.path.sep, "/")
+    return cast("RecordPath", path)
 
 
 def get_csv_rows_for_installed(
-    old_csv_rows,  # type: List[List[str]]
-    installed,  # type: Dict[RecordPath, RecordPath]
-    changed,  # type: Set[RecordPath]
-    generated,  # type: List[str]
-    lib_dir,  # type: str
-):
-    # type: (...) -> List[InstalledCSVRow]
+    old_csv_rows: List[List[str]],
+    installed: Dict[RecordPath, RecordPath],
+    changed: Set[RecordPath],
+    generated: List[str],
+    lib_dir: str,
+) -> List[InstalledCSVRow]:
     """
     :param installed: A map from archive RECORD path to installation RECORD
         path.
     """
-    installed_rows = []  # type: List[InstalledCSVRow]
+    installed_rows: List[InstalledCSVRow] = []
     for row in old_csv_rows:
         if len(row) > 3:
-            logger.warning('RECORD line has more than three elements: %s', row)
-        old_record_path = _parse_record_path(row[0])
+            logger.warning("RECORD line has more than three elements: %s", row)
+        old_record_path = cast("RecordPath", row[0])
         new_record_path = installed.pop(old_record_path, old_record_path)
         if new_record_path in changed:
-            digest, length = rehash(_record_to_fs_path(new_record_path))
+            digest, length = rehash(_record_to_fs_path(new_record_path, lib_dir))
         else:
-            digest = row[1] if len(row) > 1 else ''
-            length = row[2] if len(row) > 2 else ''
+            digest = row[1] if len(row) > 1 else ""
+            length = row[2] if len(row) > 2 else ""
         installed_rows.append((new_record_path, digest, length))
     for f in generated:
         path = _fs_to_record_path(f, lib_dir)
         digest, length = rehash(f)
         installed_rows.append((path, digest, length))
     for installed_record_path in installed.values():
-        installed_rows.append((installed_record_path, '', ''))
+        installed_rows.append((installed_record_path, "", ""))
     return installed_rows
 
 
-def get_console_script_specs(console):
-    # type: (Dict[str, str]) -> List[str]
+def get_console_script_specs(console: Dict[str, str]) -> List[str]:
     """
     Given the mapping from entrypoint name to callable, return the relevant
     console script specs.
@@ -340,62 +315,57 @@ def get_console_script_specs(console):
     # DEFAULT
     #   - The default behavior is to install pip, pipX, pipX.Y, easy_install
     #     and easy_install-X.Y.
-    pip_script = console.pop('pip', None)
+    pip_script = console.pop("pip", None)
     if pip_script:
         if "ENSUREPIP_OPTIONS" not in os.environ:
-            scripts_to_generate.append('pip = ' + pip_script)
+            scripts_to_generate.append("pip = " + pip_script)
 
         if os.environ.get("ENSUREPIP_OPTIONS", "") != "altinstall":
             scripts_to_generate.append(
-                'pip{} = {}'.format(sys.version_info[0], pip_script)
+                "pip{} = {}".format(sys.version_info[0], pip_script)
             )
 
-        scripts_to_generate.append(
-            f'pip{get_major_minor_version()} = {pip_script}'
-        )
+        scripts_to_generate.append(f"pip{get_major_minor_version()} = {pip_script}")
         # Delete any other versioned pip entry points
-        pip_ep = [k for k in console if re.match(r'pip(\d(\.\d)?)?$', k)]
+        pip_ep = [k for k in console if re.match(r"pip(\d+(\.\d+)?)?$", k)]
         for k in pip_ep:
             del console[k]
-    easy_install_script = console.pop('easy_install', None)
+    easy_install_script = console.pop("easy_install", None)
     if easy_install_script:
         if "ENSUREPIP_OPTIONS" not in os.environ:
-            scripts_to_generate.append(
-                'easy_install = ' + easy_install_script
-            )
+            scripts_to_generate.append("easy_install = " + easy_install_script)
 
         scripts_to_generate.append(
-            'easy_install-{} = {}'.format(
+            "easy_install-{} = {}".format(
                 get_major_minor_version(), easy_install_script
             )
         )
         # Delete any other versioned easy_install entry points
         easy_install_ep = [
-            k for k in console if re.match(r'easy_install(-\d\.\d)?$', k)
+            k for k in console if re.match(r"easy_install(-\d+\.\d+)?$", k)
         ]
         for k in easy_install_ep:
             del console[k]
 
     # Generate the console entry points specified in the wheel
-    scripts_to_generate.extend(starmap('{} = {}'.format, console.items()))
+    scripts_to_generate.extend(starmap("{} = {}".format, console.items()))
 
     return scripts_to_generate
 
 
 class ZipBackedFile:
-    def __init__(self, src_record_path, dest_path, zip_file):
-        # type: (RecordPath, str, ZipFile) -> None
+    def __init__(
+        self, src_record_path: RecordPath, dest_path: str, zip_file: ZipFile
+    ) -> None:
         self.src_record_path = src_record_path
         self.dest_path = dest_path
         self._zip_file = zip_file
         self.changed = False
 
-    def _getinfo(self):
-        # type: () -> ZipInfo
+    def _getinfo(self) -> ZipInfo:
         return self._zip_file.getinfo(self.src_record_path)
 
-    def save(self):
-        # type: () -> None
+    def save(self) -> None:
         # directory creation is lazy and after file filtering
         # to ensure we don't install empty dirs; empty dirs can't be
         # uninstalled.
@@ -424,22 +394,19 @@ class ZipBackedFile:
 
 
 class ScriptFile:
-    def __init__(self, file):
-        # type: (File) -> None
+    def __init__(self, file: "File") -> None:
         self._file = file
         self.src_record_path = self._file.src_record_path
         self.dest_path = self._file.dest_path
         self.changed = False
 
-    def save(self):
-        # type: () -> None
+    def save(self) -> None:
         self._file.save()
         self.changed = fix_script(self.dest_path)
 
 
 class MissingCallableSuffix(InstallationError):
-    def __init__(self, entry_point):
-        # type: (str) -> None
+    def __init__(self, entry_point: str) -> None:
         super().__init__(
             "Invalid script entry point: {} - A callable "
             "suffix is required. Cf https://packaging.python.org/"
@@ -448,31 +415,30 @@ class MissingCallableSuffix(InstallationError):
         )
 
 
-def _raise_for_invalid_entrypoint(specification):
-    # type: (str) -> None
+def _raise_for_invalid_entrypoint(specification: str) -> None:
     entry = get_export_entry(specification)
     if entry is not None and entry.suffix is None:
         raise MissingCallableSuffix(str(entry))
 
 
 class PipScriptMaker(ScriptMaker):
-    def make(self, specification, options=None):
-        # type: (str, Dict[str, Any]) -> List[str]
+    def make(
+        self, specification: str, options: Optional[Dict[str, Any]] = None
+    ) -> List[str]:
         _raise_for_invalid_entrypoint(specification)
         return super().make(specification, options)
 
 
 def _install_wheel(
-    name,  # type: str
-    wheel_zip,  # type: ZipFile
-    wheel_path,  # type: str
-    scheme,  # type: Scheme
-    pycompile=True,  # type: bool
-    warn_script_location=True,  # type: bool
-    direct_url=None,  # type: Optional[DirectUrl]
-    requested=False,  # type: bool
-):
-    # type: (...) -> None
+    name: str,
+    wheel_zip: ZipFile,
+    wheel_path: str,
+    scheme: Scheme,
+    pycompile: bool = True,
+    warn_script_location: bool = True,
+    direct_url: Optional[DirectUrl] = None,
+    requested: bool = False,
+) -> None:
     """Install a wheel.
 
     :param name: Name of the project to install
@@ -499,33 +465,23 @@ def _install_wheel(
     #   installed = files copied from the wheel to the destination
     #   changed = files changed while installing (scripts #! line typically)
     #   generated = files newly generated during the install (script wrappers)
-    installed = {}  # type: Dict[RecordPath, RecordPath]
-    changed = set()  # type: Set[RecordPath]
-    generated = []  # type: List[str]
+    installed: Dict[RecordPath, RecordPath] = {}
+    changed: Set[RecordPath] = set()
+    generated: List[str] = []
 
-    def record_installed(srcfile, destfile, modified=False):
-        # type: (RecordPath, str, bool) -> None
+    def record_installed(
+        srcfile: RecordPath, destfile: str, modified: bool = False
+    ) -> None:
         """Map archive RECORD paths to installation RECORD paths."""
         newpath = _fs_to_record_path(destfile, lib_dir)
         installed[srcfile] = newpath
         if modified:
-            changed.add(_fs_to_record_path(destfile))
-
-    def all_paths():
-        # type: () -> Iterable[RecordPath]
-        names = wheel_zip.namelist()
-        # If a flag is set, names may be unicode in Python 2. We convert to
-        # text explicitly so these are valid for lookup in RECORD.
-        decoded_names = map(ensure_text, names)
-        for name in decoded_names:
-            yield cast("RecordPath", name)
-
-    def is_dir_path(path):
-        # type: (RecordPath) -> bool
+            changed.add(newpath)
+
+    def is_dir_path(path: RecordPath) -> bool:
         return path.endswith("/")
 
-    def assert_no_path_traversal(dest_dir_path, target_path):
-        # type: (str, str) -> None
+    def assert_no_path_traversal(dest_dir_path: str, target_path: str) -> None:
         if not is_within_directory(dest_dir_path, target_path):
             message = (
                 "The wheel {!r} has a file {!r} trying to install"
@@ -535,10 +491,10 @@ def _install_wheel(
                 message.format(wheel_path, target_path, dest_dir_path)
             )
 
-    def root_scheme_file_maker(zip_file, dest):
-        # type: (ZipFile, str) -> Callable[[RecordPath], File]
-        def make_root_scheme_file(record_path):
-            # type: (RecordPath) -> File
+    def root_scheme_file_maker(
+        zip_file: ZipFile, dest: str
+    ) -> Callable[[RecordPath], "File"]:
+        def make_root_scheme_file(record_path: RecordPath) -> "File":
             normed_path = os.path.normpath(record_path)
             dest_path = os.path.join(dest, normed_path)
             assert_no_path_traversal(dest, dest_path)
@@ -546,17 +502,12 @@ def _install_wheel(
 
         return make_root_scheme_file
 
-    def data_scheme_file_maker(zip_file, scheme):
-        # type: (ZipFile, Scheme) -> Callable[[RecordPath], File]
-        scheme_paths = {}
-        for key in SCHEME_KEYS:
-            encoded_key = ensure_text(key)
-            scheme_paths[encoded_key] = ensure_text(
-                getattr(scheme, key), encoding=sys.getfilesystemencoding()
-            )
+    def data_scheme_file_maker(
+        zip_file: ZipFile, scheme: Scheme
+    ) -> Callable[[RecordPath], "File"]:
+        scheme_paths = {key: getattr(scheme, key) for key in SCHEME_KEYS}
 
-        def make_data_scheme_file(record_path):
-            # type: (RecordPath) -> File
+        def make_data_scheme_file(record_path: RecordPath) -> "File":
             normed_path = os.path.normpath(record_path)
             try:
                 _, scheme_key, dest_subpath = normed_path.split(os.path.sep, 2)
@@ -575,9 +526,7 @@ def _install_wheel(
                     "Unknown scheme key used in {}: {} (for file {!r}). .data"
                     " directory contents should be in subdirectories named"
                     " with a valid scheme key ({})"
-                ).format(
-                    wheel_path, scheme_key, record_path, valid_scheme_keys
-                )
+                ).format(wheel_path, scheme_key, record_path, valid_scheme_keys)
                 raise InstallationError(message)
 
             dest_path = os.path.join(scheme_path, dest_subpath)
@@ -586,30 +535,19 @@ def _install_wheel(
 
         return make_data_scheme_file
 
-    def is_data_scheme_path(path):
-        # type: (RecordPath) -> bool
+    def is_data_scheme_path(path: RecordPath) -> bool:
         return path.split("/", 1)[0].endswith(".data")
 
-    paths = all_paths()
+    paths = cast(List[RecordPath], wheel_zip.namelist())
     file_paths = filterfalse(is_dir_path, paths)
-    root_scheme_paths, data_scheme_paths = partition(
-        is_data_scheme_path, file_paths
-    )
+    root_scheme_paths, data_scheme_paths = partition(is_data_scheme_path, file_paths)
 
-    make_root_scheme_file = root_scheme_file_maker(
-        wheel_zip,
-        ensure_text(lib_dir, encoding=sys.getfilesystemencoding()),
-    )
-    files = map(make_root_scheme_file, root_scheme_paths)
+    make_root_scheme_file = root_scheme_file_maker(wheel_zip, lib_dir)
+    files: Iterator[File] = map(make_root_scheme_file, root_scheme_paths)
 
-    def is_script_scheme_path(path):
-        # type: (RecordPath) -> bool
+    def is_script_scheme_path(path: RecordPath) -> bool:
         parts = path.split("/", 2)
-        return (
-            len(parts) > 2 and
-            parts[0].endswith(".data") and
-            parts[1] == "scripts"
-        )
+        return len(parts) > 2 and parts[0].endswith(".data") and parts[1] == "scripts"
 
     other_scheme_paths, script_scheme_paths = partition(
         is_script_scheme_path, data_scheme_paths
@@ -620,32 +558,32 @@ def _install_wheel(
     files = chain(files, other_scheme_files)
 
     # Get the defined entry points
-    distribution = pkg_resources_distribution_for_wheel(
-        wheel_zip, name, wheel_path
+    distribution = get_wheel_distribution(
+        FilesystemWheel(wheel_path),
+        canonicalize_name(name),
     )
     console, gui = get_entrypoints(distribution)
 
-    def is_entrypoint_wrapper(file):
-        # type: (File) -> bool
+    def is_entrypoint_wrapper(file: "File") -> bool:
         # EP, EP.exe and EP-script.py are scripts generated for
         # entry point EP by setuptools
         path = file.dest_path
         name = os.path.basename(path)
-        if name.lower().endswith('.exe'):
+        if name.lower().endswith(".exe"):
             matchname = name[:-4]
-        elif name.lower().endswith('-script.py'):
+        elif name.lower().endswith("-script.py"):
             matchname = name[:-10]
         elif name.lower().endswith(".pya"):
             matchname = name[:-4]
         else:
             matchname = name
         # Ignore setuptools-generated scripts
-        return (matchname in console or matchname in gui)
+        return matchname in console or matchname in gui
 
-    script_scheme_files = map(make_data_scheme_file, script_scheme_paths)
-    script_scheme_files = filterfalse(
-        is_entrypoint_wrapper, script_scheme_files
+    script_scheme_files: Iterator[File] = map(
+        make_data_scheme_file, script_scheme_paths
     )
+    script_scheme_files = filterfalse(is_entrypoint_wrapper, script_scheme_files)
     script_scheme_files = map(ScriptFile, script_scheme_files)
     files = chain(files, script_scheme_files)
 
@@ -653,8 +591,7 @@ def _install_wheel(
         file.save()
         record_installed(file.src_record_path, file.dest_path, file.changed)
 
-    def pyc_source_file_paths():
-        # type: () -> Iterator[str]
+    def pyc_source_file_paths() -> Generator[str, None, None]:
         # We de-duplicate installation paths, since there can be overlap (e.g.
         # file in .data maps to same location as file in wheel root).
         # Sorting installation paths makes it easier to reproduce and debug
@@ -663,30 +600,21 @@ def _install_wheel(
             full_installed_path = os.path.join(lib_dir, installed_path)
             if not os.path.isfile(full_installed_path):
                 continue
-            if not full_installed_path.endswith('.py'):
+            if not full_installed_path.endswith(".py"):
                 continue
             yield full_installed_path
 
-    def pyc_output_path(path):
-        # type: (str) -> str
-        """Return the path the pyc file would have been written to.
-        """
+    def pyc_output_path(path: str) -> str:
+        """Return the path the pyc file would have been written to."""
         return importlib.util.cache_from_source(path)
 
     # Compile all of the pyc files for the installed files
     if pycompile:
         with captured_stdout() as stdout:
             with warnings.catch_warnings():
-                warnings.filterwarnings('ignore')
+                warnings.filterwarnings("ignore")
                 for path in pyc_source_file_paths():
-                    # Python 2's `compileall.compile_file` requires a str in
-                    # error cases, so we must convert to the native type.
-                    path_arg = ensure_str(
-                        path, encoding=sys.getfilesystemencoding()
-                    )
-                    success = compileall.compile_file(
-                        path_arg, force=True, quiet=True
-                    )
+                    success = compileall.compile_file(path, force=True, quiet=True)
                     if success:
                         pyc_path = pyc_output_path(path)
                         assert os.path.exists(pyc_path)
@@ -705,7 +633,7 @@ def _install_wheel(
     # Ensure we don't generate any variants for scripts because this is almost
     # never what somebody wants.
     # See https://bitbucket.org/pypa/distlib/issue/35/
-    maker.variants = {''}
+    maker.variants = {""}
 
     # This is required because otherwise distlib creates scripts that are not
     # executable.
@@ -715,14 +643,12 @@ def _install_wheel(
     # Generate the console and GUI entry points specified in the wheel
     scripts_to_generate = get_console_script_specs(console)
 
-    gui_scripts_to_generate = list(starmap('{} = {}'.format, gui.items()))
+    gui_scripts_to_generate = list(starmap("{} = {}".format, gui.items()))
 
     generated_console_scripts = maker.make_multiple(scripts_to_generate)
     generated.extend(generated_console_scripts)
 
-    generated.extend(
-        maker.make_multiple(gui_scripts_to_generate, {'gui': True})
-    )
+    generated.extend(maker.make_multiple(gui_scripts_to_generate, {"gui": True}))
 
     if warn_script_location:
         msg = message_about_scripts_not_on_PATH(generated_console_scripts)
@@ -732,8 +658,7 @@ def _install_wheel(
     generated_file_mode = 0o666 & ~current_umask()
 
     @contextlib.contextmanager
-    def _generate_file(path, **kwargs):
-        # type: (str, **Any) -> Iterator[BinaryIO]
+    def _generate_file(path: str, **kwargs: Any) -> Generator[BinaryIO, None, None]:
         with adjacent_tmp_file(path, **kwargs) as f:
             yield f
         os.chmod(f.name, generated_file_mode)
@@ -742,9 +667,9 @@ def _install_wheel(
     dest_info_dir = os.path.join(lib_dir, info_dir)
 
     # Record pip as the installer
-    installer_path = os.path.join(dest_info_dir, 'INSTALLER')
+    installer_path = os.path.join(dest_info_dir, "INSTALLER")
     with _generate_file(installer_path) as installer_file:
-        installer_file.write(b'pip\n')
+        installer_file.write(b"pip\n")
     generated.append(installer_path)
 
     # Record the PEP 610 direct URL reference
@@ -756,12 +681,12 @@ def _install_wheel(
 
     # Record the REQUESTED file
     if requested:
-        requested_path = os.path.join(dest_info_dir, 'REQUESTED')
+        requested_path = os.path.join(dest_info_dir, "REQUESTED")
         with open(requested_path, "wb"):
             pass
         generated.append(requested_path)
 
-    record_text = distribution.get_metadata('RECORD')
+    record_text = distribution.read_text("RECORD")
     record_rows = list(csv.reader(record_text.splitlines()))
 
     rows = get_csv_rows_for_installed(
@@ -769,42 +694,38 @@ def _install_wheel(
         installed=installed,
         changed=changed,
         generated=generated,
-        lib_dir=lib_dir)
+        lib_dir=lib_dir,
+    )
 
     # Record details of all files installed
-    record_path = os.path.join(dest_info_dir, 'RECORD')
+    record_path = os.path.join(dest_info_dir, "RECORD")
 
-    with _generate_file(record_path, **csv_io_kwargs('w')) as record_file:
-        # The type mypy infers for record_file is different for Python 3
-        # (typing.IO[Any]) and Python 2 (typing.BinaryIO). We explicitly
-        # cast to typing.IO[str] as a workaround.
-        writer = csv.writer(cast('IO[str]', record_file))
+    with _generate_file(record_path, **csv_io_kwargs("w")) as record_file:
+        # Explicitly cast to typing.IO[str] as a workaround for the mypy error:
+        # "writer" has incompatible type "BinaryIO"; expected "_Writer"
+        writer = csv.writer(cast("IO[str]", record_file))
         writer.writerows(_normalized_outrows(rows))
 
 
 @contextlib.contextmanager
-def req_error_context(req_description):
-    # type: (str) -> Iterator[None]
+def req_error_context(req_description: str) -> Generator[None, None, None]:
     try:
         yield
     except InstallationError as e:
         message = "For req: {}. {}".format(req_description, e.args[0])
-        reraise(
-            InstallationError, InstallationError(message), sys.exc_info()[2]
-        )
+        raise InstallationError(message) from e
 
 
 def install_wheel(
-    name,  # type: str
-    wheel_path,  # type: str
-    scheme,  # type: Scheme
-    req_description,  # type: str
-    pycompile=True,  # type: bool
-    warn_script_location=True,  # type: bool
-    direct_url=None,  # type: Optional[DirectUrl]
-    requested=False,  # type: bool
-):
-    # type: (...) -> None
+    name: str,
+    wheel_path: str,
+    scheme: Scheme,
+    req_description: str,
+    pycompile: bool = True,
+    warn_script_location: bool = True,
+    direct_url: Optional[DirectUrl] = None,
+    requested: bool = False,
+) -> None:
     with ZipFile(wheel_path, allowZip64=True) as z:
         with req_error_context(req_description):
             _install_wheel(
diff --git a/env/Lib/site-packages/pip/_internal/operations/prepare.py b/env/Lib/site-packages/pip/_internal/operations/prepare.py
index 3d074f9f..cb121bcb 100644
--- a/env/Lib/site-packages/pip/_internal/operations/prepare.py
+++ b/env/Lib/site-packages/pip/_internal/operations/prepare.py
@@ -8,10 +8,9 @@ import logging
 import mimetypes
 import os
 import shutil
-from typing import Dict, Iterable, List, Optional, Tuple
+from typing import Dict, Iterable, List, Optional
 
 from pip._vendor.packaging.utils import canonicalize_name
-from pip._vendor.pkg_resources import Distribution
 
 from pip._internal.distributions import make_distribution_for_install_requirement
 from pip._internal.distributions.installed import InstalledDistribution
@@ -20,11 +19,14 @@ from pip._internal.exceptions import (
     HashMismatch,
     HashUnpinned,
     InstallationError,
+    MetadataInconsistent,
     NetworkConnectionError,
     PreviousBuildDirError,
     VcsHashUnsupported,
 )
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata import BaseDistribution, get_metadata_distribution
+from pip._internal.models.direct_url import ArchiveInfo
 from pip._internal.models.link import Link
 from pip._internal.models.wheel import Wheel
 from pip._internal.network.download import BatchDownloader, Downloader
@@ -33,13 +35,20 @@ from pip._internal.network.lazy_wheel import (
     dist_from_wheel_url,
 )
 from pip._internal.network.session import PipSession
+from pip._internal.operations.build.build_tracker import BuildTracker
 from pip._internal.req.req_install import InstallRequirement
-from pip._internal.req.req_tracker import RequirementTracker
-from pip._internal.utils.deprecation import deprecated
-from pip._internal.utils.filesystem import copy2_fixed
+from pip._internal.utils.direct_url_helpers import (
+    direct_url_for_editable,
+    direct_url_from_link,
+)
 from pip._internal.utils.hashes import Hashes, MissingHashes
 from pip._internal.utils.logging import indent_log
-from pip._internal.utils.misc import display_path, hide_url, rmtree
+from pip._internal.utils.misc import (
+    display_path,
+    hash_file,
+    hide_url,
+    is_installable_dir,
+)
 from pip._internal.utils.temp_dir import TempDirectory
 from pip._internal.utils.unpacking import unpack_file
 from pip._internal.vcs import vcs
@@ -48,30 +57,29 @@ logger = logging.getLogger(__name__)
 
 
 def _get_prepared_distribution(
-    req,  # type: InstallRequirement
-    req_tracker,  # type: RequirementTracker
-    finder,  # type: PackageFinder
-    build_isolation,  # type: bool
-):
-    # type: (...) -> Distribution
+    req: InstallRequirement,
+    build_tracker: BuildTracker,
+    finder: PackageFinder,
+    build_isolation: bool,
+    check_build_deps: bool,
+) -> BaseDistribution:
     """Prepare a distribution for installation."""
     abstract_dist = make_distribution_for_install_requirement(req)
-    with req_tracker.track(req):
-        abstract_dist.prepare_distribution_metadata(finder, build_isolation)
-    return abstract_dist.get_pkg_resources_distribution()
+    with build_tracker.track(req):
+        abstract_dist.prepare_distribution_metadata(
+            finder, build_isolation, check_build_deps
+        )
+    return abstract_dist.get_metadata_distribution()
 
 
-def unpack_vcs_link(link, location):
-    # type: (Link, str) -> None
+def unpack_vcs_link(link: Link, location: str, verbosity: int) -> None:
     vcs_backend = vcs.get_backend_for_scheme(link.scheme)
     assert vcs_backend is not None
-    vcs_backend.unpack(location, url=hide_url(link.url))
+    vcs_backend.unpack(location, url=hide_url(link.url), verbosity=verbosity)
 
 
 class File:
-
-    def __init__(self, path, content_type):
-        # type: (str, Optional[str]) -> None
+    def __init__(self, path: str, content_type: Optional[str]) -> None:
         self.path = path
         if content_type is None:
             self.content_type = mimetypes.guess_type(path)[0]
@@ -80,19 +88,16 @@ class File:
 
 
 def get_http_url(
-    link,  # type: Link
-    download,  # type: Downloader
-    download_dir=None,  # type: Optional[str]
-    hashes=None,  # type: Optional[Hashes]
-):
-    # type: (...) -> File
+    link: Link,
+    download: Downloader,
+    download_dir: Optional[str] = None,
+    hashes: Optional[Hashes] = None,
+) -> File:
     temp_dir = TempDirectory(kind="unpack", globally_managed=True)
     # If a download dir is specified, is the file already downloaded there?
     already_downloaded_path = None
     if download_dir:
-        already_downloaded_path = _check_download_dir(
-            link, download_dir, hashes
-        )
+        already_downloaded_path = _check_download_dir(link, download_dir, hashes)
 
     if already_downloaded_path:
         from_path = already_downloaded_path
@@ -106,72 +111,14 @@ def get_http_url(
     return File(from_path, content_type)
 
 
-def _copy2_ignoring_special_files(src, dest):
-    # type: (str, str) -> None
-    """Copying special files is not supported, but as a convenience to users
-    we skip errors copying them. This supports tools that may create e.g.
-    socket files in the project source directory.
-    """
-    try:
-        copy2_fixed(src, dest)
-    except shutil.SpecialFileError as e:
-        # SpecialFileError may be raised due to either the source or
-        # destination. If the destination was the cause then we would actually
-        # care, but since the destination directory is deleted prior to
-        # copy we ignore all of them assuming it is caused by the source.
-        logger.warning(
-            "Ignoring special file error '%s' encountered copying %s to %s.",
-            str(e),
-            src,
-            dest,
-        )
-
-
-def _copy_source_tree(source, target):
-    # type: (str, str) -> None
-    target_abspath = os.path.abspath(target)
-    target_basename = os.path.basename(target_abspath)
-    target_dirname = os.path.dirname(target_abspath)
-
-    def ignore(d, names):
-        # type: (str, List[str]) -> List[str]
-        skipped = []  # type: List[str]
-        if d == source:
-            # Pulling in those directories can potentially be very slow,
-            # exclude the following directories if they appear in the top
-            # level dir (and only it).
-            # See discussion at https://github.com/pypa/pip/pull/6770
-            skipped += ['.tox', '.nox']
-        if os.path.abspath(d) == target_dirname:
-            # Prevent an infinite recursion if the target is in source.
-            # This can happen when TMPDIR is set to ${PWD}/...
-            # and we copy PWD to TMPDIR.
-            skipped += [target_basename]
-        return skipped
-
-    shutil.copytree(
-        source,
-        target,
-        ignore=ignore,
-        symlinks=True,
-        copy_function=_copy2_ignoring_special_files,
-    )
-
-
 def get_file_url(
-    link,  # type: Link
-    download_dir=None,  # type: Optional[str]
-    hashes=None  # type: Optional[Hashes]
-):
-    # type: (...) -> File
-    """Get file and optionally check its hash.
-    """
+    link: Link, download_dir: Optional[str] = None, hashes: Optional[Hashes] = None
+) -> File:
+    """Get file and optionally check its hash."""
     # If a download dir is specified, is the file already there and valid?
     already_downloaded_path = None
     if download_dir:
-        already_downloaded_path = _check_download_dir(
-            link, download_dir, hashes
-        )
+        already_downloaded_path = _check_download_dir(link, download_dir, hashes)
 
     if already_downloaded_path:
         from_path = already_downloaded_path
@@ -189,13 +136,13 @@ def get_file_url(
 
 
 def unpack_url(
-    link,  # type: Link
-    location,  # type: str
-    download,  # type: Downloader
-    download_dir=None,  # type: Optional[str]
-    hashes=None,  # type: Optional[Hashes]
-):
-    # type: (...) -> Optional[File]
+    link: Link,
+    location: str,
+    download: Downloader,
+    verbosity: int,
+    download_dir: Optional[str] = None,
+    hashes: Optional[Hashes] = None,
+) -> Optional[File]:
     """Unpack link into location, downloading if required.
 
     :param hashes: A Hashes object, one of whose embedded hashes must match,
@@ -205,30 +152,10 @@ def unpack_url(
     """
     # non-editable vcs urls
     if link.is_vcs:
-        unpack_vcs_link(link, location)
+        unpack_vcs_link(link, location, verbosity=verbosity)
         return None
 
-    # Once out-of-tree-builds are no longer supported, could potentially
-    # replace the below condition with `assert not link.is_existing_dir`
-    # - unpack_url does not need to be called for in-tree-builds.
-    #
-    # As further cleanup, _copy_source_tree and accompanying tests can
-    # be removed.
-    if link.is_existing_dir():
-        deprecated(
-            "A future pip version will change local packages to be built "
-            "in-place without first copying to a temporary directory. "
-            "We recommend you use --use-feature=in-tree-build to test "
-            "your packages with this new behavior before it becomes the "
-            "default.\n",
-            replacement=None,
-            gone_in="21.3",
-            issue=7555
-        )
-        if os.path.isdir(location):
-            rmtree(location)
-        _copy_source_tree(link.file_path, location)
-        return None
+    assert not link.is_existing_dir()
 
     # file urls
     if link.is_file:
@@ -251,10 +178,14 @@ def unpack_url(
     return file
 
 
-def _check_download_dir(link, download_dir, hashes):
-    # type: (Link, str, Optional[Hashes]) -> Optional[str]
-    """ Check download_dir for previously downloaded file with correct hash
-        If a correct file is found return its path else None
+def _check_download_dir(
+    link: Link,
+    download_dir: str,
+    hashes: Optional[Hashes],
+    warn_on_hash_mismatch: bool = True,
+) -> Optional[str]:
+    """Check download_dir for previously downloaded file with correct hash
+    If a correct file is found return its path else None
     """
     download_path = os.path.join(download_dir, link.filename)
 
@@ -262,46 +193,46 @@ def _check_download_dir(link, download_dir, hashes):
         return None
 
     # If already downloaded, does its hash match?
-    logger.info('File was already downloaded %s', download_path)
+    logger.info("File was already downloaded %s", download_path)
     if hashes:
         try:
             hashes.check_against_path(download_path)
         except HashMismatch:
-            logger.warning(
-                'Previously-downloaded file %s has bad hash. '
-                'Re-downloading.',
-                download_path
-            )
+            if warn_on_hash_mismatch:
+                logger.warning(
+                    "Previously-downloaded file %s has bad hash. Re-downloading.",
+                    download_path,
+                )
             os.unlink(download_path)
             return None
     return download_path
 
 
 class RequirementPreparer:
-    """Prepares a Requirement
-    """
+    """Prepares a Requirement"""
 
     def __init__(
         self,
-        build_dir,  # type: str
-        download_dir,  # type: Optional[str]
-        src_dir,  # type: str
-        build_isolation,  # type: bool
-        req_tracker,  # type: RequirementTracker
-        session,  # type: PipSession
-        progress_bar,  # type: str
-        finder,  # type: PackageFinder
-        require_hashes,  # type: bool
-        use_user_site,  # type: bool
-        lazy_wheel,  # type: bool
-        in_tree_build,  # type: bool
-    ):
-        # type: (...) -> None
+        build_dir: str,
+        download_dir: Optional[str],
+        src_dir: str,
+        build_isolation: bool,
+        check_build_deps: bool,
+        build_tracker: BuildTracker,
+        session: PipSession,
+        progress_bar: str,
+        finder: PackageFinder,
+        require_hashes: bool,
+        use_user_site: bool,
+        lazy_wheel: bool,
+        verbosity: int,
+        legacy_resolver: bool,
+    ) -> None:
         super().__init__()
 
         self.src_dir = src_dir
         self.build_dir = build_dir
-        self.req_tracker = req_tracker
+        self.build_tracker = build_tracker
         self._session = session
         self._download = Downloader(session, progress_bar)
         self._batch_download = BatchDownloader(session, progress_bar)
@@ -314,6 +245,9 @@ class RequirementPreparer:
         # Is build isolation allowed?
         self.build_isolation = build_isolation
 
+        # Should check build dependencies?
+        self.check_build_deps = check_build_deps
+
         # Should hash-checking be required?
         self.require_hashes = require_hashes
 
@@ -323,35 +257,48 @@ class RequirementPreparer:
         # Should wheels be downloaded lazily?
         self.use_lazy_wheel = lazy_wheel
 
-        # Should in-tree builds be used for local paths?
-        self.in_tree_build = in_tree_build
+        # How verbose should underlying tooling be?
+        self.verbosity = verbosity
+
+        # Are we using the legacy resolver?
+        self.legacy_resolver = legacy_resolver
 
-        # Memoized downloaded files, as mapping of url: (path, mime type)
-        self._downloaded = {}  # type: Dict[str, Tuple[str, str]]
+        # Memoized downloaded files, as mapping of url: path.
+        self._downloaded: Dict[str, str] = {}
 
         # Previous "header" printed for a link-based InstallRequirement
         self._previous_requirement_header = ("", "")
 
-    def _log_preparing_link(self, req):
-        # type: (InstallRequirement) -> None
+    def _log_preparing_link(self, req: InstallRequirement) -> None:
         """Provide context for the requirement being prepared."""
-        if req.link.is_file and not req.original_link_is_in_wheel_cache:
+        if req.link.is_file and not req.is_wheel_from_cache:
             message = "Processing %s"
             information = str(display_path(req.link.file_path))
         else:
             message = "Collecting %s"
             information = str(req.req or req)
 
+        # If we used req.req, inject requirement source if available (this
+        # would already be included if we used req directly)
+        if req.req and req.comes_from:
+            if isinstance(req.comes_from, str):
+                comes_from: Optional[str] = req.comes_from
+            else:
+                comes_from = req.comes_from.from_path()
+            if comes_from:
+                information += f" (from {comes_from})"
+
         if (message, information) != self._previous_requirement_header:
             self._previous_requirement_header = (message, information)
             logger.info(message, information)
 
-        if req.original_link_is_in_wheel_cache:
+        if req.is_wheel_from_cache:
             with indent_log():
                 logger.info("Using cached %s", req.link.filename)
 
-    def _ensure_link_req_src_dir(self, req, parallel_builds):
-        # type: (InstallRequirement, bool) -> None
+    def _ensure_link_req_src_dir(
+        self, req: InstallRequirement, parallel_builds: bool
+    ) -> None:
         """Ensure source_dir of a linked InstallRequirement."""
         # Since source_dir is only set for editable requirements.
         if req.link.is_wheel:
@@ -359,7 +306,7 @@ class RequirementPreparer:
             # directory.
             return
         assert req.source_dir is None
-        if req.link.is_existing_dir() and self.in_tree_build:
+        if req.link.is_existing_dir():
             # build local directories in-tree
             req.source_dir = req.link.file_path
             return
@@ -376,7 +323,8 @@ class RequirementPreparer:
         # installation.
         # FIXME: this won't upgrade when there's an existing
         # package unpacked in `req.source_dir`
-        if os.path.exists(os.path.join(req.source_dir, 'setup.py')):
+        # TODO: this check is now probably dead code
+        if is_installable_dir(req.source_dir):
             raise PreviousBuildDirError(
                 "pip can't proceed with requirements '{}' due to a"
                 "pre-existing build directory ({}). This is likely "
@@ -385,8 +333,7 @@ class RequirementPreparer:
                 "Please delete it and try again.".format(req, req.source_dir)
             )
 
-    def _get_linked_req_hashes(self, req):
-        # type: (InstallRequirement) -> Hashes
+    def _get_linked_req_hashes(self, req: InstallRequirement) -> Hashes:
         # By the time this is called, the requirement's link should have
         # been checked so we can tell what kind of requirements req is
         # and raise some more informative errors than otherwise.
@@ -409,7 +356,7 @@ class RequirementPreparer:
         # a surprising hash mismatch in the future.
         # file:/// URLs aren't pinnable, so don't complain about them
         # not being pinned.
-        if req.original_link is None and not req.is_pinned:
+        if not req.is_direct and not req.is_pinned:
             raise HashUnpinned()
 
         # If known-good hashes are missing for this requirement,
@@ -418,18 +365,77 @@ class RequirementPreparer:
         # showing the user what the hash should be.
         return req.hashes(trust_internet=False) or MissingHashes()
 
-    def _fetch_metadata_using_lazy_wheel(self, link):
-        # type: (Link) -> Optional[Distribution]
-        """Fetch metadata using lazy wheel, if possible."""
-        if not self.use_lazy_wheel:
+    def _fetch_metadata_only(
+        self,
+        req: InstallRequirement,
+    ) -> Optional[BaseDistribution]:
+        if self.legacy_resolver:
+            logger.debug(
+                "Metadata-only fetching is not used in the legacy resolver",
+            )
             return None
         if self.require_hashes:
-            logger.debug('Lazy wheel is not used as hash checking is required')
+            logger.debug(
+                "Metadata-only fetching is not used as hash checking is required",
+            )
+            return None
+        # Try PEP 658 metadata first, then fall back to lazy wheel if unavailable.
+        return self._fetch_metadata_using_link_data_attr(
+            req
+        ) or self._fetch_metadata_using_lazy_wheel(req.link)
+
+    def _fetch_metadata_using_link_data_attr(
+        self,
+        req: InstallRequirement,
+    ) -> Optional[BaseDistribution]:
+        """Fetch metadata from the data-dist-info-metadata attribute, if possible."""
+        # (1) Get the link to the metadata file, if provided by the backend.
+        metadata_link = req.link.metadata_link()
+        if metadata_link is None:
+            return None
+        assert req.req is not None
+        logger.info(
+            "Obtaining dependency information for %s from %s",
+            req.req,
+            metadata_link,
+        )
+        # (2) Download the contents of the METADATA file, separate from the dist itself.
+        metadata_file = get_http_url(
+            metadata_link,
+            self._download,
+            hashes=metadata_link.as_hashes(),
+        )
+        with open(metadata_file.path, "rb") as f:
+            metadata_contents = f.read()
+        # (3) Generate a dist just from those file contents.
+        metadata_dist = get_metadata_distribution(
+            metadata_contents,
+            req.link.filename,
+            req.req.name,
+        )
+        # (4) Ensure the Name: field from the METADATA file matches the name from the
+        #     install requirement.
+        #
+        #     NB: raw_name will fall back to the name from the install requirement if
+        #     the Name: field is not present, but it's noted in the raw_name docstring
+        #     that that should NEVER happen anyway.
+        if canonicalize_name(metadata_dist.raw_name) != canonicalize_name(req.req.name):
+            raise MetadataInconsistent(
+                req, "Name", req.req.name, metadata_dist.raw_name
+            )
+        return metadata_dist
+
+    def _fetch_metadata_using_lazy_wheel(
+        self,
+        link: Link,
+    ) -> Optional[BaseDistribution]:
+        """Fetch metadata using lazy wheel, if possible."""
+        # --use-feature=fast-deps must be provided.
+        if not self.use_lazy_wheel:
             return None
         if link.is_file or not link.is_wheel:
             logger.debug(
-                'Lazy wheel is not used as '
-                '%r does not points to a remote wheel',
+                "Lazy wheel is not used as %r does not point to a remote wheel",
                 link,
             )
             return None
@@ -437,22 +443,22 @@ class RequirementPreparer:
         wheel = Wheel(link.filename)
         name = canonicalize_name(wheel.name)
         logger.info(
-            'Obtaining dependency information from %s %s',
-            name, wheel.version,
+            "Obtaining dependency information from %s %s",
+            name,
+            wheel.version,
         )
-        url = link.url.split('#', 1)[0]
+        url = link.url.split("#", 1)[0]
         try:
             return dist_from_wheel_url(name, url, self._session)
         except HTTPRangeRequestUnsupported:
-            logger.debug('%s does not support range requests', url)
+            logger.debug("%s does not support range requests", url)
             return None
 
     def _complete_partial_requirements(
         self,
-        partially_downloaded_reqs,  # type: Iterable[InstallRequirement]
-        parallel_builds=False,      # type: bool
-    ):
-        # type: (...) -> None
+        partially_downloaded_reqs: Iterable[InstallRequirement],
+        parallel_builds: bool = False,
+    ) -> None:
         """Download any requirements which were only fetched by metadata."""
         # Download to a temporary directory. These will be copied over as
         # needed for downstream 'download', 'wheel', and 'install' commands.
@@ -461,7 +467,7 @@ class RequirementPreparer:
         # Map each link to the requirement that owns it. This allows us to set
         # `req.local_file_path` on the appropriate requirement after passing
         # all the links at once into BatchDownloader.
-        links_to_fully_download = {}  # type: Dict[Link, InstallRequirement]
+        links_to_fully_download: Dict[Link, InstallRequirement] = {}
         for req in partially_downloaded_reqs:
             assert req.link
             links_to_fully_download[req.link] = req
@@ -474,41 +480,66 @@ class RequirementPreparer:
             logger.debug("Downloading link %s to %s", link, filepath)
             req = links_to_fully_download[link]
             req.local_file_path = filepath
+            # TODO: This needs fixing for sdists
+            # This is an emergency fix for #11847, which reports that
+            # distributions get downloaded twice when metadata is loaded
+            # from a PEP 658 standalone metadata file. Setting _downloaded
+            # fixes this for wheels, but breaks the sdist case (tests
+            # test_download_metadata). As PyPI is currently only serving
+            # metadata for wheels, this is not an immediate issue.
+            # Fixing the problem properly looks like it will require a
+            # complete refactoring of the `prepare_linked_requirements_more`
+            # logic, and I haven't a clue where to start on that, so for now
+            # I have fixed the issue *just* for wheels.
+            if req.is_wheel:
+                self._downloaded[req.link.url] = filepath
 
         # This step is necessary to ensure all lazy wheels are processed
         # successfully by the 'download', 'wheel', and 'install' commands.
         for req in partially_downloaded_reqs:
             self._prepare_linked_requirement(req, parallel_builds)
 
-    def prepare_linked_requirement(self, req, parallel_builds=False):
-        # type: (InstallRequirement, bool) -> Distribution
+    def prepare_linked_requirement(
+        self, req: InstallRequirement, parallel_builds: bool = False
+    ) -> BaseDistribution:
         """Prepare a requirement to be obtained from req.link."""
         assert req.link
-        link = req.link
         self._log_preparing_link(req)
         with indent_log():
             # Check if the relevant file is already available
             # in the download directory
             file_path = None
-            if self.download_dir is not None and link.is_wheel:
+            if self.download_dir is not None and req.link.is_wheel:
                 hashes = self._get_linked_req_hashes(req)
-                file_path = _check_download_dir(req.link, self.download_dir, hashes)
+                file_path = _check_download_dir(
+                    req.link,
+                    self.download_dir,
+                    hashes,
+                    # When a locally built wheel has been found in cache, we don't warn
+                    # about re-downloading when the already downloaded wheel hash does
+                    # not match. This is because the hash must be checked against the
+                    # original link, not the cached link. It that case the already
+                    # downloaded file will be removed and re-fetched from cache (which
+                    # implies a hash check against the cache entry's origin.json).
+                    warn_on_hash_mismatch=not req.is_wheel_from_cache,
+                )
 
             if file_path is not None:
                 # The file is already available, so mark it as downloaded
-                self._downloaded[req.link.url] = file_path, None
+                self._downloaded[req.link.url] = file_path
             else:
                 # The file is not available, attempt to fetch only metadata
-                wheel_dist = self._fetch_metadata_using_lazy_wheel(link)
-                if wheel_dist is not None:
+                metadata_dist = self._fetch_metadata_only(req)
+                if metadata_dist is not None:
                     req.needs_more_preparation = True
-                    return wheel_dist
+                    return metadata_dist
 
             # None of the optimizations worked, fully prepare the requirement
             return self._prepare_linked_requirement(req, parallel_builds)
 
-    def prepare_linked_requirements_more(self, reqs, parallel_builds=False):
-        # type: (Iterable[InstallRequirement], bool) -> None
+    def prepare_linked_requirements_more(
+        self, reqs: Iterable[InstallRequirement], parallel_builds: bool = False
+    ) -> None:
         """Prepare linked requirements more, if needed."""
         reqs = [req for req in reqs if req.needs_more_preparation]
         for req in reqs:
@@ -517,12 +548,12 @@ class RequirementPreparer:
                 hashes = self._get_linked_req_hashes(req)
                 file_path = _check_download_dir(req.link, self.download_dir, hashes)
                 if file_path is not None:
-                    self._downloaded[req.link.url] = file_path, None
+                    self._downloaded[req.link.url] = file_path
                     req.needs_more_preparation = False
 
         # Prepare requirements we found were already downloaded for some
         # reason. The other downloads will be completed separately.
-        partially_downloaded_reqs = []  # type: List[InstallRequirement]
+        partially_downloaded_reqs: List[InstallRequirement] = []
         for req in reqs:
             if req.needs_more_preparation:
                 partially_downloaded_reqs.append(req)
@@ -532,35 +563,87 @@ class RequirementPreparer:
         # TODO: separate this part out from RequirementPreparer when the v1
         # resolver can be removed!
         self._complete_partial_requirements(
-            partially_downloaded_reqs, parallel_builds=parallel_builds,
+            partially_downloaded_reqs,
+            parallel_builds=parallel_builds,
         )
 
-    def _prepare_linked_requirement(self, req, parallel_builds):
-        # type: (InstallRequirement, bool) -> Distribution
+    def _prepare_linked_requirement(
+        self, req: InstallRequirement, parallel_builds: bool
+    ) -> BaseDistribution:
         assert req.link
         link = req.link
 
-        self._ensure_link_req_src_dir(req, parallel_builds)
         hashes = self._get_linked_req_hashes(req)
 
-        if link.is_existing_dir() and self.in_tree_build:
+        if hashes and req.is_wheel_from_cache:
+            assert req.download_info is not None
+            assert link.is_wheel
+            assert link.is_file
+            # We need to verify hashes, and we have found the requirement in the cache
+            # of locally built wheels.
+            if (
+                isinstance(req.download_info.info, ArchiveInfo)
+                and req.download_info.info.hashes
+                and hashes.has_one_of(req.download_info.info.hashes)
+            ):
+                # At this point we know the requirement was built from a hashable source
+                # artifact, and we verified that the cache entry's hash of the original
+                # artifact matches one of the hashes we expect. We don't verify hashes
+                # against the cached wheel, because the wheel is not the original.
+                hashes = None
+            else:
+                logger.warning(
+                    "The hashes of the source archive found in cache entry "
+                    "don't match, ignoring cached built wheel "
+                    "and re-downloading source."
+                )
+                req.link = req.cached_wheel_source_link
+                link = req.link
+
+        self._ensure_link_req_src_dir(req, parallel_builds)
+
+        if link.is_existing_dir():
             local_file = None
         elif link.url not in self._downloaded:
             try:
                 local_file = unpack_url(
-                    link, req.source_dir, self._download,
-                    self.download_dir, hashes
+                    link,
+                    req.source_dir,
+                    self._download,
+                    self.verbosity,
+                    self.download_dir,
+                    hashes,
                 )
             except NetworkConnectionError as exc:
                 raise InstallationError(
-                    'Could not install requirement {} because of HTTP '
-                    'error {} for URL {}'.format(req, exc, link)
+                    "Could not install requirement {} because of HTTP "
+                    "error {} for URL {}".format(req, exc, link)
                 )
         else:
-            file_path, content_type = self._downloaded[link.url]
+            file_path = self._downloaded[link.url]
             if hashes:
                 hashes.check_against_path(file_path)
-            local_file = File(file_path, content_type)
+            local_file = File(file_path, content_type=None)
+
+        # If download_info is set, we got it from the wheel cache.
+        if req.download_info is None:
+            # Editables don't go through this function (see
+            # prepare_editable_requirement).
+            assert not req.editable
+            req.download_info = direct_url_from_link(link, req.source_dir)
+            # Make sure we have a hash in download_info. If we got it as part of the
+            # URL, it will have been verified and we can rely on it. Otherwise we
+            # compute it from the downloaded file.
+            # FIXME: https://github.com/pypa/pip/issues/11943
+            if (
+                isinstance(req.download_info.info, ArchiveInfo)
+                and not req.download_info.info.hashes
+                and local_file
+            ):
+                hash = hash_file(local_file.path)[0].hexdigest()
+                # We populate info.hash for backward compatibility.
+                # This will automatically populate info.hashes.
+                req.download_info.info.hash = f"sha256={hash}"
 
         # For use in later processing,
         # preserve the file path on the requirement.
@@ -568,12 +651,15 @@ class RequirementPreparer:
             req.local_file_path = local_file.path
 
         dist = _get_prepared_distribution(
-            req, self.req_tracker, self.finder, self.build_isolation,
+            req,
+            self.build_tracker,
+            self.finder,
+            self.build_isolation,
+            self.check_build_deps,
         )
         return dist
 
-    def save_linked_requirement(self, req):
-        # type: (InstallRequirement) -> None
+    def save_linked_requirement(self, req: InstallRequirement) -> None:
         assert self.download_dir is not None
         assert req.link is not None
         link = req.link
@@ -584,8 +670,9 @@ class RequirementPreparer:
 
         if link.is_existing_dir():
             logger.debug(
-                'Not copying link to destination directory '
-                'since it is a directory: %s', link,
+                "Not copying link to destination directory "
+                "since it is a directory: %s",
+                link,
             )
             return
         if req.local_file_path is None:
@@ -596,31 +683,35 @@ class RequirementPreparer:
         if not os.path.exists(download_location):
             shutil.copy(req.local_file_path, download_location)
             download_path = display_path(download_location)
-            logger.info('Saved %s', download_path)
+            logger.info("Saved %s", download_path)
 
     def prepare_editable_requirement(
         self,
-        req,  # type: InstallRequirement
-    ):
-        # type: (...) -> Distribution
-        """Prepare an editable requirement
-        """
+        req: InstallRequirement,
+    ) -> BaseDistribution:
+        """Prepare an editable requirement."""
         assert req.editable, "cannot prepare a non-editable req as editable"
 
-        logger.info('Obtaining %s', req)
+        logger.info("Obtaining %s", req)
 
         with indent_log():
             if self.require_hashes:
                 raise InstallationError(
-                    'The editable requirement {} cannot be installed when '
-                    'requiring hashes, because there is no single file to '
-                    'hash.'.format(req)
+                    "The editable requirement {} cannot be installed when "
+                    "requiring hashes, because there is no single file to "
+                    "hash.".format(req)
                 )
             req.ensure_has_source_dir(self.src_dir)
             req.update_editable()
+            assert req.source_dir
+            req.download_info = direct_url_for_editable(req.unpacked_source_directory)
 
             dist = _get_prepared_distribution(
-                req, self.req_tracker, self.finder, self.build_isolation,
+                req,
+                self.build_tracker,
+                self.finder,
+                self.build_isolation,
+                self.check_build_deps,
             )
 
             req.check_if_exists(self.use_user_site)
@@ -629,27 +720,24 @@ class RequirementPreparer:
 
     def prepare_installed_requirement(
         self,
-        req,  # type: InstallRequirement
-        skip_reason  # type: str
-    ):
-        # type: (...) -> Distribution
-        """Prepare an already-installed requirement
-        """
+        req: InstallRequirement,
+        skip_reason: str,
+    ) -> BaseDistribution:
+        """Prepare an already-installed requirement."""
         assert req.satisfied_by, "req should have been satisfied but isn't"
         assert skip_reason is not None, (
             "did not get skip reason skipped but req.satisfied_by "
             "is set to {}".format(req.satisfied_by)
         )
         logger.info(
-            'Requirement %s: %s (%s)',
-            skip_reason, req, req.satisfied_by.version
+            "Requirement %s: %s (%s)", skip_reason, req, req.satisfied_by.version
         )
         with indent_log():
             if self.require_hashes:
                 logger.debug(
-                    'Since it is already installed, we are trusting this '
-                    'package without checking its hash. To ensure a '
-                    'completely repeatable environment, install into an '
-                    'empty virtualenv.'
+                    "Since it is already installed, we are trusting this "
+                    "package without checking its hash. To ensure a "
+                    "completely repeatable environment, install into an "
+                    "empty virtualenv."
                 )
-            return InstalledDistribution(req).get_pkg_resources_distribution()
+            return InstalledDistribution(req).get_metadata_distribution()
diff --git a/env/Lib/site-packages/pip/_internal/pyproject.py b/env/Lib/site-packages/pip/_internal/pyproject.py
index 9016d355..eb8e12b2 100644
--- a/env/Lib/site-packages/pip/_internal/pyproject.py
+++ b/env/Lib/site-packages/pip/_internal/pyproject.py
@@ -1,38 +1,34 @@
+import importlib.util
 import os
 from collections import namedtuple
 from typing import Any, List, Optional
 
-from pip._vendor import toml
+from pip._vendor import tomli
 from pip._vendor.packaging.requirements import InvalidRequirement, Requirement
 
-from pip._internal.exceptions import InstallationError
+from pip._internal.exceptions import (
+    InstallationError,
+    InvalidPyProjectBuildRequires,
+    MissingPyProjectBuildRequires,
+)
 
 
-def _is_list_of_str(obj):
-    # type: (Any) -> bool
-    return (
-        isinstance(obj, list) and
-        all(isinstance(item, str) for item in obj)
-    )
+def _is_list_of_str(obj: Any) -> bool:
+    return isinstance(obj, list) and all(isinstance(item, str) for item in obj)
 
 
-def make_pyproject_path(unpacked_source_directory):
-    # type: (str) -> str
-    return os.path.join(unpacked_source_directory, 'pyproject.toml')
+def make_pyproject_path(unpacked_source_directory: str) -> str:
+    return os.path.join(unpacked_source_directory, "pyproject.toml")
 
 
-BuildSystemDetails = namedtuple('BuildSystemDetails', [
-    'requires', 'backend', 'check', 'backend_path'
-])
+BuildSystemDetails = namedtuple(
+    "BuildSystemDetails", ["requires", "backend", "check", "backend_path"]
+)
 
 
 def load_pyproject_toml(
-    use_pep517,  # type: Optional[bool]
-    pyproject_toml,  # type: str
-    setup_py,  # type: str
-    req_name  # type: str
-):
-    # type: (...) -> Optional[BuildSystemDetails]
+    use_pep517: Optional[bool], pyproject_toml: str, setup_py: str, req_name: str
+) -> Optional[BuildSystemDetails]:
     """Load the pyproject.toml file.
 
     Parameters:
@@ -57,9 +53,15 @@ def load_pyproject_toml(
     has_pyproject = os.path.isfile(pyproject_toml)
     has_setup = os.path.isfile(setup_py)
 
+    if not has_pyproject and not has_setup:
+        raise InstallationError(
+            f"{req_name} does not appear to be a Python project: "
+            f"neither 'setup.py' nor 'pyproject.toml' found."
+        )
+
     if has_pyproject:
         with open(pyproject_toml, encoding="utf-8") as f:
-            pp_toml = toml.load(f)
+            pp_toml = tomli.loads(f.read())
         build_system = pp_toml.get("build-system")
     else:
         build_system = None
@@ -82,17 +84,26 @@ def load_pyproject_toml(
             raise InstallationError(
                 "Disabling PEP 517 processing is invalid: "
                 "project specifies a build backend of {} "
-                "in pyproject.toml".format(
-                    build_system["build-backend"]
-                )
+                "in pyproject.toml".format(build_system["build-backend"])
             )
         use_pep517 = True
 
     # If we haven't worked out whether to use PEP 517 yet,
     # and the user hasn't explicitly stated a preference,
-    # we do so if the project has a pyproject.toml file.
+    # we do so if the project has a pyproject.toml file
+    # or if we cannot import setuptools or wheels.
+
+    # We fallback to PEP 517 when without setuptools or without the wheel package,
+    # so setuptools can be installed as a default build backend.
+    # For more info see:
+    # https://discuss.python.org/t/pip-without-setuptools-could-the-experience-be-improved/11810/9
+    # https://github.com/pypa/pip/issues/8559
     elif use_pep517 is None:
-        use_pep517 = has_pyproject
+        use_pep517 = (
+            has_pyproject
+            or not importlib.util.find_spec("setuptools")
+            or not importlib.util.find_spec("wheel")
+        )
 
     # At this point, we know whether we're going to use PEP 517.
     assert use_pep517 is not None
@@ -124,52 +135,37 @@ def load_pyproject_toml(
 
     # Ensure that the build-system section in pyproject.toml conforms
     # to PEP 518.
-    error_template = (
-        "{package} has a pyproject.toml file that does not comply "
-        "with PEP 518: {reason}"
-    )
 
     # Specifying the build-system table but not the requires key is invalid
     if "requires" not in build_system:
-        raise InstallationError(
-            error_template.format(package=req_name, reason=(
-                "it has a 'build-system' table but not "
-                "'build-system.requires' which is mandatory in the table"
-            ))
-        )
+        raise MissingPyProjectBuildRequires(package=req_name)
 
     # Error out if requires is not a list of strings
     requires = build_system["requires"]
     if not _is_list_of_str(requires):
-        raise InstallationError(error_template.format(
+        raise InvalidPyProjectBuildRequires(
             package=req_name,
-            reason="'build-system.requires' is not a list of strings.",
-        ))
+            reason="It is not a list of strings.",
+        )
 
     # Each requirement must be valid as per PEP 508
     for requirement in requires:
         try:
             Requirement(requirement)
-        except InvalidRequirement:
-            raise InstallationError(
-                error_template.format(
-                    package=req_name,
-                    reason=(
-                        "'build-system.requires' contains an invalid "
-                        "requirement: {!r}".format(requirement)
-                    ),
-                )
-            )
+        except InvalidRequirement as error:
+            raise InvalidPyProjectBuildRequires(
+                package=req_name,
+                reason=f"It contains an invalid requirement: {requirement!r}",
+            ) from error
 
     backend = build_system.get("build-backend")
     backend_path = build_system.get("backend-path", [])
-    check = []  # type: List[str]
+    check: List[str] = []
     if backend is None:
         # If the user didn't specify a backend, we assume they want to use
         # the setuptools backend. But we can't be sure they have included
-        # a version of setuptools which supplies the backend, or wheel
-        # (which is needed by the backend) in their requirements. So we
-        # make a note to check that those requirements are present once
+        # a version of setuptools which supplies the backend. So we
+        # make a note to check that this requirement is present once
         # we have set up the environment.
         # This is quite a lot of work to check for a very specific case. But
         # the problem is, that case is potentially quite common - projects that
@@ -178,6 +174,6 @@ def load_pyproject_toml(
         # tools themselves. The original PEP 518 code had a similar check (but
         # implemented in a different way).
         backend = "setuptools.build_meta:__legacy__"
-        check = ["setuptools>=40.8.0", "wheel"]
+        check = ["setuptools>=40.8.0"]
 
     return BuildSystemDetails(requires, backend, check, backend_path)
diff --git a/env/Lib/site-packages/pip/_internal/req/__init__.py b/env/Lib/site-packages/pip/_internal/req/__init__.py
index 06f0a082..16de903a 100644
--- a/env/Lib/site-packages/pip/_internal/req/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/req/__init__.py
@@ -1,6 +1,6 @@
 import collections
 import logging
-from typing import Iterator, List, Optional, Sequence, Tuple
+from typing import Generator, List, Optional, Sequence, Tuple
 
 from pip._internal.utils.logging import indent_log
 
@@ -9,44 +9,41 @@ from .req_install import InstallRequirement
 from .req_set import RequirementSet
 
 __all__ = [
-    "RequirementSet", "InstallRequirement",
-    "parse_requirements", "install_given_reqs",
+    "RequirementSet",
+    "InstallRequirement",
+    "parse_requirements",
+    "install_given_reqs",
 ]
 
 logger = logging.getLogger(__name__)
 
 
 class InstallationResult:
-    def __init__(self, name):
-        # type: (str) -> None
+    def __init__(self, name: str) -> None:
         self.name = name
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return f"InstallationResult(name={self.name!r})"
 
 
 def _validate_requirements(
-    requirements,  # type: List[InstallRequirement]
-):
-    # type: (...) -> Iterator[Tuple[str, InstallRequirement]]
+    requirements: List[InstallRequirement],
+) -> Generator[Tuple[str, InstallRequirement], None, None]:
     for req in requirements:
         assert req.name, f"invalid to-be-installed requirement: {req}"
         yield req.name, req
 
 
 def install_given_reqs(
-    requirements,  # type: List[InstallRequirement]
-    install_options,  # type: List[str]
-    global_options,  # type: Sequence[str]
-    root,  # type: Optional[str]
-    home,  # type: Optional[str]
-    prefix,  # type: Optional[str]
-    warn_script_location,  # type: bool
-    use_user_site,  # type: bool
-    pycompile,  # type: bool
-):
-    # type: (...) -> List[InstallationResult]
+    requirements: List[InstallRequirement],
+    global_options: Sequence[str],
+    root: Optional[str],
+    home: Optional[str],
+    prefix: Optional[str],
+    warn_script_location: bool,
+    use_user_site: bool,
+    pycompile: bool,
+) -> List[InstallationResult]:
     """
     Install everything in the given list.
 
@@ -56,8 +53,8 @@ def install_given_reqs(
 
     if to_install:
         logger.info(
-            'Installing collected packages: %s',
-            ', '.join(to_install.keys()),
+            "Installing collected packages: %s",
+            ", ".join(to_install.keys()),
         )
 
     installed = []
@@ -65,17 +62,14 @@ def install_given_reqs(
     with indent_log():
         for req_name, requirement in to_install.items():
             if requirement.should_reinstall:
-                logger.info('Attempting uninstall: %s', req_name)
+                logger.info("Attempting uninstall: %s", req_name)
                 with indent_log():
-                    uninstalled_pathset = requirement.uninstall(
-                        auto_confirm=True
-                    )
+                    uninstalled_pathset = requirement.uninstall(auto_confirm=True)
             else:
                 uninstalled_pathset = None
 
             try:
                 requirement.install(
-                    install_options,
                     global_options,
                     root=root,
                     home=home,
diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 0d885a37520c3b3217e78fc6cb6234c6c0e88a2c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/constructors.cpython-39.pyc
deleted file mode 100644
index baafd90039bce100bf9133d5ac821014652d809c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_file.cpython-39.pyc
deleted file mode 100644
index a25b0ce6f0cf68355884b766e8202b2cec5915a2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_install.cpython-39.pyc
deleted file mode 100644
index 20a582b9dedfd7eb8a1a1618ff02c95261c2c24d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 20542
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%0A#Err!qb_F)uMa
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
J>KPD_0RZ-s0F?j$

diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_set.cpython-39.pyc
deleted file mode 100644
index ae2f115ee96cf7a029041a3522402ee344b888d5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5708
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
N4-*d~7&37&0|4Ek=5+u7

diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_tracker.cpython-39.pyc
deleted file mode 100644
index 62c7068c5d89ef9d8e8bd8db579753e39128cd2e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4053
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
WqXH8TBM+z{$;`sYCB?$X#SZ|qL*C5*

diff --git a/env/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/req/__pycache__/req_uninstall.cpython-39.pyc
deleted file mode 100644
index 58ad9d78cad1ff38a3ef66aa1765f5687f9cc177..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 17489
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
Y;ALXu66X-%Q0Fk_%jc_SsAu2?0C@$KRR910

diff --git a/env/Lib/site-packages/pip/_internal/req/constructors.py b/env/Lib/site-packages/pip/_internal/req/constructors.py
index 3f9e7dd7..c5ca2d85 100644
--- a/env/Lib/site-packages/pip/_internal/req/constructors.py
+++ b/env/Lib/site-packages/pip/_internal/req/constructors.py
@@ -11,37 +11,36 @@ InstallRequirement.
 import logging
 import os
 import re
-from typing import Any, Dict, Optional, Set, Tuple, Union
+from typing import Dict, List, Optional, Set, Tuple, Union
 
 from pip._vendor.packaging.markers import Marker
 from pip._vendor.packaging.requirements import InvalidRequirement, Requirement
 from pip._vendor.packaging.specifiers import Specifier
-from pip._vendor.pkg_resources import RequirementParseError, parse_requirements
 
 from pip._internal.exceptions import InstallationError
 from pip._internal.models.index import PyPI, TestPyPI
 from pip._internal.models.link import Link
 from pip._internal.models.wheel import Wheel
-from pip._internal.pyproject import make_pyproject_path
 from pip._internal.req.req_file import ParsedRequirement
 from pip._internal.req.req_install import InstallRequirement
 from pip._internal.utils.filetypes import is_archive_file
 from pip._internal.utils.misc import is_installable_dir
+from pip._internal.utils.packaging import get_requirement
 from pip._internal.utils.urls import path_to_url
 from pip._internal.vcs import is_url, vcs
 
 __all__ = [
-    "install_req_from_editable", "install_req_from_line",
-    "parse_editable"
+    "install_req_from_editable",
+    "install_req_from_line",
+    "parse_editable",
 ]
 
 logger = logging.getLogger(__name__)
 operators = Specifier._operators.keys()
 
 
-def _strip_extras(path):
-    # type: (str) -> Tuple[str, Optional[str]]
-    m = re.match(r'^(.+)(\[[^\]]+\])$', path)
+def _strip_extras(path: str) -> Tuple[str, Optional[str]]:
+    m = re.match(r"^(.+)(\[[^\]]+\])$", path)
     extras = None
     if m:
         path_no_extras = m.group(1)
@@ -52,15 +51,13 @@ def _strip_extras(path):
     return path_no_extras, extras
 
 
-def convert_extras(extras):
-    # type: (Optional[str]) -> Set[str]
+def convert_extras(extras: Optional[str]) -> Set[str]:
     if not extras:
         return set()
-    return Requirement("placeholder" + extras.lower()).extras
+    return get_requirement("placeholder" + extras.lower()).extras
 
 
-def parse_editable(editable_req):
-    # type: (str) -> Tuple[Optional[str], str, Set[str]]
+def parse_editable(editable_req: str) -> Tuple[Optional[str], str, Set[str]]:
     """Parses an editable requirement into:
         - a requirement name
         - an URL
@@ -77,39 +74,23 @@ def parse_editable(editable_req):
     url_no_extras, extras = _strip_extras(url)
 
     if os.path.isdir(url_no_extras):
-        setup_py = os.path.join(url_no_extras, 'setup.py')
-        setup_cfg = os.path.join(url_no_extras, 'setup.cfg')
-        if not os.path.exists(setup_py) and not os.path.exists(setup_cfg):
-            msg = (
-                'File "setup.py" or "setup.cfg" not found. Directory cannot be '
-                'installed in editable mode: {}'
-                .format(os.path.abspath(url_no_extras))
-            )
-            pyproject_path = make_pyproject_path(url_no_extras)
-            if os.path.isfile(pyproject_path):
-                msg += (
-                    '\n(A "pyproject.toml" file was found, but editable '
-                    'mode currently requires a setuptools-based build.)'
-                )
-            raise InstallationError(msg)
-
         # Treating it as code that has already been checked out
         url_no_extras = path_to_url(url_no_extras)
 
-    if url_no_extras.lower().startswith('file:'):
+    if url_no_extras.lower().startswith("file:"):
         package_name = Link(url_no_extras).egg_fragment
         if extras:
             return (
                 package_name,
                 url_no_extras,
-                Requirement("placeholder" + extras.lower()).extras,
+                get_requirement("placeholder" + extras.lower()).extras,
             )
         else:
             return package_name, url_no_extras, set()
 
     for version_control in vcs:
-        if url.lower().startswith(f'{version_control}:'):
-            url = f'{version_control}+{url}'
+        if url.lower().startswith(f"{version_control}:"):
+            url = f"{version_control}+{url}"
             break
 
     link = Link(url)
@@ -117,9 +98,9 @@ def parse_editable(editable_req):
     if not link.is_vcs:
         backends = ", ".join(vcs.all_schemes)
         raise InstallationError(
-            f'{editable_req} is not a valid editable requirement. '
-            f'It should either be a path to a local project or a VCS URL '
-            f'(beginning with {backends}).'
+            f"{editable_req} is not a valid editable requirement. "
+            f"It should either be a path to a local project or a VCS URL "
+            f"(beginning with {backends})."
         )
 
     package_name = link.egg_fragment
@@ -131,44 +112,66 @@ def parse_editable(editable_req):
     return package_name, url, set()
 
 
-def deduce_helpful_msg(req):
-    # type: (str) -> str
+def check_first_requirement_in_file(filename: str) -> None:
+    """Check if file is parsable as a requirements file.
+
+    This is heavily based on ``pkg_resources.parse_requirements``, but
+    simplified to just check the first meaningful line.
+
+    :raises InvalidRequirement: If the first meaningful line cannot be parsed
+        as an requirement.
+    """
+    with open(filename, encoding="utf-8", errors="ignore") as f:
+        # Create a steppable iterator, so we can handle \-continuations.
+        lines = (
+            line
+            for line in (line.strip() for line in f)
+            if line and not line.startswith("#")  # Skip blank lines/comments.
+        )
+
+        for line in lines:
+            # Drop comments -- a hash without a space may be in a URL.
+            if " #" in line:
+                line = line[: line.find(" #")]
+            # If there is a line continuation, drop it, and append the next line.
+            if line.endswith("\\"):
+                line = line[:-2].strip() + next(lines, "")
+            Requirement(line)
+            return
+
+
+def deduce_helpful_msg(req: str) -> str:
     """Returns helpful msg in case requirements file does not exist,
     or cannot be parsed.
 
     :params req: Requirements file path
     """
-    msg = ""
-    if os.path.exists(req):
-        msg = " The path does exist. "
-        # Try to parse and check if it is a requirements file.
-        try:
-            with open(req) as fp:
-                # parse first line only
-                next(parse_requirements(fp.read()))
-                msg += (
-                    "The argument you provided "
-                    "({}) appears to be a"
-                    " requirements file. If that is the"
-                    " case, use the '-r' flag to install"
-                    " the packages specified within it."
-                ).format(req)
-        except RequirementParseError:
-            logger.debug(
-                "Cannot parse '%s' as requirements file", req, exc_info=True
-            )
+    if not os.path.exists(req):
+        return f" File '{req}' does not exist."
+    msg = " The path does exist. "
+    # Try to parse and check if it is a requirements file.
+    try:
+        check_first_requirement_in_file(req)
+    except InvalidRequirement:
+        logger.debug("Cannot parse '%s' as requirements file", req)
     else:
-        msg += f" File '{req}' does not exist."
+        msg += (
+            f"The argument you provided "
+            f"({req}) appears to be a"
+            f" requirements file. If that is the"
+            f" case, use the '-r' flag to install"
+            f" the packages specified within it."
+        )
     return msg
 
 
 class RequirementParts:
     def __init__(
-            self,
-            requirement,  # type: Optional[Requirement]
-            link,         # type: Optional[Link]
-            markers,      # type: Optional[Marker]
-            extras,       # type: Set[str]
+        self,
+        requirement: Optional[Requirement],
+        link: Optional[Link],
+        markers: Optional[Marker],
+        extras: Set[str],
     ):
         self.requirement = requirement
         self.link = link
@@ -176,13 +179,12 @@ class RequirementParts:
         self.extras = extras
 
 
-def parse_req_from_editable(editable_req):
-    # type: (str) -> RequirementParts
+def parse_req_from_editable(editable_req: str) -> RequirementParts:
     name, url, extras_override = parse_editable(editable_req)
 
     if name is not None:
         try:
-            req = Requirement(name)  # type: Optional[Requirement]
+            req: Optional[Requirement] = Requirement(name)
         except InvalidRequirement:
             raise InstallationError(f"Invalid requirement: '{name}'")
     else:
@@ -197,16 +199,18 @@ def parse_req_from_editable(editable_req):
 
 
 def install_req_from_editable(
-    editable_req,  # type: str
-    comes_from=None,  # type: Optional[Union[InstallRequirement, str]]
-    use_pep517=None,  # type: Optional[bool]
-    isolated=False,  # type: bool
-    options=None,  # type: Optional[Dict[str, Any]]
-    constraint=False,  # type: bool
-    user_supplied=False,  # type: bool
-):
-    # type: (...) -> InstallRequirement
-
+    editable_req: str,
+    comes_from: Optional[Union[InstallRequirement, str]] = None,
+    *,
+    use_pep517: Optional[bool] = None,
+    isolated: bool = False,
+    global_options: Optional[List[str]] = None,
+    hash_options: Optional[Dict[str, List[str]]] = None,
+    constraint: bool = False,
+    user_supplied: bool = False,
+    permit_editable_wheels: bool = False,
+    config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+) -> InstallRequirement:
     parts = parse_req_from_editable(editable_req)
 
     return InstallRequirement(
@@ -214,19 +218,19 @@ def install_req_from_editable(
         comes_from=comes_from,
         user_supplied=user_supplied,
         editable=True,
+        permit_editable_wheels=permit_editable_wheels,
         link=parts.link,
         constraint=constraint,
         use_pep517=use_pep517,
         isolated=isolated,
-        install_options=options.get("install_options", []) if options else [],
-        global_options=options.get("global_options", []) if options else [],
-        hash_options=options.get("hashes", {}) if options else {},
+        global_options=global_options,
+        hash_options=hash_options,
+        config_settings=config_settings,
         extras=parts.extras,
     )
 
 
-def _looks_like_path(name):
-    # type: (str) -> bool
+def _looks_like_path(name: str) -> bool:
     """Checks whether the string "looks like" a path on the filesystem.
 
     This does not check whether the target actually exists, only judge from the
@@ -245,11 +249,10 @@ def _looks_like_path(name):
     return False
 
 
-def _get_url_from_path(path, name):
-    # type: (str, str) -> Optional[str]
+def _get_url_from_path(path: str, name: str) -> Optional[str]:
     """
-    First, it checks whether a provided path is an installable directory
-    (e.g. it has a setup.py). If it is, returns the path.
+    First, it checks whether a provided path is an installable directory. If it
+    is, returns the path.
 
     If false, check if the path is an archive file (such as a .whl).
     The function checks if the path is a file. If false, if the path has
@@ -258,6 +261,8 @@ def _get_url_from_path(path, name):
     if _looks_like_path(name) and os.path.isdir(path):
         if is_installable_dir(path):
             return path_to_url(path)
+        # TODO: The is_installable_dir test here might not be necessary
+        #       now that it is done in load_pyproject_toml too.
         raise InstallationError(
             f"Directory {name!r} is not installable. Neither 'setup.py' "
             "nor 'pyproject.toml' found."
@@ -266,25 +271,23 @@ def _get_url_from_path(path, name):
         return None
     if os.path.isfile(path):
         return path_to_url(path)
-    urlreq_parts = name.split('@', 1)
+    urlreq_parts = name.split("@", 1)
     if len(urlreq_parts) >= 2 and not _looks_like_path(urlreq_parts[0]):
         # If the path contains '@' and the part before it does not look
         # like a path, try to treat it as a PEP 440 URL req instead.
         return None
     logger.warning(
-        'Requirement %r looks like a filename, but the '
-        'file does not exist',
-        name
+        "Requirement %r looks like a filename, but the file does not exist",
+        name,
     )
     return path_to_url(path)
 
 
-def parse_req_from_line(name, line_source):
-    # type: (str, Optional[str]) -> RequirementParts
+def parse_req_from_line(name: str, line_source: Optional[str]) -> RequirementParts:
     if is_url(name):
-        marker_sep = '; '
+        marker_sep = "; "
     else:
-        marker_sep = ';'
+        marker_sep = ";"
     if marker_sep in name:
         name, markers_as_string = name.split(marker_sep, 1)
         markers_as_string = markers_as_string.strip()
@@ -311,9 +314,8 @@ def parse_req_from_line(name, line_source):
     # it's a local file, dir, or url
     if link:
         # Handle relative file URLs
-        if link.scheme == 'file' and re.search(r'\.\./', link.url):
-            link = Link(
-                path_to_url(os.path.normpath(os.path.abspath(link.path))))
+        if link.scheme == "file" and re.search(r"\.\./", link.url):
+            link = Link(path_to_url(os.path.normpath(os.path.abspath(link.path))))
         # wheel file
         if link.is_wheel:
             wheel = Wheel(link.filename)  # can raise InvalidWheelFilename
@@ -329,29 +331,27 @@ def parse_req_from_line(name, line_source):
 
     extras = convert_extras(extras_as_string)
 
-    def with_source(text):
-        # type: (str) -> str
+    def with_source(text: str) -> str:
         if not line_source:
             return text
-        return f'{text} (from {line_source})'
+        return f"{text} (from {line_source})"
 
     def _parse_req_string(req_as_string: str) -> Requirement:
         try:
-            req = Requirement(req_as_string)
+            req = get_requirement(req_as_string)
         except InvalidRequirement:
             if os.path.sep in req_as_string:
                 add_msg = "It looks like a path."
                 add_msg += deduce_helpful_msg(req_as_string)
-            elif ('=' in req_as_string and
-                  not any(op in req_as_string for op in operators)):
+            elif "=" in req_as_string and not any(
+                op in req_as_string for op in operators
+            ):
                 add_msg = "= is not a valid operator. Did you mean == ?"
             else:
-                add_msg = ''
-            msg = with_source(
-                f'Invalid requirement: {req_as_string!r}'
-            )
+                add_msg = ""
+            msg = with_source(f"Invalid requirement: {req_as_string!r}")
             if add_msg:
-                msg += f'\nHint: {add_msg}'
+                msg += f"\nHint: {add_msg}"
             raise InstallationError(msg)
         else:
             # Deprecate extras after specifiers: "name>=1.0[extras]"
@@ -360,13 +360,13 @@ def parse_req_from_line(name, line_source):
             # RequirementParts
             for spec in req.specifier:
                 spec_str = str(spec)
-                if spec_str.endswith(']'):
+                if spec_str.endswith("]"):
                     msg = f"Extras after version '{spec_str}'."
                     raise InstallationError(msg)
         return req
 
     if req_as_string is not None:
-        req = _parse_req_string(req_as_string)  # type: Optional[Requirement]
+        req: Optional[Requirement] = _parse_req_string(req_as_string)
     else:
         req = None
 
@@ -374,16 +374,18 @@ def parse_req_from_line(name, line_source):
 
 
 def install_req_from_line(
-    name,  # type: str
-    comes_from=None,  # type: Optional[Union[str, InstallRequirement]]
-    use_pep517=None,  # type: Optional[bool]
-    isolated=False,  # type: bool
-    options=None,  # type: Optional[Dict[str, Any]]
-    constraint=False,  # type: bool
-    line_source=None,  # type: Optional[str]
-    user_supplied=False,  # type: bool
-):
-    # type: (...) -> InstallRequirement
+    name: str,
+    comes_from: Optional[Union[str, InstallRequirement]] = None,
+    *,
+    use_pep517: Optional[bool] = None,
+    isolated: bool = False,
+    global_options: Optional[List[str]] = None,
+    hash_options: Optional[Dict[str, List[str]]] = None,
+    constraint: bool = False,
+    line_source: Optional[str] = None,
+    user_supplied: bool = False,
+    config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+) -> InstallRequirement:
     """Creates an InstallRequirement from a name, which might be a
     requirement, directory containing 'setup.py', filename, or URL.
 
@@ -393,11 +395,15 @@ def install_req_from_line(
     parts = parse_req_from_line(name, line_source)
 
     return InstallRequirement(
-        parts.requirement, comes_from, link=parts.link, markers=parts.markers,
-        use_pep517=use_pep517, isolated=isolated,
-        install_options=options.get("install_options", []) if options else [],
-        global_options=options.get("global_options", []) if options else [],
-        hash_options=options.get("hashes", {}) if options else {},
+        parts.requirement,
+        comes_from,
+        link=parts.link,
+        markers=parts.markers,
+        use_pep517=use_pep517,
+        isolated=isolated,
+        global_options=global_options,
+        hash_options=hash_options,
+        config_settings=config_settings,
         constraint=constraint,
         extras=parts.extras,
         user_supplied=user_supplied,
@@ -405,15 +411,14 @@ def install_req_from_line(
 
 
 def install_req_from_req_string(
-    req_string,  # type: str
-    comes_from=None,  # type: Optional[InstallRequirement]
-    isolated=False,  # type: bool
-    use_pep517=None,  # type: Optional[bool]
-    user_supplied=False,  # type: bool
-):
-    # type: (...) -> InstallRequirement
+    req_string: str,
+    comes_from: Optional[InstallRequirement] = None,
+    isolated: bool = False,
+    use_pep517: Optional[bool] = None,
+    user_supplied: bool = False,
+) -> InstallRequirement:
     try:
-        req = Requirement(req_string)
+        req = get_requirement(req_string)
     except InvalidRequirement:
         raise InstallationError(f"Invalid requirement: '{req_string}'")
 
@@ -421,8 +426,12 @@ def install_req_from_req_string(
         PyPI.file_storage_domain,
         TestPyPI.file_storage_domain,
     ]
-    if (req.url and comes_from and comes_from.link and
-            comes_from.link.netloc in domains_not_allowed):
+    if (
+        req.url
+        and comes_from
+        and comes_from.link
+        and comes_from.link.netloc in domains_not_allowed
+    ):
         # Explicitly disallow pypi packages that depend on external urls
         raise InstallationError(
             "Packages installed from PyPI cannot depend on packages "
@@ -440,12 +449,12 @@ def install_req_from_req_string(
 
 
 def install_req_from_parsed_requirement(
-    parsed_req,  # type: ParsedRequirement
-    isolated=False,  # type: bool
-    use_pep517=None,  # type: Optional[bool]
-    user_supplied=False,  # type: bool
-):
-    # type: (...) -> InstallRequirement
+    parsed_req: ParsedRequirement,
+    isolated: bool = False,
+    use_pep517: Optional[bool] = None,
+    user_supplied: bool = False,
+    config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+) -> InstallRequirement:
     if parsed_req.is_editable:
         req = install_req_from_editable(
             parsed_req.requirement,
@@ -454,6 +463,7 @@ def install_req_from_parsed_requirement(
             constraint=parsed_req.constraint,
             isolated=isolated,
             user_supplied=user_supplied,
+            config_settings=config_settings,
         )
 
     else:
@@ -462,16 +472,25 @@ def install_req_from_parsed_requirement(
             comes_from=parsed_req.comes_from,
             use_pep517=use_pep517,
             isolated=isolated,
-            options=parsed_req.options,
+            global_options=(
+                parsed_req.options.get("global_options", [])
+                if parsed_req.options
+                else []
+            ),
+            hash_options=(
+                parsed_req.options.get("hashes", {}) if parsed_req.options else {}
+            ),
             constraint=parsed_req.constraint,
             line_source=parsed_req.line_source,
             user_supplied=user_supplied,
+            config_settings=config_settings,
         )
     return req
 
 
-def install_req_from_link_and_ireq(link, ireq):
-    # type: (Link, InstallRequirement) -> InstallRequirement
+def install_req_from_link_and_ireq(
+    link: Link, ireq: InstallRequirement
+) -> InstallRequirement:
     return InstallRequirement(
         req=ireq.req,
         comes_from=ireq.comes_from,
@@ -480,7 +499,8 @@ def install_req_from_link_and_ireq(link, ireq):
         markers=ireq.markers,
         use_pep517=ireq.use_pep517,
         isolated=ireq.isolated,
-        install_options=ireq.install_options,
         global_options=ireq.global_options,
         hash_options=ireq.hash_options,
+        config_settings=ireq.config_settings,
+        user_supplied=ireq.user_supplied,
     )
diff --git a/env/Lib/site-packages/pip/_internal/req/req_file.py b/env/Lib/site-packages/pip/_internal/req/req_file.py
index 080c1281..f717c1cc 100644
--- a/env/Lib/site-packages/pip/_internal/req/req_file.py
+++ b/env/Lib/site-packages/pip/_internal/req/req_file.py
@@ -2,13 +2,24 @@
 Requirements file parsing
 """
 
+import logging
 import optparse
 import os
 import re
 import shlex
 import urllib.parse
 from optparse import Values
-from typing import TYPE_CHECKING, Any, Callable, Dict, Iterator, List, Optional, Tuple
+from typing import (
+    TYPE_CHECKING,
+    Any,
+    Callable,
+    Dict,
+    Generator,
+    Iterable,
+    List,
+    Optional,
+    Tuple,
+)
 
 from pip._internal.cli import cmdoptions
 from pip._internal.exceptions import InstallationError, RequirementsFileParseError
@@ -16,7 +27,7 @@ from pip._internal.models.search_scope import SearchScope
 from pip._internal.network.session import PipSession
 from pip._internal.network.utils import raise_for_status
 from pip._internal.utils.encoding import auto_decode
-from pip._internal.utils.urls import get_url_scheme, url_to_path
+from pip._internal.utils.urls import get_url_scheme
 
 if TYPE_CHECKING:
     # NoReturn introduced in 3.6.2; imported only for type checking to maintain
@@ -25,22 +36,22 @@ if TYPE_CHECKING:
 
     from pip._internal.index.package_finder import PackageFinder
 
-__all__ = ['parse_requirements']
+__all__ = ["parse_requirements"]
 
-ReqFileLines = Iterator[Tuple[int, str]]
+ReqFileLines = Iterable[Tuple[int, str]]
 
 LineParser = Callable[[str], Tuple[str, Values]]
 
-SCHEME_RE = re.compile(r'^(http|https|file):', re.I)
-COMMENT_RE = re.compile(r'(^|\s+)#.*$')
+SCHEME_RE = re.compile(r"^(http|https|file):", re.I)
+COMMENT_RE = re.compile(r"(^|\s+)#.*$")
 
 # Matches environment variable-style values in '${MY_VARIABLE_1}' with the
 # variable name consisting of only uppercase letters, digits or the '_'
 # (underscore). This follows the POSIX standard defined in IEEE Std 1003.1,
 # 2013 Edition.
-ENV_VAR_RE = re.compile(r'(?P<var>\$\{(?P<name>[A-Z0-9_]+)\})')
+ENV_VAR_RE = re.compile(r"(?P<var>\$\{(?P<name>[A-Z0-9_]+)\})")
 
-SUPPORTED_OPTIONS = [
+SUPPORTED_OPTIONS: List[Callable[..., optparse.Option]] = [
     cmdoptions.index_url,
     cmdoptions.extra_index_url,
     cmdoptions.no_index,
@@ -55,30 +66,31 @@ SUPPORTED_OPTIONS = [
     cmdoptions.pre,
     cmdoptions.trusted_host,
     cmdoptions.use_new_feature,
-]  # type: List[Callable[..., optparse.Option]]
+]
 
 # options to be passed to requirements
-SUPPORTED_OPTIONS_REQ = [
-    cmdoptions.install_options,
+SUPPORTED_OPTIONS_REQ: List[Callable[..., optparse.Option]] = [
     cmdoptions.global_options,
     cmdoptions.hash,
-]  # type: List[Callable[..., optparse.Option]]
+    cmdoptions.config_settings,
+]
 
 # the 'dest' string values
 SUPPORTED_OPTIONS_REQ_DEST = [str(o().dest) for o in SUPPORTED_OPTIONS_REQ]
 
+logger = logging.getLogger(__name__)
+
 
 class ParsedRequirement:
     def __init__(
         self,
-        requirement,  # type:str
-        is_editable,  # type: bool
-        comes_from,  # type: str
-        constraint,  # type: bool
-        options=None,  # type: Optional[Dict[str, Any]]
-        line_source=None,  # type: Optional[str]
-    ):
-        # type: (...) -> None
+        requirement: str,
+        is_editable: bool,
+        comes_from: str,
+        constraint: bool,
+        options: Optional[Dict[str, Any]] = None,
+        line_source: Optional[str] = None,
+    ) -> None:
         self.requirement = requirement
         self.is_editable = is_editable
         self.comes_from = comes_from
@@ -90,13 +102,12 @@ class ParsedRequirement:
 class ParsedLine:
     def __init__(
         self,
-        filename,  # type: str
-        lineno,  # type: int
-        args,  # type: str
-        opts,  # type: Values
-        constraint,  # type: bool
-    ):
-        # type: (...) -> None
+        filename: str,
+        lineno: int,
+        args: str,
+        opts: Values,
+        constraint: bool,
+    ) -> None:
         self.filename = filename
         self.lineno = lineno
         self.opts = opts
@@ -116,13 +127,12 @@ class ParsedLine:
 
 
 def parse_requirements(
-    filename,  # type: str
-    session,  # type: PipSession
-    finder=None,  # type: Optional[PackageFinder]
-    options=None,  # type: Optional[optparse.Values]
-    constraint=False,  # type: bool
-):
-    # type: (...) -> Iterator[ParsedRequirement]
+    filename: str,
+    session: PipSession,
+    finder: Optional["PackageFinder"] = None,
+    options: Optional[optparse.Values] = None,
+    constraint: bool = False,
+) -> Generator[ParsedRequirement, None, None]:
     """Parse a requirements file and yield ParsedRequirement instances.
 
     :param filename:    Path or url of requirements file.
@@ -137,22 +147,18 @@ def parse_requirements(
 
     for parsed_line in parser.parse(filename, constraint):
         parsed_req = handle_line(
-            parsed_line,
-            options=options,
-            finder=finder,
-            session=session
+            parsed_line, options=options, finder=finder, session=session
         )
         if parsed_req is not None:
             yield parsed_req
 
 
-def preprocess(content):
-    # type: (str) -> ReqFileLines
+def preprocess(content: str) -> ReqFileLines:
     """Split, filter, and join lines, and return a line iterator
 
     :param content: the content of the requirements file
     """
-    lines_enum = enumerate(content.splitlines(), start=1)  # type: ReqFileLines
+    lines_enum: ReqFileLines = enumerate(content.splitlines(), start=1)
     lines_enum = join_lines(lines_enum)
     lines_enum = ignore_comments(lines_enum)
     lines_enum = expand_env_variables(lines_enum)
@@ -160,14 +166,14 @@ def preprocess(content):
 
 
 def handle_requirement_line(
-    line,  # type: ParsedLine
-    options=None,  # type: Optional[optparse.Values]
-):
-    # type: (...) -> ParsedRequirement
-
+    line: ParsedLine,
+    options: Optional[optparse.Values] = None,
+) -> ParsedRequirement:
     # preserve for the nested code path
-    line_comes_from = '{} {} (line {})'.format(
-        '-c' if line.constraint else '-r', line.filename, line.lineno,
+    line_comes_from = "{} {} (line {})".format(
+        "-c" if line.constraint else "-r",
+        line.filename,
+        line.lineno,
     )
 
     assert line.is_requirement
@@ -182,17 +188,13 @@ def handle_requirement_line(
             constraint=line.constraint,
         )
     else:
-        if options:
-            # Disable wheels if the user has specified build options
-            cmdoptions.check_install_build_global(options, line.opts)
-
         # get the options that apply to requirements
         req_options = {}
         for dest in SUPPORTED_OPTIONS_REQ_DEST:
             if dest in line.opts.__dict__ and line.opts.__dict__[dest]:
                 req_options[dest] = line.opts.__dict__[dest]
 
-        line_source = f'line {line.lineno} of {line.filename}'
+        line_source = f"line {line.lineno} of {line.filename}"
         return ParsedRequirement(
             requirement=line.requirement,
             is_editable=line.is_editable,
@@ -204,14 +206,19 @@ def handle_requirement_line(
 
 
 def handle_option_line(
-    opts,  # type: Values
-    filename,  # type: str
-    lineno,  # type: int
-    finder=None,  # type: Optional[PackageFinder]
-    options=None,  # type: Optional[optparse.Values]
-    session=None,  # type: Optional[PipSession]
-):
-    # type:  (...) -> None
+    opts: Values,
+    filename: str,
+    lineno: int,
+    finder: Optional["PackageFinder"] = None,
+    options: Optional[optparse.Values] = None,
+    session: Optional[PipSession] = None,
+) -> None:
+    if opts.hashes:
+        logger.warning(
+            "%s line %s has --hash but no requirement, and will be ignored.",
+            filename,
+            lineno,
+        )
 
     if options:
         # percolate options upward
@@ -219,19 +226,20 @@ def handle_option_line(
             options.require_hashes = opts.require_hashes
         if opts.features_enabled:
             options.features_enabled.extend(
-                f for f in opts.features_enabled
-                if f not in options.features_enabled
+                f for f in opts.features_enabled if f not in options.features_enabled
             )
 
     # set finder options
     if finder:
         find_links = finder.find_links
         index_urls = finder.index_urls
-        if opts.index_url:
-            index_urls = [opts.index_url]
+        no_index = finder.search_scope.no_index
         if opts.no_index is True:
+            no_index = True
             index_urls = []
-        if opts.extra_index_urls:
+        if opts.index_url and not no_index:
+            index_urls = [opts.index_url]
+        if opts.extra_index_urls and not no_index:
             index_urls.extend(opts.extra_index_urls)
         if opts.find_links:
             # FIXME: it would be nice to keep track of the source
@@ -251,6 +259,7 @@ def handle_option_line(
         search_scope = SearchScope(
             find_links=find_links,
             index_urls=index_urls,
+            no_index=no_index,
         )
         finder.search_scope = search_scope
 
@@ -262,17 +271,16 @@ def handle_option_line(
 
         if session:
             for host in opts.trusted_hosts or []:
-                source = f'line {lineno} of {filename}'
+                source = f"line {lineno} of {filename}"
                 session.add_trusted_host(host, source=source)
 
 
 def handle_line(
-    line,  # type: ParsedLine
-    options=None,  # type: Optional[optparse.Values]
-    finder=None,  # type: Optional[PackageFinder]
-    session=None,  # type: Optional[PipSession]
-):
-    # type: (...) -> Optional[ParsedRequirement]
+    line: ParsedLine,
+    options: Optional[optparse.Values] = None,
+    finder: Optional["PackageFinder"] = None,
+    session: Optional[PipSession] = None,
+) -> Optional[ParsedRequirement]:
     """Handle a single parsed requirements line; This can result in
     creating/yielding requirements, or updating the finder.
 
@@ -314,25 +322,24 @@ def handle_line(
 class RequirementsFileParser:
     def __init__(
         self,
-        session,  # type: PipSession
-        line_parser,  # type: LineParser
-    ):
-        # type: (...) -> None
+        session: PipSession,
+        line_parser: LineParser,
+    ) -> None:
         self._session = session
         self._line_parser = line_parser
 
-    def parse(self, filename, constraint):
-        # type: (str, bool) -> Iterator[ParsedLine]
-        """Parse a given file, yielding parsed lines.
-        """
+    def parse(
+        self, filename: str, constraint: bool
+    ) -> Generator[ParsedLine, None, None]:
+        """Parse a given file, yielding parsed lines."""
         yield from self._parse_and_recurse(filename, constraint)
 
-    def _parse_and_recurse(self, filename, constraint):
-        # type: (str, bool) -> Iterator[ParsedLine]
+    def _parse_and_recurse(
+        self, filename: str, constraint: bool
+    ) -> Generator[ParsedLine, None, None]:
         for line in self._parse_file(filename, constraint):
-            if (
-                not line.is_requirement and
-                (line.opts.requirements or line.opts.constraints)
+            if not line.is_requirement and (
+                line.opts.requirements or line.opts.constraints
             ):
                 # parse a nested requirements file
                 if line.opts.requirements:
@@ -350,15 +357,17 @@ class RequirementsFileParser:
                 elif not SCHEME_RE.search(req_path):
                     # do a join so relative paths work
                     req_path = os.path.join(
-                        os.path.dirname(filename), req_path,
+                        os.path.dirname(filename),
+                        req_path,
                     )
 
                 yield from self._parse_and_recurse(req_path, nested_constraint)
             else:
                 yield line
 
-    def _parse_file(self, filename, constraint):
-        # type: (str, bool) -> Iterator[ParsedLine]
+    def _parse_file(
+        self, filename: str, constraint: bool
+    ) -> Generator[ParsedLine, None, None]:
         _, content = get_file_content(filename, self._session)
 
         lines_enum = preprocess(content)
@@ -368,7 +377,7 @@ class RequirementsFileParser:
                 args_str, opts = self._line_parser(line)
             except OptionParsingError as e:
                 # add offending line
-                msg = f'Invalid requirement: {line}\n{e.msg}'
+                msg = f"Invalid requirement: {line}\n{e.msg}"
                 raise RequirementsFileParseError(msg)
 
             yield ParsedLine(
@@ -380,10 +389,8 @@ class RequirementsFileParser:
             )
 
 
-def get_line_parser(finder):
-    # type: (Optional[PackageFinder]) -> LineParser
-    def parse_line(line):
-        # type: (str) -> Tuple[str, Values]
+def get_line_parser(finder: Optional["PackageFinder"]) -> LineParser:
+    def parse_line(line: str) -> Tuple[str, Values]:
         # Build new parser for each line since it accumulates appendable
         # options.
         parser = build_parser()
@@ -394,39 +401,41 @@ def get_line_parser(finder):
 
         args_str, options_str = break_args_options(line)
 
-        opts, _ = parser.parse_args(shlex.split(options_str), defaults)
+        try:
+            options = shlex.split(options_str)
+        except ValueError as e:
+            raise OptionParsingError(f"Could not split options: {options_str}") from e
+
+        opts, _ = parser.parse_args(options, defaults)
 
         return args_str, opts
 
     return parse_line
 
 
-def break_args_options(line):
-    # type: (str) -> Tuple[str, str]
+def break_args_options(line: str) -> Tuple[str, str]:
     """Break up the line into an args and options string.  We only want to shlex
     (and then optparse) the options, not the args.  args can contain markers
     which are corrupted by shlex.
     """
-    tokens = line.split(' ')
+    tokens = line.split(" ")
     args = []
     options = tokens[:]
     for token in tokens:
-        if token.startswith('-') or token.startswith('--'):
+        if token.startswith("-") or token.startswith("--"):
             break
         else:
             args.append(token)
             options.pop(0)
-    return ' '.join(args), ' '.join(options)
+    return " ".join(args), " ".join(options)
 
 
 class OptionParsingError(Exception):
-    def __init__(self, msg):
-        # type: (str) -> None
+    def __init__(self, msg: str) -> None:
         self.msg = msg
 
 
-def build_parser():
-    # type: () -> optparse.OptionParser
+def build_parser() -> optparse.OptionParser:
     """
     Return a parser for parsing requirement lines
     """
@@ -439,9 +448,9 @@ def build_parser():
 
     # By default optparse sys.exits on parsing errors. We want to wrap
     # that in our own exception.
-    def parser_exit(self, msg):
-        # type: (Any, str) -> NoReturn
+    def parser_exit(self: Any, msg: str) -> "NoReturn":
         raise OptionParsingError(msg)
+
     # NOTE: mypy disallows assigning to a method
     #       https://github.com/python/mypy/issues/2427
     parser.exit = parser_exit  # type: ignore
@@ -449,52 +458,49 @@ def build_parser():
     return parser
 
 
-def join_lines(lines_enum):
-    # type: (ReqFileLines) -> ReqFileLines
+def join_lines(lines_enum: ReqFileLines) -> ReqFileLines:
     """Joins a line ending in '\' with the previous line (except when following
     comments).  The joined line takes on the index of the first line.
     """
     primary_line_number = None
-    new_line = []  # type: List[str]
+    new_line: List[str] = []
     for line_number, line in lines_enum:
-        if not line.endswith('\\') or COMMENT_RE.match(line):
+        if not line.endswith("\\") or COMMENT_RE.match(line):
             if COMMENT_RE.match(line):
                 # this ensures comments are always matched later
-                line = ' ' + line
+                line = " " + line
             if new_line:
                 new_line.append(line)
                 assert primary_line_number is not None
-                yield primary_line_number, ''.join(new_line)
+                yield primary_line_number, "".join(new_line)
                 new_line = []
             else:
                 yield line_number, line
         else:
             if not new_line:
                 primary_line_number = line_number
-            new_line.append(line.strip('\\'))
+            new_line.append(line.strip("\\"))
 
     # last line contains \
     if new_line:
         assert primary_line_number is not None
-        yield primary_line_number, ''.join(new_line)
+        yield primary_line_number, "".join(new_line)
 
     # TODO: handle space after '\'.
 
 
-def ignore_comments(lines_enum):
-    # type: (ReqFileLines) -> ReqFileLines
+def ignore_comments(lines_enum: ReqFileLines) -> ReqFileLines:
     """
     Strips comments and filter empty lines.
     """
     for line_number, line in lines_enum:
-        line = COMMENT_RE.sub('', line)
+        line = COMMENT_RE.sub("", line)
         line = line.strip()
         if line:
             yield line_number, line
 
 
-def expand_env_variables(lines_enum):
-    # type: (ReqFileLines) -> ReqFileLines
+def expand_env_variables(lines_enum: ReqFileLines) -> ReqFileLines:
     """Replace all environment variables that can be retrieved via `os.getenv`.
 
     The only allowed format for environment variables defined in the
@@ -521,8 +527,7 @@ def expand_env_variables(lines_enum):
         yield line_number, line
 
 
-def get_file_content(url, session):
-    # type: (str, PipSession) -> Tuple[str, str]
+def get_file_content(url: str, session: PipSession) -> Tuple[str, str]:
     """Gets the content of a file; it may be a filename, file: URL, or
     http: URL.  Returns (location, content).  Content is unicode.
     Respects # -*- coding: declarations on the retrieved files.
@@ -532,20 +537,16 @@ def get_file_content(url, session):
     """
     scheme = get_url_scheme(url)
 
-    if scheme in ['http', 'https']:
-        # FIXME: catch some errors
+    # Pip has special support for file:// URLs (LocalFSAdapter).
+    if scheme in ["http", "https", "file"]:
         resp = session.get(url)
         raise_for_status(resp)
         return resp.url, resp.text
 
-    elif scheme == 'file':
-        url = url_to_path(url)
-
+    # Assume this is a bare path.
     try:
-        with open(url, 'rb') as f:
+        with open(url, "rb") as f:
             content = auto_decode(f.read())
     except OSError as exc:
-        raise InstallationError(
-            f'Could not open requirements file: {exc}'
-        )
+        raise InstallationError(f"Could not open requirements file: {exc}")
     return url, content
diff --git a/env/Lib/site-packages/pip/_internal/req/req_install.py b/env/Lib/site-packages/pip/_internal/req/req_install.py
index f4d62514..1f479713 100644
--- a/env/Lib/site-packages/pip/_internal/req/req_install.py
+++ b/env/Lib/site-packages/pip/_internal/req/req_install.py
@@ -1,55 +1,59 @@
 # The following comment should be removed at some point in the future.
 # mypy: strict-optional=False
 
+import functools
 import logging
 import os
 import shutil
 import sys
 import uuid
 import zipfile
-from typing import Any, Dict, Iterable, List, Optional, Sequence, Union
+from optparse import Values
+from typing import Any, Collection, Dict, Iterable, List, Optional, Sequence, Union
 
-from pip._vendor import pkg_resources, six
 from pip._vendor.packaging.markers import Marker
 from pip._vendor.packaging.requirements import Requirement
 from pip._vendor.packaging.specifiers import SpecifierSet
 from pip._vendor.packaging.utils import canonicalize_name
 from pip._vendor.packaging.version import Version
 from pip._vendor.packaging.version import parse as parse_version
-from pip._vendor.pep517.wrappers import Pep517HookCaller
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.pyproject_hooks import BuildBackendHookCaller
 
 from pip._internal.build_env import BuildEnvironment, NoOpBuildEnvironment
 from pip._internal.exceptions import InstallationError
 from pip._internal.locations import get_scheme
+from pip._internal.metadata import (
+    BaseDistribution,
+    get_default_environment,
+    get_directory_distribution,
+    get_wheel_distribution,
+)
+from pip._internal.metadata.base import FilesystemWheel
+from pip._internal.models.direct_url import DirectUrl
 from pip._internal.models.link import Link
 from pip._internal.operations.build.metadata import generate_metadata
+from pip._internal.operations.build.metadata_editable import generate_editable_metadata
 from pip._internal.operations.build.metadata_legacy import (
     generate_metadata as generate_metadata_legacy,
 )
 from pip._internal.operations.install.editable_legacy import (
     install_editable as install_editable_legacy,
 )
-from pip._internal.operations.install.legacy import LegacyInstallFailure
-from pip._internal.operations.install.legacy import install as install_legacy
 from pip._internal.operations.install.wheel import install_wheel
 from pip._internal.pyproject import load_pyproject_toml, make_pyproject_path
 from pip._internal.req.req_uninstall import UninstallPathSet
 from pip._internal.utils.deprecation import deprecated
-from pip._internal.utils.direct_url_helpers import direct_url_from_link
 from pip._internal.utils.hashes import Hashes
-from pip._internal.utils.logging import indent_log
 from pip._internal.utils.misc import (
+    ConfiguredBuildBackendHookCaller,
     ask_path_exists,
     backup_dir,
     display_path,
-    dist_in_site_packages,
-    dist_in_usersite,
-    get_distribution,
     hide_url,
     redact_auth_from_url,
 )
-from pip._internal.utils.packaging import get_metadata
+from pip._internal.utils.packaging import safe_extra
+from pip._internal.utils.subprocess import runner_with_spinner_message
 from pip._internal.utils.temp_dir import TempDirectory, tempdir_kinds
 from pip._internal.utils.virtualenv import running_under_virtualenv
 from pip._internal.vcs import vcs
@@ -57,33 +61,6 @@ from pip._internal.vcs import vcs
 logger = logging.getLogger(__name__)
 
 
-def _get_dist(metadata_directory):
-    # type: (str) -> Distribution
-    """Return a pkg_resources.Distribution for the provided
-    metadata directory.
-    """
-    dist_dir = metadata_directory.rstrip(os.sep)
-
-    # Build a PathMetadata object, from path to metadata. :wink:
-    base_dir, dist_dir_name = os.path.split(dist_dir)
-    metadata = pkg_resources.PathMetadata(base_dir, dist_dir)
-
-    # Determine the correct Distribution object type.
-    if dist_dir.endswith(".egg-info"):
-        dist_cls = pkg_resources.Distribution
-        dist_name = os.path.splitext(dist_dir_name)[0]
-    else:
-        assert dist_dir.endswith(".dist-info")
-        dist_cls = pkg_resources.DistInfoDistribution
-        dist_name = os.path.splitext(dist_dir_name)[0].split("-")[0]
-
-    return dist_cls(
-        base_dir,
-        project_name=dist_name,
-        metadata=metadata,
-    )
-
-
 class InstallRequirement:
     """
     Represents something that may be installed later on, may have information
@@ -93,78 +70,84 @@ class InstallRequirement:
 
     def __init__(
         self,
-        req,  # type: Optional[Requirement]
-        comes_from,  # type: Optional[Union[str, InstallRequirement]]
-        editable=False,  # type: bool
-        link=None,  # type: Optional[Link]
-        markers=None,  # type: Optional[Marker]
-        use_pep517=None,  # type: Optional[bool]
-        isolated=False,  # type: bool
-        install_options=None,  # type: Optional[List[str]]
-        global_options=None,  # type: Optional[List[str]]
-        hash_options=None,  # type: Optional[Dict[str, List[str]]]
-        constraint=False,  # type: bool
-        extras=(),  # type: Iterable[str]
-        user_supplied=False,  # type: bool
-    ):
-        # type: (...) -> None
+        req: Optional[Requirement],
+        comes_from: Optional[Union[str, "InstallRequirement"]],
+        editable: bool = False,
+        link: Optional[Link] = None,
+        markers: Optional[Marker] = None,
+        use_pep517: Optional[bool] = None,
+        isolated: bool = False,
+        *,
+        global_options: Optional[List[str]] = None,
+        hash_options: Optional[Dict[str, List[str]]] = None,
+        config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+        constraint: bool = False,
+        extras: Collection[str] = (),
+        user_supplied: bool = False,
+        permit_editable_wheels: bool = False,
+    ) -> None:
         assert req is None or isinstance(req, Requirement), req
         self.req = req
         self.comes_from = comes_from
         self.constraint = constraint
         self.editable = editable
-        self.legacy_install_reason = None  # type: Optional[int]
+        self.permit_editable_wheels = permit_editable_wheels
 
         # source_dir is the local directory where the linked requirement is
         # located, or unpacked. In case unpacking is needed, creating and
         # populating source_dir is done by the RequirementPreparer. Note this
         # is not necessarily the directory where pyproject.toml or setup.py is
         # located - that one is obtained via unpacked_source_directory.
-        self.source_dir = None  # type: Optional[str]
+        self.source_dir: Optional[str] = None
         if self.editable:
             assert link
             if link.is_file:
-                self.source_dir = os.path.normpath(
-                    os.path.abspath(link.file_path)
-                )
+                self.source_dir = os.path.normpath(os.path.abspath(link.file_path))
 
+        # original_link is the direct URL that was provided by the user for the
+        # requirement, either directly or via a constraints file.
         if link is None and req and req.url:
             # PEP 508 URL requirement
             link = Link(req.url)
         self.link = self.original_link = link
-        self.original_link_is_in_wheel_cache = False
+
+        # When this InstallRequirement is a wheel obtained from the cache of locally
+        # built wheels, this is the source link corresponding to the cache entry, which
+        # was used to download and build the cached wheel.
+        self.cached_wheel_source_link: Optional[Link] = None
+
+        # Information about the location of the artifact that was downloaded . This
+        # property is guaranteed to be set in resolver results.
+        self.download_info: Optional[DirectUrl] = None
 
         # Path to any downloaded or already-existing package.
-        self.local_file_path = None  # type: Optional[str]
+        self.local_file_path: Optional[str] = None
         if self.link and self.link.is_file:
             self.local_file_path = self.link.file_path
 
         if extras:
             self.extras = extras
         elif req:
-            self.extras = {
-                pkg_resources.safe_extra(extra) for extra in req.extras
-            }
+            self.extras = {safe_extra(extra) for extra in req.extras}
         else:
             self.extras = set()
         if markers is None and req:
             markers = req.marker
         self.markers = markers
 
-        # This holds the pkg_resources.Distribution object if this requirement
-        # is already available:
-        self.satisfied_by = None  # type: Optional[Distribution]
+        # This holds the Distribution object if this requirement is already installed.
+        self.satisfied_by: Optional[BaseDistribution] = None
         # Whether the installation process should try to uninstall an existing
         # distribution before installing this requirement.
         self.should_reinstall = False
         # Temporary build location
-        self._temp_build_dir = None  # type: Optional[TempDirectory]
+        self._temp_build_dir: Optional[TempDirectory] = None
         # Set to True after successful installation
-        self.install_succeeded = None  # type: Optional[bool]
+        self.install_succeeded: Optional[bool] = None
         # Supplied options
-        self.install_options = install_options if install_options else []
         self.global_options = global_options if global_options else []
         self.hash_options = hash_options if hash_options else {}
+        self.config_settings = config_settings
         # Set to True after successful preparation of this requirement
         self.prepared = False
         # User supplied requirement are explicitly requested for installation
@@ -173,22 +156,22 @@ class InstallRequirement:
         self.user_supplied = user_supplied
 
         self.isolated = isolated
-        self.build_env = NoOpBuildEnvironment()  # type: BuildEnvironment
+        self.build_env: BuildEnvironment = NoOpBuildEnvironment()
 
         # For PEP 517, the directory where we request the project metadata
         # gets stored. We need this to pass to build_wheel, so the backend
         # can ensure that the wheel matches the metadata (see the PEP for
         # details).
-        self.metadata_directory = None  # type: Optional[str]
+        self.metadata_directory: Optional[str] = None
 
         # The static build requirements (from pyproject.toml)
-        self.pyproject_requires = None  # type: Optional[List[str]]
+        self.pyproject_requires: Optional[List[str]] = None
 
         # Build requirements that we will check are available
-        self.requirements_to_check = []  # type: List[str]
+        self.requirements_to_check: List[str] = []
 
         # The PEP 517 backend we should use to build the project
-        self.pep517_backend = None  # type: Optional[Pep517HookCaller]
+        self.pep517_backend: Optional[BuildBackendHookCaller] = None
 
         # Are we using PEP 517 for this requirement?
         # After pyproject.toml has been loaded, the only valid values are True
@@ -200,87 +183,97 @@ class InstallRequirement:
         # This requirement needs more preparation before it can be built
         self.needs_more_preparation = False
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         if self.req:
             s = str(self.req)
             if self.link:
-                s += ' from {}'.format(redact_auth_from_url(self.link.url))
+                s += " from {}".format(redact_auth_from_url(self.link.url))
         elif self.link:
             s = redact_auth_from_url(self.link.url)
         else:
-            s = '<InstallRequirement>'
+            s = "<InstallRequirement>"
         if self.satisfied_by is not None:
-            s += ' in {}'.format(display_path(self.satisfied_by.location))
+            if self.satisfied_by.location is not None:
+                location = display_path(self.satisfied_by.location)
+            else:
+                location = "<memory>"
+            s += f" in {location}"
         if self.comes_from:
             if isinstance(self.comes_from, str):
-                comes_from = self.comes_from  # type: Optional[str]
+                comes_from: Optional[str] = self.comes_from
             else:
                 comes_from = self.comes_from.from_path()
             if comes_from:
-                s += f' (from {comes_from})'
+                s += f" (from {comes_from})"
         return s
 
-    def __repr__(self):
-        # type: () -> str
-        return '<{} object: {} editable={!r}>'.format(
-            self.__class__.__name__, str(self), self.editable)
+    def __repr__(self) -> str:
+        return "<{} object: {} editable={!r}>".format(
+            self.__class__.__name__, str(self), self.editable
+        )
 
-    def format_debug(self):
-        # type: () -> str
-        """An un-tested helper for getting state, for debugging.
-        """
+    def format_debug(self) -> str:
+        """An un-tested helper for getting state, for debugging."""
         attributes = vars(self)
         names = sorted(attributes)
 
-        state = (
-            "{}={!r}".format(attr, attributes[attr]) for attr in sorted(names)
-        )
-        return '<{name} object: {{{state}}}>'.format(
+        state = ("{}={!r}".format(attr, attributes[attr]) for attr in sorted(names))
+        return "<{name} object: {{{state}}}>".format(
             name=self.__class__.__name__,
             state=", ".join(state),
         )
 
     # Things that are valid for all kinds of requirements?
     @property
-    def name(self):
-        # type: () -> Optional[str]
+    def name(self) -> Optional[str]:
         if self.req is None:
             return None
-        return pkg_resources.safe_name(self.req.name)
+        return self.req.name
+
+    @functools.lru_cache()  # use cached_property in python 3.8+
+    def supports_pyproject_editable(self) -> bool:
+        if not self.use_pep517:
+            return False
+        assert self.pep517_backend
+        with self.build_env:
+            runner = runner_with_spinner_message(
+                "Checking if build backend supports build_editable"
+            )
+            with self.pep517_backend.subprocess_runner(runner):
+                return "build_editable" in self.pep517_backend._supported_features()
 
     @property
-    def specifier(self):
-        # type: () -> SpecifierSet
+    def specifier(self) -> SpecifierSet:
         return self.req.specifier
 
     @property
-    def is_pinned(self):
-        # type: () -> bool
+    def is_direct(self) -> bool:
+        """Whether this requirement was specified as a direct URL."""
+        return self.original_link is not None
+
+    @property
+    def is_pinned(self) -> bool:
         """Return whether I am pinned to an exact version.
 
         For example, some-package==1.2 is pinned; some-package>1.2 is not.
         """
         specifiers = self.specifier
-        return (len(specifiers) == 1 and
-                next(iter(specifiers)).operator in {'==', '==='})
+        return len(specifiers) == 1 and next(iter(specifiers)).operator in {"==", "==="}
 
-    def match_markers(self, extras_requested=None):
-        # type: (Optional[Iterable[str]]) -> bool
+    def match_markers(self, extras_requested: Optional[Iterable[str]] = None) -> bool:
         if not extras_requested:
             # Provide an extra to safely evaluate the markers
             # without matching any extra
-            extras_requested = ('',)
+            extras_requested = ("",)
         if self.markers is not None:
             return any(
-                self.markers.evaluate({'extra': extra})
-                for extra in extras_requested)
+                self.markers.evaluate({"extra": extra}) for extra in extras_requested
+            )
         else:
             return True
 
     @property
-    def has_hash_options(self):
-        # type: () -> bool
+    def has_hash_options(self) -> bool:
         """Return whether any known-good hashes are specified as options.
 
         These activate --require-hashes mode; hashes specified as part of a
@@ -289,8 +282,7 @@ class InstallRequirement:
         """
         return bool(self.hash_options)
 
-    def hashes(self, trust_internet=True):
-        # type: (bool) -> Hashes
+    def hashes(self, trust_internet: bool = True) -> Hashes:
         """Return a hash-comparer that considers my option- and URL-based
         hashes to be known-good.
 
@@ -306,15 +298,18 @@ class InstallRequirement:
 
         """
         good_hashes = self.hash_options.copy()
-        link = self.link if trust_internet else self.original_link
+        if trust_internet:
+            link = self.link
+        elif self.is_direct and self.user_supplied:
+            link = self.original_link
+        else:
+            link = None
         if link and link.hash:
             good_hashes.setdefault(link.hash_name, []).append(link.hash)
         return Hashes(good_hashes)
 
-    def from_path(self):
-        # type: () -> Optional[str]
-        """Format a nice indicator to show where this "comes from"
-        """
+    def from_path(self) -> Optional[str]:
+        """Format a nice indicator to show where this "comes from" """
         if self.req is None:
             return None
         s = str(self.req)
@@ -324,11 +319,12 @@ class InstallRequirement:
             else:
                 comes_from = self.comes_from.from_path()
             if comes_from:
-                s += '->' + comes_from
+                s += "->" + comes_from
         return s
 
-    def ensure_build_location(self, build_dir, autodelete, parallel_builds):
-        # type: (str, bool, bool) -> str
+    def ensure_build_location(
+        self, build_dir: str, autodelete: bool, parallel_builds: bool
+    ) -> str:
         assert build_dir is not None
         if self._temp_build_dir is not None:
             assert self._temp_build_dir.path
@@ -349,14 +345,14 @@ class InstallRequirement:
 
         # When parallel builds are enabled, add a UUID to the build directory
         # name so multiple builds do not interfere with each other.
-        dir_name = canonicalize_name(self.name)  # type: str
+        dir_name: str = canonicalize_name(self.name)
         if parallel_builds:
             dir_name = f"{dir_name}_{uuid.uuid4().hex}"
 
         # FIXME: Is there a better place to create the build_dir? (hg and bzr
         # need this)
         if not os.path.exists(build_dir):
-            logger.debug('Creating directory %s', build_dir)
+            logger.debug("Creating directory %s", build_dir)
             os.makedirs(build_dir)
         actual_build_dir = os.path.join(build_dir, dir_name)
         # `None` indicates that we respect the globally-configured deletion
@@ -369,10 +365,8 @@ class InstallRequirement:
             globally_managed=True,
         ).path
 
-    def _set_requirement(self):
-        # type: () -> None
-        """Set requirement after generating metadata.
-        """
+    def _set_requirement(self) -> None:
+        """Set requirement after generating metadata."""
         assert self.req is None
         assert self.metadata is not None
         assert self.source_dir is not None
@@ -384,15 +378,16 @@ class InstallRequirement:
             op = "==="
 
         self.req = Requirement(
-            "".join([
-                self.metadata["Name"],
-                op,
-                self.metadata["Version"],
-            ])
+            "".join(
+                [
+                    self.metadata["Name"],
+                    op,
+                    self.metadata["Version"],
+                ]
+            )
         )
 
-    def warn_on_mismatching_name(self):
-        # type: () -> None
+    def warn_on_mismatching_name(self) -> None:
         metadata_name = canonicalize_name(self.metadata["Name"])
         if canonicalize_name(self.req.name) == metadata_name:
             # Everything is fine.
@@ -400,45 +395,40 @@ class InstallRequirement:
 
         # If we're here, there's a mismatch. Log a warning about it.
         logger.warning(
-            'Generating metadata for package %s '
-            'produced metadata for project name %s. Fix your '
-            '#egg=%s fragments.',
-            self.name, metadata_name, self.name
+            "Generating metadata for package %s "
+            "produced metadata for project name %s. Fix your "
+            "#egg=%s fragments.",
+            self.name,
+            metadata_name,
+            self.name,
         )
         self.req = Requirement(metadata_name)
 
-    def check_if_exists(self, use_user_site):
-        # type: (bool) -> None
+    def check_if_exists(self, use_user_site: bool) -> None:
         """Find an installed distribution that satisfies or conflicts
         with this requirement, and set self.satisfied_by or
         self.should_reinstall appropriately.
         """
         if self.req is None:
             return
-        existing_dist = get_distribution(self.req.name)
+        existing_dist = get_default_environment().get_distribution(self.req.name)
         if not existing_dist:
             return
 
-        # pkg_resouces may contain a different copy of packaging.version from
-        # pip in if the downstream distributor does a poor job debundling pip.
-        # We avoid existing_dist.parsed_version and let SpecifierSet.contains
-        # parses the version instead.
-        existing_version = existing_dist.version
-        version_compatible = (
-            existing_version is not None and
-            self.req.specifier.contains(existing_version, prereleases=True)
+        version_compatible = self.req.specifier.contains(
+            existing_dist.version,
+            prereleases=True,
         )
         if not version_compatible:
             self.satisfied_by = None
             if use_user_site:
-                if dist_in_usersite(existing_dist):
+                if existing_dist.in_usersite:
                     self.should_reinstall = True
-                elif (running_under_virtualenv() and
-                        dist_in_site_packages(existing_dist)):
+                elif running_under_virtualenv() and existing_dist.in_site_packages:
                     raise InstallationError(
-                        "Will not install to the user site because it will "
-                        "lack sys.path precedence to {} in {}".format(
-                            existing_dist.project_name, existing_dist.location)
+                        f"Will not install to the user site because it will "
+                        f"lack sys.path precedence to {existing_dist.raw_name} "
+                        f"in {existing_dist.location}"
                     )
             else:
                 self.should_reinstall = True
@@ -453,36 +443,44 @@ class InstallRequirement:
 
     # Things valid for wheels
     @property
-    def is_wheel(self):
-        # type: () -> bool
+    def is_wheel(self) -> bool:
         if not self.link:
             return False
         return self.link.is_wheel
 
+    @property
+    def is_wheel_from_cache(self) -> bool:
+        # When True, it means that this InstallRequirement is a local wheel file in the
+        # cache of locally built wheels.
+        return self.cached_wheel_source_link is not None
+
     # Things valid for sdists
     @property
-    def unpacked_source_directory(self):
-        # type: () -> str
+    def unpacked_source_directory(self) -> str:
         return os.path.join(
-            self.source_dir,
-            self.link and self.link.subdirectory_fragment or '')
+            self.source_dir, self.link and self.link.subdirectory_fragment or ""
+        )
 
     @property
-    def setup_py_path(self):
-        # type: () -> str
+    def setup_py_path(self) -> str:
         assert self.source_dir, f"No source dir for {self}"
-        setup_py = os.path.join(self.unpacked_source_directory, 'setup.py')
+        setup_py = os.path.join(self.unpacked_source_directory, "setup.py")
 
         return setup_py
 
     @property
-    def pyproject_toml_path(self):
-        # type: () -> str
+    def setup_cfg_path(self) -> str:
+        assert self.source_dir, f"No source dir for {self}"
+        setup_cfg = os.path.join(self.unpacked_source_directory, "setup.cfg")
+
+        return setup_cfg
+
+    @property
+    def pyproject_toml_path(self) -> str:
         assert self.source_dir, f"No source dir for {self}"
         return make_pyproject_path(self.unpacked_source_directory)
 
-    def load_pyproject_toml(self):
-        # type: () -> None
+    def load_pyproject_toml(self) -> None:
         """Load the pyproject.toml file.
 
         After calling this routine, all of the attributes related to PEP 517
@@ -491,13 +489,19 @@ class InstallRequirement:
         follow the PEP 517 or legacy (setup.py) code path.
         """
         pyproject_toml_data = load_pyproject_toml(
-            self.use_pep517,
-            self.pyproject_toml_path,
-            self.setup_py_path,
-            str(self)
+            self.use_pep517, self.pyproject_toml_path, self.setup_py_path, str(self)
         )
 
         if pyproject_toml_data is None:
+            if self.config_settings:
+                deprecated(
+                    reason=f"Config settings are ignored for project {self}.",
+                    replacement=(
+                        "to use --use-pep517 or add a "
+                        "pyproject.toml file to the project"
+                    ),
+                    gone_in="23.3",
+                )
             self.use_pep517 = False
             return
 
@@ -505,48 +509,69 @@ class InstallRequirement:
         requires, backend, check, backend_path = pyproject_toml_data
         self.requirements_to_check = check
         self.pyproject_requires = requires
-        self.pep517_backend = Pep517HookCaller(
-            self.unpacked_source_directory, backend, backend_path=backend_path,
+        self.pep517_backend = ConfiguredBuildBackendHookCaller(
+            self,
+            self.unpacked_source_directory,
+            backend,
+            backend_path=backend_path,
         )
 
-    def _generate_metadata(self):
-        # type: () -> str
-        """Invokes metadata generator functions, with the required arguments.
-        """
-        if not self.use_pep517:
-            assert self.unpacked_source_directory
-
-            if not os.path.exists(self.setup_py_path):
-                raise InstallationError(
-                    f'File "setup.py" not found for legacy project {self}.'
-                )
+    def isolated_editable_sanity_check(self) -> None:
+        """Check that an editable requirement if valid for use with PEP 517/518.
 
-            return generate_metadata_legacy(
-                build_env=self.build_env,
-                setup_py_path=self.setup_py_path,
-                source_dir=self.unpacked_source_directory,
-                isolated=self.isolated,
-                details=self.name or f"from {self.link}"
+        This verifies that an editable that has a pyproject.toml either supports PEP 660
+        or as a setup.py or a setup.cfg
+        """
+        if (
+            self.editable
+            and self.use_pep517
+            and not self.supports_pyproject_editable()
+            and not os.path.isfile(self.setup_py_path)
+            and not os.path.isfile(self.setup_cfg_path)
+        ):
+            raise InstallationError(
+                f"Project {self} has a 'pyproject.toml' and its build "
+                f"backend is missing the 'build_editable' hook. Since it does not "
+                f"have a 'setup.py' nor a 'setup.cfg', "
+                f"it cannot be installed in editable mode. "
+                f"Consider using a build backend that supports PEP 660."
             )
 
-        assert self.pep517_backend is not None
-
-        return generate_metadata(
-            build_env=self.build_env,
-            backend=self.pep517_backend,
-        )
-
-    def prepare_metadata(self):
-        # type: () -> None
+    def prepare_metadata(self) -> None:
         """Ensure that project metadata is available.
 
-        Under PEP 517, call the backend hook to prepare the metadata.
+        Under PEP 517 and PEP 660, call the backend hook to prepare the metadata.
         Under legacy processing, call setup.py egg-info.
         """
         assert self.source_dir
-
-        with indent_log():
-            self.metadata_directory = self._generate_metadata()
+        details = self.name or f"from {self.link}"
+
+        if self.use_pep517:
+            assert self.pep517_backend is not None
+            if (
+                self.editable
+                and self.permit_editable_wheels
+                and self.supports_pyproject_editable()
+            ):
+                self.metadata_directory = generate_editable_metadata(
+                    build_env=self.build_env,
+                    backend=self.pep517_backend,
+                    details=details,
+                )
+            else:
+                self.metadata_directory = generate_metadata(
+                    build_env=self.build_env,
+                    backend=self.pep517_backend,
+                    details=details,
+                )
+        else:
+            self.metadata_directory = generate_metadata_legacy(
+                build_env=self.build_env,
+                setup_py_path=self.setup_py_path,
+                source_dir=self.unpacked_source_directory,
+                isolated=self.isolated,
+                details=details,
+            )
 
         # Act on the newly generated metadata, based on the name and version.
         if not self.name:
@@ -557,30 +582,36 @@ class InstallRequirement:
         self.assert_source_matches_version()
 
     @property
-    def metadata(self):
-        # type: () -> Any
-        if not hasattr(self, '_metadata'):
-            self._metadata = get_metadata(self.get_dist())
+    def metadata(self) -> Any:
+        if not hasattr(self, "_metadata"):
+            self._metadata = self.get_dist().metadata
 
         return self._metadata
 
-    def get_dist(self):
-        # type: () -> Distribution
-        return _get_dist(self.metadata_directory)
+    def get_dist(self) -> BaseDistribution:
+        if self.metadata_directory:
+            return get_directory_distribution(self.metadata_directory)
+        elif self.local_file_path and self.is_wheel:
+            return get_wheel_distribution(
+                FilesystemWheel(self.local_file_path), canonicalize_name(self.name)
+            )
+        raise AssertionError(
+            f"InstallRequirement {self} has no metadata directory and no wheel: "
+            f"can't make a distribution."
+        )
 
-    def assert_source_matches_version(self):
-        # type: () -> None
+    def assert_source_matches_version(self) -> None:
         assert self.source_dir
-        version = self.metadata['version']
+        version = self.metadata["version"]
         if self.req.specifier and version not in self.req.specifier:
             logger.warning(
-                'Requested %s, but installing version %s',
+                "Requested %s, but installing version %s",
                 self,
                 version,
             )
         else:
             logger.debug(
-                'Source in %s has version %s, which satisfies requirement %s',
+                "Source in %s has version %s, which satisfies requirement %s",
                 display_path(self.source_dir),
                 version,
                 self,
@@ -589,11 +620,10 @@ class InstallRequirement:
     # For both source distributions and editables
     def ensure_has_source_dir(
         self,
-        parent_dir,
-        autodelete=False,
-        parallel_builds=False,
-    ):
-        # type: (str, bool, bool) -> None
+        parent_dir: str,
+        autodelete: bool = False,
+        parallel_builds: bool = False,
+    ) -> None:
         """Ensure that a source_dir is set.
 
         This will create a temporary build dir if the name of the requirement
@@ -611,18 +641,16 @@ class InstallRequirement:
             )
 
     # For editable installations
-    def update_editable(self):
-        # type: () -> None
+    def update_editable(self) -> None:
         if not self.link:
             logger.debug(
-                "Cannot update repository at %s; repository location is "
-                "unknown",
+                "Cannot update repository at %s; repository location is unknown",
                 self.source_dir,
             )
             return
         assert self.editable
         assert self.source_dir
-        if self.link.scheme == 'file':
+        if self.link.scheme == "file":
             # Static paths don't get updated
             return
         vcs_backend = vcs.get_backend_for_scheme(self.link.scheme)
@@ -630,11 +658,12 @@ class InstallRequirement:
         # So here, if it's neither a path nor a valid VCS URL, it's a bug.
         assert vcs_backend, f"Unsupported VCS URL {self.link.url}"
         hidden_url = hide_url(self.link.url)
-        vcs_backend.obtain(self.source_dir, url=hidden_url)
+        vcs_backend.obtain(self.source_dir, url=hidden_url, verbosity=0)
 
     # Top-level Actions
-    def uninstall(self, auto_confirm=False, verbose=False):
-        # type: (bool, bool) -> Optional[UninstallPathSet]
+    def uninstall(
+        self, auto_confirm: bool = False, verbose: bool = False
+    ) -> Optional[UninstallPathSet]:
         """
         Uninstall the distribution currently satisfying this requirement.
 
@@ -648,34 +677,30 @@ class InstallRequirement:
 
         """
         assert self.req
-        dist = get_distribution(self.req.name)
+        dist = get_default_environment().get_distribution(self.req.name)
         if not dist:
             logger.warning("Skipping %s as it is not installed.", self.name)
             return None
-        logger.info('Found existing installation: %s', dist)
+        logger.info("Found existing installation: %s", dist)
 
         uninstalled_pathset = UninstallPathSet.from_dist(dist)
         uninstalled_pathset.remove(auto_confirm, verbose)
         return uninstalled_pathset
 
-    def _get_archive_name(self, path, parentdir, rootdir):
-        # type: (str, str, str) -> str
-
-        def _clean_zip_name(name, prefix):
-            # type: (str, str) -> str
-            assert name.startswith(prefix + os.path.sep), (
-                f"name {name!r} doesn't start with prefix {prefix!r}"
-            )
-            name = name[len(prefix) + 1:]
-            name = name.replace(os.path.sep, '/')
+    def _get_archive_name(self, path: str, parentdir: str, rootdir: str) -> str:
+        def _clean_zip_name(name: str, prefix: str) -> str:
+            assert name.startswith(
+                prefix + os.path.sep
+            ), f"name {name!r} doesn't start with prefix {prefix!r}"
+            name = name[len(prefix) + 1 :]
+            name = name.replace(os.path.sep, "/")
             return name
 
         path = os.path.join(parentdir, path)
         name = _clean_zip_name(path, rootdir)
-        return self.name + '/' + name
+        return self.name + "/" + name
 
-    def archive(self, build_dir):
-        # type: (Optional[str]) -> None
+    def archive(self, build_dir: Optional[str]) -> None:
         """Saves archive to provided build_dir.
 
         Used for saving downloaded VCS requirements as part of `pip download`.
@@ -685,70 +710,73 @@ class InstallRequirement:
             return
 
         create_archive = True
-        archive_name = '{}-{}.zip'.format(self.name, self.metadata["version"])
+        archive_name = "{}-{}.zip".format(self.name, self.metadata["version"])
         archive_path = os.path.join(build_dir, archive_name)
 
         if os.path.exists(archive_path):
             response = ask_path_exists(
-                'The file {} exists. (i)gnore, (w)ipe, '
-                '(b)ackup, (a)bort '.format(
-                    display_path(archive_path)),
-                ('i', 'w', 'b', 'a'))
-            if response == 'i':
+                "The file {} exists. (i)gnore, (w)ipe, "
+                "(b)ackup, (a)bort ".format(display_path(archive_path)),
+                ("i", "w", "b", "a"),
+            )
+            if response == "i":
                 create_archive = False
-            elif response == 'w':
-                logger.warning('Deleting %s', display_path(archive_path))
+            elif response == "w":
+                logger.warning("Deleting %s", display_path(archive_path))
                 os.remove(archive_path)
-            elif response == 'b':
+            elif response == "b":
                 dest_file = backup_dir(archive_path)
                 logger.warning(
-                    'Backing up %s to %s',
+                    "Backing up %s to %s",
                     display_path(archive_path),
                     display_path(dest_file),
                 )
                 shutil.move(archive_path, dest_file)
-            elif response == 'a':
+            elif response == "a":
                 sys.exit(-1)
 
         if not create_archive:
             return
 
         zip_output = zipfile.ZipFile(
-            archive_path, 'w', zipfile.ZIP_DEFLATED, allowZip64=True,
+            archive_path,
+            "w",
+            zipfile.ZIP_DEFLATED,
+            allowZip64=True,
         )
         with zip_output:
-            dir = os.path.normcase(
-                os.path.abspath(self.unpacked_source_directory)
-            )
+            dir = os.path.normcase(os.path.abspath(self.unpacked_source_directory))
             for dirpath, dirnames, filenames in os.walk(dir):
                 for dirname in dirnames:
                     dir_arcname = self._get_archive_name(
-                        dirname, parentdir=dirpath, rootdir=dir,
+                        dirname,
+                        parentdir=dirpath,
+                        rootdir=dir,
                     )
-                    zipdir = zipfile.ZipInfo(dir_arcname + '/')
+                    zipdir = zipfile.ZipInfo(dir_arcname + "/")
                     zipdir.external_attr = 0x1ED << 16  # 0o755
-                    zip_output.writestr(zipdir, '')
+                    zip_output.writestr(zipdir, "")
                 for filename in filenames:
                     file_arcname = self._get_archive_name(
-                        filename, parentdir=dirpath, rootdir=dir,
+                        filename,
+                        parentdir=dirpath,
+                        rootdir=dir,
                     )
                     filename = os.path.join(dirpath, filename)
                     zip_output.write(filename, file_arcname)
 
-        logger.info('Saved %s', display_path(archive_path))
+        logger.info("Saved %s", display_path(archive_path))
 
     def install(
         self,
-        install_options,  # type: List[str]
-        global_options=None,  # type: Optional[Sequence[str]]
-        root=None,  # type: Optional[str]
-        home=None,  # type: Optional[str]
-        prefix=None,  # type: Optional[str]
-        warn_script_location=True,  # type: bool
-        use_user_site=False,  # type: bool
-        pycompile=True  # type: bool
-    ):
-        # type: (...) -> None
+        global_options: Optional[Sequence[str]] = None,
+        root: Optional[str] = None,
+        home: Optional[str] = None,
+        prefix: Optional[str] = None,
+        warn_script_location: bool = True,
+        use_user_site: bool = False,
+        pycompile: bool = True,
+    ) -> None:
         scheme = get_scheme(
             self.name,
             user=use_user_site,
@@ -758,11 +786,9 @@ class InstallRequirement:
             prefix=prefix,
         )
 
-        global_options = global_options if global_options is not None else []
-        if self.editable:
+        if self.editable and not self.is_wheel:
             install_editable_legacy(
-                install_options,
-                global_options,
+                global_options=global_options if global_options is not None else [],
                 prefix=prefix,
                 home=home,
                 use_user_site=use_user_site,
@@ -775,80 +801,23 @@ class InstallRequirement:
             self.install_succeeded = True
             return
 
-        if self.is_wheel:
-            assert self.local_file_path
-            direct_url = None
-            if self.original_link:
-                direct_url = direct_url_from_link(
-                    self.original_link,
-                    self.source_dir,
-                    self.original_link_is_in_wheel_cache,
-                )
-            install_wheel(
-                self.name,
-                self.local_file_path,
-                scheme=scheme,
-                req_description=str(self.req),
-                pycompile=pycompile,
-                warn_script_location=warn_script_location,
-                direct_url=direct_url,
-                requested=self.user_supplied,
-            )
-            self.install_succeeded = True
-            return
-
-        # TODO: Why don't we do this for editable installs?
-
-        # Extend the list of global and install options passed on to
-        # the setup.py call with the ones from the requirements file.
-        # Options specified in requirements file override those
-        # specified on the command line, since the last option given
-        # to setup.py is the one that is used.
-        global_options = list(global_options) + self.global_options
-        install_options = list(install_options) + self.install_options
-
-        try:
-            success = install_legacy(
-                install_options=install_options,
-                global_options=global_options,
-                root=root,
-                home=home,
-                prefix=prefix,
-                use_user_site=use_user_site,
-                pycompile=pycompile,
-                scheme=scheme,
-                setup_py_path=self.setup_py_path,
-                isolated=self.isolated,
-                req_name=self.name,
-                build_env=self.build_env,
-                unpacked_source_directory=self.unpacked_source_directory,
-                req_description=str(self.req),
-            )
-        except LegacyInstallFailure as exc:
-            self.install_succeeded = False
-            six.reraise(*exc.parent)
-        except Exception:
-            self.install_succeeded = True
-            raise
-
-        self.install_succeeded = success
-
-        if success and self.legacy_install_reason == 8368:
-            deprecated(
-                reason=(
-                    "{} was installed using the legacy 'setup.py install' "
-                    "method, because a wheel could not be built for it.".
-                    format(self.name)
-                ),
-                replacement="to fix the wheel build issue reported above",
-                gone_in=None,
-                issue=8368,
-            )
+        assert self.is_wheel
+        assert self.local_file_path
 
+        install_wheel(
+            self.name,
+            self.local_file_path,
+            scheme=scheme,
+            req_description=str(self.req),
+            pycompile=pycompile,
+            warn_script_location=warn_script_location,
+            direct_url=self.download_info if self.is_direct else None,
+            requested=self.user_supplied,
+        )
+        self.install_succeeded = True
 
-def check_invalid_constraint_type(req):
-    # type: (InstallRequirement) -> str
 
+def check_invalid_constraint_type(req: InstallRequirement) -> str:
     # Check for unsupported forms
     problem = ""
     if not req.name:
@@ -867,12 +836,39 @@ def check_invalid_constraint_type(req):
                 "undocumented. The new implementation of the resolver no "
                 "longer supports these forms."
             ),
-            replacement=(
-                "replacing the constraint with a requirement."
-            ),
+            replacement="replacing the constraint with a requirement",
             # No plan yet for when the new resolver becomes default
             gone_in=None,
-            issue=8210
+            issue=8210,
         )
 
     return problem
+
+
+def _has_option(options: Values, reqs: List[InstallRequirement], option: str) -> bool:
+    if getattr(options, option, None):
+        return True
+    for req in reqs:
+        if getattr(req, option, None):
+            return True
+    return False
+
+
+def check_legacy_setup_py_options(
+    options: Values,
+    reqs: List[InstallRequirement],
+) -> None:
+    has_build_options = _has_option(options, reqs, "build_options")
+    has_global_options = _has_option(options, reqs, "global_options")
+    if has_build_options or has_global_options:
+        deprecated(
+            reason="--build-option and --global-option are deprecated.",
+            issue=11859,
+            replacement="to use --config-settings",
+            gone_in="23.3",
+        )
+        logger.warning(
+            "Implying --no-binary=:all: due to the presence of "
+            "--build-option / --global-option. "
+        )
+        options.format_control.disallow_binaries()
diff --git a/env/Lib/site-packages/pip/_internal/req/req_set.py b/env/Lib/site-packages/pip/_internal/req/req_set.py
index 59c58435..cff67601 100644
--- a/env/Lib/site-packages/pip/_internal/req/req_set.py
+++ b/env/Lib/site-packages/pip/_internal/req/req_set.py
@@ -1,191 +1,65 @@
 import logging
 from collections import OrderedDict
-from typing import Dict, Iterable, List, Optional, Tuple
+from typing import Dict, List
 
+from pip._vendor.packaging.specifiers import LegacySpecifier
 from pip._vendor.packaging.utils import canonicalize_name
+from pip._vendor.packaging.version import LegacyVersion
 
-from pip._internal.exceptions import InstallationError
-from pip._internal.models.wheel import Wheel
 from pip._internal.req.req_install import InstallRequirement
-from pip._internal.utils import compatibility_tags
+from pip._internal.utils.deprecation import deprecated
 
 logger = logging.getLogger(__name__)
 
 
 class RequirementSet:
+    def __init__(self, check_supported_wheels: bool = True) -> None:
+        """Create a RequirementSet."""
 
-    def __init__(self, check_supported_wheels=True):
-        # type: (bool) -> None
-        """Create a RequirementSet.
-        """
-
-        self.requirements = OrderedDict()  # type: Dict[str, InstallRequirement]
+        self.requirements: Dict[str, InstallRequirement] = OrderedDict()
         self.check_supported_wheels = check_supported_wheels
 
-        self.unnamed_requirements = []  # type: List[InstallRequirement]
+        self.unnamed_requirements: List[InstallRequirement] = []
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         requirements = sorted(
             (req for req in self.requirements.values() if not req.comes_from),
             key=lambda req: canonicalize_name(req.name or ""),
         )
-        return ' '.join(str(req.req) for req in requirements)
+        return " ".join(str(req.req) for req in requirements)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         requirements = sorted(
             self.requirements.values(),
             key=lambda req: canonicalize_name(req.name or ""),
         )
 
-        format_string = '<{classname} object; {count} requirement(s): {reqs}>'
+        format_string = "<{classname} object; {count} requirement(s): {reqs}>"
         return format_string.format(
             classname=self.__class__.__name__,
             count=len(requirements),
-            reqs=', '.join(str(req.req) for req in requirements),
+            reqs=", ".join(str(req.req) for req in requirements),
         )
 
-    def add_unnamed_requirement(self, install_req):
-        # type: (InstallRequirement) -> None
+    def add_unnamed_requirement(self, install_req: InstallRequirement) -> None:
         assert not install_req.name
         self.unnamed_requirements.append(install_req)
 
-    def add_named_requirement(self, install_req):
-        # type: (InstallRequirement) -> None
+    def add_named_requirement(self, install_req: InstallRequirement) -> None:
         assert install_req.name
 
         project_name = canonicalize_name(install_req.name)
         self.requirements[project_name] = install_req
 
-    def add_requirement(
-        self,
-        install_req,  # type: InstallRequirement
-        parent_req_name=None,  # type: Optional[str]
-        extras_requested=None  # type: Optional[Iterable[str]]
-    ):
-        # type: (...) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]]
-        """Add install_req as a requirement to install.
-
-        :param parent_req_name: The name of the requirement that needed this
-            added. The name is used because when multiple unnamed requirements
-            resolve to the same name, we could otherwise end up with dependency
-            links that point outside the Requirements set. parent_req must
-            already be added. Note that None implies that this is a user
-            supplied requirement, vs an inferred one.
-        :param extras_requested: an iterable of extras used to evaluate the
-            environment markers.
-        :return: Additional requirements to scan. That is either [] if
-            the requirement is not applicable, or [install_req] if the
-            requirement is applicable and has just been added.
-        """
-        # If the markers do not match, ignore this requirement.
-        if not install_req.match_markers(extras_requested):
-            logger.info(
-                "Ignoring %s: markers '%s' don't match your environment",
-                install_req.name, install_req.markers,
-            )
-            return [], None
-
-        # If the wheel is not supported, raise an error.
-        # Should check this after filtering out based on environment markers to
-        # allow specifying different wheels based on the environment/OS, in a
-        # single requirements file.
-        if install_req.link and install_req.link.is_wheel:
-            wheel = Wheel(install_req.link.filename)
-            tags = compatibility_tags.get_supported()
-            if (self.check_supported_wheels and not wheel.supported(tags)):
-                raise InstallationError(
-                    "{} is not a supported wheel on this platform.".format(
-                        wheel.filename)
-                )
-
-        # This next bit is really a sanity check.
-        assert not install_req.user_supplied or parent_req_name is None, (
-            "a user supplied req shouldn't have a parent"
-        )
-
-        # Unnamed requirements are scanned again and the requirement won't be
-        # added as a dependency until after scanning.
-        if not install_req.name:
-            self.add_unnamed_requirement(install_req)
-            return [install_req], None
-
-        try:
-            existing_req = self.get_requirement(
-                install_req.name)  # type: Optional[InstallRequirement]
-        except KeyError:
-            existing_req = None
-
-        has_conflicting_requirement = (
-            parent_req_name is None and
-            existing_req and
-            not existing_req.constraint and
-            existing_req.extras == install_req.extras and
-            existing_req.req and
-            install_req.req and
-            existing_req.req.specifier != install_req.req.specifier
-        )
-        if has_conflicting_requirement:
-            raise InstallationError(
-                "Double requirement given: {} (already in {}, name={!r})"
-                .format(install_req, existing_req, install_req.name)
-            )
-
-        # When no existing requirement exists, add the requirement as a
-        # dependency and it will be scanned again after.
-        if not existing_req:
-            self.add_named_requirement(install_req)
-            # We'd want to rescan this requirement later
-            return [install_req], install_req
-
-        # Assume there's no need to scan, and that we've already
-        # encountered this for scanning.
-        if install_req.constraint or not existing_req.constraint:
-            return [], existing_req
-
-        does_not_satisfy_constraint = (
-            install_req.link and
-            not (
-                existing_req.link and
-                install_req.link.path == existing_req.link.path
-            )
-        )
-        if does_not_satisfy_constraint:
-            raise InstallationError(
-                "Could not satisfy constraints for '{}': "
-                "installation from path or url cannot be "
-                "constrained to a version".format(install_req.name)
-            )
-        # If we're now installing a constraint, mark the existing
-        # object for real installation.
-        existing_req.constraint = False
-        # If we're now installing a user supplied requirement,
-        # mark the existing object as such.
-        if install_req.user_supplied:
-            existing_req.user_supplied = True
-        existing_req.extras = tuple(sorted(
-            set(existing_req.extras) | set(install_req.extras)
-        ))
-        logger.debug(
-            "Setting %s extras to: %s",
-            existing_req, existing_req.extras,
-        )
-        # Return the existing requirement for addition to the parent and
-        # scanning again.
-        return [existing_req], existing_req
-
-    def has_requirement(self, name):
-        # type: (str) -> bool
+    def has_requirement(self, name: str) -> bool:
         project_name = canonicalize_name(name)
 
         return (
-            project_name in self.requirements and
-            not self.requirements[project_name].constraint
+            project_name in self.requirements
+            and not self.requirements[project_name].constraint
         )
 
-    def get_requirement(self, name):
-        # type: (str) -> InstallRequirement
+    def get_requirement(self, name: str) -> InstallRequirement:
         project_name = canonicalize_name(name)
 
         if project_name in self.requirements:
@@ -194,6 +68,52 @@ class RequirementSet:
         raise KeyError(f"No project with the name {name!r}")
 
     @property
-    def all_requirements(self):
-        # type: () -> List[InstallRequirement]
+    def all_requirements(self) -> List[InstallRequirement]:
         return self.unnamed_requirements + list(self.requirements.values())
+
+    @property
+    def requirements_to_install(self) -> List[InstallRequirement]:
+        """Return the list of requirements that need to be installed.
+
+        TODO remove this property together with the legacy resolver, since the new
+             resolver only returns requirements that need to be installed.
+        """
+        return [
+            install_req
+            for install_req in self.all_requirements
+            if not install_req.constraint and not install_req.satisfied_by
+        ]
+
+    def warn_legacy_versions_and_specifiers(self) -> None:
+        for req in self.requirements_to_install:
+            version = req.get_dist().version
+            if isinstance(version, LegacyVersion):
+                deprecated(
+                    reason=(
+                        f"pip has selected the non standard version {version} "
+                        f"of {req}. In the future this version will be "
+                        f"ignored as it isn't standard compliant."
+                    ),
+                    replacement=(
+                        "set or update constraints to select another version "
+                        "or contact the package author to fix the version number"
+                    ),
+                    issue=12063,
+                    gone_in="23.3",
+                )
+            for dep in req.get_dist().iter_dependencies():
+                if any(isinstance(spec, LegacySpecifier) for spec in dep.specifier):
+                    deprecated(
+                        reason=(
+                            f"pip has selected {req} {version} which has non "
+                            f"standard dependency specifier {dep}. "
+                            f"In the future this version of {req} will be "
+                            f"ignored as it isn't standard compliant."
+                        ),
+                        replacement=(
+                            "set or update constraints to select another version "
+                            "or contact the package author to fix the version number"
+                        ),
+                        issue=12063,
+                        gone_in="23.3",
+                    )
diff --git a/env/Lib/site-packages/pip/_internal/req/req_tracker.py b/env/Lib/site-packages/pip/_internal/req/req_tracker.py
deleted file mode 100644
index 542e0d94..00000000
--- a/env/Lib/site-packages/pip/_internal/req/req_tracker.py
+++ /dev/null
@@ -1,140 +0,0 @@
-import contextlib
-import hashlib
-import logging
-import os
-from types import TracebackType
-from typing import Dict, Iterator, Optional, Set, Type, Union
-
-from pip._internal.models.link import Link
-from pip._internal.req.req_install import InstallRequirement
-from pip._internal.utils.temp_dir import TempDirectory
-
-logger = logging.getLogger(__name__)
-
-
-@contextlib.contextmanager
-def update_env_context_manager(**changes):
-    # type: (str) -> Iterator[None]
-    target = os.environ
-
-    # Save values from the target and change them.
-    non_existent_marker = object()
-    saved_values = {}  # type: Dict[str, Union[object, str]]
-    for name, new_value in changes.items():
-        try:
-            saved_values[name] = target[name]
-        except KeyError:
-            saved_values[name] = non_existent_marker
-        target[name] = new_value
-
-    try:
-        yield
-    finally:
-        # Restore original values in the target.
-        for name, original_value in saved_values.items():
-            if original_value is non_existent_marker:
-                del target[name]
-            else:
-                assert isinstance(original_value, str)  # for mypy
-                target[name] = original_value
-
-
-@contextlib.contextmanager
-def get_requirement_tracker():
-    # type: () -> Iterator[RequirementTracker]
-    root = os.environ.get('PIP_REQ_TRACKER')
-    with contextlib.ExitStack() as ctx:
-        if root is None:
-            root = ctx.enter_context(
-                TempDirectory(kind='req-tracker')
-            ).path
-            ctx.enter_context(update_env_context_manager(PIP_REQ_TRACKER=root))
-            logger.debug("Initialized build tracking at %s", root)
-
-        with RequirementTracker(root) as tracker:
-            yield tracker
-
-
-class RequirementTracker:
-
-    def __init__(self, root):
-        # type: (str) -> None
-        self._root = root
-        self._entries = set()  # type: Set[InstallRequirement]
-        logger.debug("Created build tracker: %s", self._root)
-
-    def __enter__(self):
-        # type: () -> RequirementTracker
-        logger.debug("Entered build tracker: %s", self._root)
-        return self
-
-    def __exit__(
-        self,
-        exc_type,  # type: Optional[Type[BaseException]]
-        exc_val,  # type: Optional[BaseException]
-        exc_tb  # type: Optional[TracebackType]
-    ):
-        # type: (...) -> None
-        self.cleanup()
-
-    def _entry_path(self, link):
-        # type: (Link) -> str
-        hashed = hashlib.sha224(link.url_without_fragment.encode()).hexdigest()
-        return os.path.join(self._root, hashed)
-
-    def add(self, req):
-        # type: (InstallRequirement) -> None
-        """Add an InstallRequirement to build tracking.
-        """
-
-        assert req.link
-        # Get the file to write information about this requirement.
-        entry_path = self._entry_path(req.link)
-
-        # Try reading from the file. If it exists and can be read from, a build
-        # is already in progress, so a LookupError is raised.
-        try:
-            with open(entry_path) as fp:
-                contents = fp.read()
-        except FileNotFoundError:
-            pass
-        else:
-            message = '{} is already being built: {}'.format(
-                req.link, contents)
-            raise LookupError(message)
-
-        # If we're here, req should really not be building already.
-        assert req not in self._entries
-
-        # Start tracking this requirement.
-        with open(entry_path, 'w', encoding="utf-8") as fp:
-            fp.write(str(req))
-        self._entries.add(req)
-
-        logger.debug('Added %s to build tracker %r', req, self._root)
-
-    def remove(self, req):
-        # type: (InstallRequirement) -> None
-        """Remove an InstallRequirement from build tracking.
-        """
-
-        assert req.link
-        # Delete the created file and the corresponding entries.
-        os.unlink(self._entry_path(req.link))
-        self._entries.remove(req)
-
-        logger.debug('Removed %s from build tracker %r', req, self._root)
-
-    def cleanup(self):
-        # type: () -> None
-        for req in set(self._entries):
-            self.remove(req)
-
-        logger.debug("Removed build tracker: %r", self._root)
-
-    @contextlib.contextmanager
-    def track(self, req):
-        # type: (InstallRequirement) -> Iterator[None]
-        self.add(req)
-        yield
-        self.remove(req)
diff --git a/env/Lib/site-packages/pip/_internal/req/req_uninstall.py b/env/Lib/site-packages/pip/_internal/req/req_uninstall.py
index b7223417..ad5178e7 100644
--- a/env/Lib/site-packages/pip/_internal/req/req_uninstall.py
+++ b/env/Lib/site-packages/pip/_internal/req/req_uninstall.py
@@ -1,72 +1,58 @@
-import csv
 import functools
-import logging
 import os
 import sys
 import sysconfig
 from importlib.util import cache_from_source
-from typing import Any, Callable, Dict, Iterable, Iterator, List, Optional, Set, Tuple
-
-from pip._vendor import pkg_resources
-from pip._vendor.pkg_resources import Distribution
+from typing import Any, Callable, Dict, Generator, Iterable, List, Optional, Set, Tuple
 
 from pip._internal.exceptions import UninstallationError
 from pip._internal.locations import get_bin_prefix, get_bin_user
+from pip._internal.metadata import BaseDistribution
 from pip._internal.utils.compat import WINDOWS
-from pip._internal.utils.logging import indent_log
-from pip._internal.utils.misc import (
-    ask,
-    dist_in_usersite,
-    dist_is_local,
-    egg_link_path,
-    is_local,
-    normalize_path,
-    renames,
-    rmtree,
-)
+from pip._internal.utils.egg_link import egg_link_path_from_location
+from pip._internal.utils.logging import getLogger, indent_log
+from pip._internal.utils.misc import ask, normalize_path, renames, rmtree
 from pip._internal.utils.temp_dir import AdjacentTempDirectory, TempDirectory
+from pip._internal.utils.virtualenv import running_under_virtualenv
 
-logger = logging.getLogger(__name__)
+logger = getLogger(__name__)
 
 
-def _script_names(dist, script_name, is_gui):
-    # type: (Distribution, str, bool) -> List[str]
+def _script_names(
+    bin_dir: str, script_name: str, is_gui: bool
+) -> Generator[str, None, None]:
     """Create the fully qualified name of the files created by
     {console,gui}_scripts for the given ``dist``.
     Returns the list of file names
     """
-    if dist_in_usersite(dist):
-        bin_dir = get_bin_user()
-    else:
-        bin_dir = get_bin_prefix()
     exe_name = os.path.join(bin_dir, script_name)
-    paths_to_remove = [exe_name]
-    if WINDOWS:
-        paths_to_remove.append(exe_name + '.exe')
-        paths_to_remove.append(exe_name + '.exe.manifest')
-        if is_gui:
-            paths_to_remove.append(exe_name + '-script.pyw')
-        else:
-            paths_to_remove.append(exe_name + '-script.py')
-    return paths_to_remove
+    yield exe_name
+    if not WINDOWS:
+        return
+    yield f"{exe_name}.exe"
+    yield f"{exe_name}.exe.manifest"
+    if is_gui:
+        yield f"{exe_name}-script.pyw"
+    else:
+        yield f"{exe_name}-script.py"
 
 
-def _unique(fn):
-    # type: (Callable[..., Iterator[Any]]) -> Callable[..., Iterator[Any]]
+def _unique(
+    fn: Callable[..., Generator[Any, None, None]]
+) -> Callable[..., Generator[Any, None, None]]:
     @functools.wraps(fn)
-    def unique(*args, **kw):
-        # type: (Any, Any) -> Iterator[Any]
-        seen = set()  # type: Set[Any]
+    def unique(*args: Any, **kw: Any) -> Generator[Any, None, None]:
+        seen: Set[Any] = set()
         for item in fn(*args, **kw):
             if item not in seen:
                 seen.add(item)
                 yield item
+
     return unique
 
 
 @_unique
-def uninstallation_paths(dist):
-    # type: (Distribution) -> Iterator[str]
+def uninstallation_paths(dist: BaseDistribution) -> Generator[str, None, None]:
     """
     Yield all the uninstallation paths for dist based on RECORD-without-.py[co]
 
@@ -74,33 +60,53 @@ def uninstallation_paths(dist):
     the .pyc and .pyo in the same directory.
 
     UninstallPathSet.add() takes care of the __pycache__ .py[co].
+
+    If RECORD is not found, raises UninstallationError,
+    with possible information from the INSTALLER file.
+
+    https://packaging.python.org/specifications/recording-installed-packages/
     """
-    r = csv.reader(dist.get_metadata_lines('RECORD'))
-    for row in r:
-        path = os.path.join(dist.location, row[0])
+    location = dist.location
+    assert location is not None, "not installed"
+
+    entries = dist.iter_declared_entries()
+    if entries is None:
+        msg = "Cannot uninstall {dist}, RECORD file not found.".format(dist=dist)
+        installer = dist.installer
+        if not installer or installer == "pip":
+            dep = "{}=={}".format(dist.raw_name, dist.version)
+            msg += (
+                " You might be able to recover from this via: "
+                "'pip install --force-reinstall --no-deps {}'.".format(dep)
+            )
+        else:
+            msg += " Hint: The package was installed by {}.".format(installer)
+        raise UninstallationError(msg)
+
+    for entry in entries:
+        path = os.path.join(location, entry)
         yield path
-        if path.endswith('.py'):
+        if path.endswith(".py"):
             dn, fn = os.path.split(path)
             base = fn[:-3]
-            path = os.path.join(dn, base + '.pyc')
+            path = os.path.join(dn, base + ".pyc")
             yield path
-            path = os.path.join(dn, base + '.pyo')
+            path = os.path.join(dn, base + ".pyo")
             yield path
 
 
-def compact(paths):
-    # type: (Iterable[str]) -> Set[str]
+def compact(paths: Iterable[str]) -> Set[str]:
     """Compact a path set to contain the minimal number of paths
     necessary to contain all paths in the set. If /a/path/ and
     /a/path/to/a/file.txt are both in the set, leave only the
     shorter path."""
 
     sep = os.path.sep
-    short_paths = set()  # type: Set[str]
+    short_paths: Set[str] = set()
     for path in sorted(paths, key=len):
         should_skip = any(
-            path.startswith(shortpath.rstrip("*")) and
-            path[len(shortpath.rstrip("*").rstrip(sep))] == sep
+            path.startswith(shortpath.rstrip("*"))
+            and path[len(shortpath.rstrip("*").rstrip(sep))] == sep
             for shortpath in short_paths
         )
         if not should_skip:
@@ -108,8 +114,7 @@ def compact(paths):
     return short_paths
 
 
-def compress_for_rename(paths):
-    # type: (Iterable[str]) -> Set[str]
+def compress_for_rename(paths: Iterable[str]) -> Set[str]:
     """Returns a set containing the paths that need to be renamed.
 
     This set may include directories when the original sequence of paths
@@ -118,25 +123,21 @@ def compress_for_rename(paths):
     case_map = {os.path.normcase(p): p for p in paths}
     remaining = set(case_map)
     unchecked = sorted({os.path.split(p)[0] for p in case_map.values()}, key=len)
-    wildcards = set()  # type: Set[str]
+    wildcards: Set[str] = set()
 
-    def norm_join(*a):
-        # type: (str) -> str
+    def norm_join(*a: str) -> str:
         return os.path.normcase(os.path.join(*a))
 
     for root in unchecked:
-        if any(os.path.normcase(root).startswith(w)
-               for w in wildcards):
+        if any(os.path.normcase(root).startswith(w) for w in wildcards):
             # This directory has already been handled.
             continue
 
-        all_files = set()  # type: Set[str]
-        all_subdirs = set()  # type: Set[str]
+        all_files: Set[str] = set()
+        all_subdirs: Set[str] = set()
         for dirname, subdirs, files in os.walk(root):
-            all_subdirs.update(norm_join(root, dirname, d)
-                               for d in subdirs)
-            all_files.update(norm_join(root, dirname, f)
-                             for f in files)
+            all_subdirs.update(norm_join(root, dirname, d) for d in subdirs)
+            all_files.update(norm_join(root, dirname, f) for f in files)
         # If all the files we found are in our remaining set of files to
         # remove, then remove them from the latter set and add a wildcard
         # for the directory.
@@ -147,8 +148,7 @@ def compress_for_rename(paths):
     return set(map(case_map.__getitem__, remaining)) | wildcards
 
 
-def compress_for_output_listing(paths):
-    # type: (Iterable[str]) -> Tuple[Set[str], Set[str]]
+def compress_for_output_listing(paths: Iterable[str]) -> Tuple[Set[str], Set[str]]:
     """Returns a tuple of 2 sets of which paths to display to user
 
     The first set contains paths that would be deleted. Files of a package
@@ -186,14 +186,14 @@ def compress_for_output_listing(paths):
                     continue
 
                 file_ = os.path.join(dirpath, fname)
-                if (os.path.isfile(file_) and
-                        os.path.normcase(file_) not in _normcased_files):
+                if (
+                    os.path.isfile(file_)
+                    and os.path.normcase(file_) not in _normcased_files
+                ):
                     # We are skipping this file. Add it to the set.
                     will_skip.add(file_)
 
-    will_remove = files | {
-        os.path.join(folder, "*") for folder in folders
-    }
+    will_remove = files | {os.path.join(folder, "*") for folder in folders}
 
     return will_remove, will_skip
 
@@ -201,32 +201,30 @@ def compress_for_output_listing(paths):
 class StashedUninstallPathSet:
     """A set of file rename operations to stash files while
     tentatively uninstalling them."""
-    def __init__(self):
-        # type: () -> None
+
+    def __init__(self) -> None:
         # Mapping from source file root to [Adjacent]TempDirectory
         # for files under that directory.
-        self._save_dirs = {}  # type: Dict[str, TempDirectory]
+        self._save_dirs: Dict[str, TempDirectory] = {}
         # (old path, new path) tuples for each move that may need
         # to be undone.
-        self._moves = []  # type: List[Tuple[str, str]]
+        self._moves: List[Tuple[str, str]] = []
 
-    def _get_directory_stash(self, path):
-        # type: (str) -> str
+    def _get_directory_stash(self, path: str) -> str:
         """Stashes a directory.
 
         Directories are stashed adjacent to their original location if
         possible, or else moved/copied into the user's temp dir."""
 
         try:
-            save_dir = AdjacentTempDirectory(path)  # type: TempDirectory
+            save_dir: TempDirectory = AdjacentTempDirectory(path)
         except OSError:
             save_dir = TempDirectory(kind="uninstall")
         self._save_dirs[os.path.normcase(path)] = save_dir
 
         return save_dir.path
 
-    def _get_file_stash(self, path):
-        # type: (str) -> str
+    def _get_file_stash(self, path: str) -> str:
         """Stashes a file.
 
         If no root has been provided, one will be created for the directory
@@ -245,7 +243,7 @@ class StashedUninstallPathSet:
         else:
             # Did not find any suitable root
             head = os.path.dirname(path)
-            save_dir = TempDirectory(kind='uninstall')
+            save_dir = TempDirectory(kind="uninstall")
             self._save_dirs[head] = save_dir
 
         relpath = os.path.relpath(path, head)
@@ -253,8 +251,7 @@ class StashedUninstallPathSet:
             return os.path.join(save_dir.path, relpath)
         return save_dir.path
 
-    def stash(self, path):
-        # type: (str) -> str
+    def stash(self, path: str) -> str:
         """Stashes the directory or file and returns its new location.
         Handle symlinks as files to avoid modifying the symlink targets.
         """
@@ -265,7 +262,7 @@ class StashedUninstallPathSet:
             new_path = self._get_file_stash(path)
 
         self._moves.append((path, new_path))
-        if (path_is_dir and os.path.isdir(new_path)):
+        if path_is_dir and os.path.isdir(new_path):
             # If we're moving a directory, we need to
             # remove the destination first or else it will be
             # moved to inside the existing directory.
@@ -275,23 +272,21 @@ class StashedUninstallPathSet:
         renames(path, new_path)
         return new_path
 
-    def commit(self):
-        # type: () -> None
+    def commit(self) -> None:
         """Commits the uninstall by removing stashed files."""
         for _, save_dir in self._save_dirs.items():
             save_dir.cleanup()
         self._moves = []
         self._save_dirs = {}
 
-    def rollback(self):
-        # type: () -> None
+    def rollback(self) -> None:
         """Undoes the uninstall by moving stashed files back."""
         for p in self._moves:
             logger.info("Moving to %s\n from %s", *p)
 
         for new_path, path in self._moves:
             try:
-                logger.debug('Replacing %s from %s', new_path, path)
+                logger.debug("Replacing %s from %s", new_path, path)
                 if os.path.isfile(new_path) or os.path.islink(new_path):
                     os.unlink(new_path)
                 elif os.path.isdir(new_path):
@@ -304,100 +299,97 @@ class StashedUninstallPathSet:
         self.commit()
 
     @property
-    def can_rollback(self):
-        # type: () -> bool
+    def can_rollback(self) -> bool:
         return bool(self._moves)
 
 
 class UninstallPathSet:
     """A set of file paths to be removed in the uninstallation of a
     requirement."""
-    def __init__(self, dist):
-        # type: (Distribution) -> None
-        self.paths = set()  # type: Set[str]
-        self._refuse = set()  # type: Set[str]
-        self.pth = {}  # type: Dict[str, UninstallPthEntries]
-        self.dist = dist
+
+    def __init__(self, dist: BaseDistribution) -> None:
+        self._paths: Set[str] = set()
+        self._refuse: Set[str] = set()
+        self._pth: Dict[str, UninstallPthEntries] = {}
+        self._dist = dist
         self._moved_paths = StashedUninstallPathSet()
+        # Create local cache of normalize_path results. Creating an UninstallPathSet
+        # can result in hundreds/thousands of redundant calls to normalize_path with
+        # the same args, which hurts performance.
+        self._normalize_path_cached = functools.lru_cache()(normalize_path)
 
-    def _permitted(self, path):
-        # type: (str) -> bool
+    def _permitted(self, path: str) -> bool:
         """
         Return True if the given path is one we are permitted to
         remove/modify, False otherwise.
 
         """
-        return is_local(path)
+        # aka is_local, but caching normalized sys.prefix
+        if not running_under_virtualenv():
+            return True
+        return path.startswith(self._normalize_path_cached(sys.prefix))
 
-    def add(self, path):
-        # type: (str) -> None
+    def add(self, path: str) -> None:
         head, tail = os.path.split(path)
 
         # we normalize the head to resolve parent directory symlinks, but not
         # the tail, since we only want to uninstall symlinks, not their targets
-        path = os.path.join(normalize_path(head), os.path.normcase(tail))
+        path = os.path.join(self._normalize_path_cached(head), os.path.normcase(tail))
 
         if not os.path.exists(path):
             return
         if self._permitted(path):
-            self.paths.add(path)
+            self._paths.add(path)
         else:
             self._refuse.add(path)
 
         # __pycache__ files can show up after 'installed-files.txt' is created,
         # due to imports
-        if os.path.splitext(path)[1] == '.py':
+        if os.path.splitext(path)[1] == ".py":
             self.add(cache_from_source(path))
 
-    def add_pth(self, pth_file, entry):
-        # type: (str, str) -> None
-        pth_file = normalize_path(pth_file)
+    def add_pth(self, pth_file: str, entry: str) -> None:
+        pth_file = self._normalize_path_cached(pth_file)
         if self._permitted(pth_file):
-            if pth_file not in self.pth:
-                self.pth[pth_file] = UninstallPthEntries(pth_file)
-            self.pth[pth_file].add(entry)
+            if pth_file not in self._pth:
+                self._pth[pth_file] = UninstallPthEntries(pth_file)
+            self._pth[pth_file].add(entry)
         else:
             self._refuse.add(pth_file)
 
-    def remove(self, auto_confirm=False, verbose=False):
-        # type: (bool, bool) -> None
-        """Remove paths in ``self.paths`` with confirmation (unless
+    def remove(self, auto_confirm: bool = False, verbose: bool = False) -> None:
+        """Remove paths in ``self._paths`` with confirmation (unless
         ``auto_confirm`` is True)."""
 
-        if not self.paths:
+        if not self._paths:
             logger.info(
                 "Can't uninstall '%s'. No files were found to uninstall.",
-                self.dist.project_name,
+                self._dist.raw_name,
             )
             return
 
-        dist_name_version = (
-            self.dist.project_name + "-" + self.dist.version
-        )
-        logger.info('Uninstalling %s:', dist_name_version)
+        dist_name_version = f"{self._dist.raw_name}-{self._dist.version}"
+        logger.info("Uninstalling %s:", dist_name_version)
 
         with indent_log():
             if auto_confirm or self._allowed_to_proceed(verbose):
                 moved = self._moved_paths
 
-                for_rename = compress_for_rename(self.paths)
+                for_rename = compress_for_rename(self._paths)
 
                 for path in sorted(compact(for_rename)):
                     moved.stash(path)
-                    logger.debug('Removing file or directory %s', path)
+                    logger.verbose("Removing file or directory %s", path)
 
-                for pth in self.pth.values():
+                for pth in self._pth.values():
                     pth.remove()
 
-                logger.info('Successfully uninstalled %s', dist_name_version)
+                logger.info("Successfully uninstalled %s", dist_name_version)
 
-    def _allowed_to_proceed(self, verbose):
-        # type: (bool) -> bool
-        """Display which files would be deleted and prompt for confirmation
-        """
+    def _allowed_to_proceed(self, verbose: bool) -> bool:
+        """Display which files would be deleted and prompt for confirmation"""
 
-        def _display(msg, paths):
-            # type: (str, Iterable[str]) -> None
+        def _display(msg: str, paths: Iterable[str]) -> None:
             if not paths:
                 return
 
@@ -407,182 +399,206 @@ class UninstallPathSet:
                     logger.info(path)
 
         if not verbose:
-            will_remove, will_skip = compress_for_output_listing(self.paths)
+            will_remove, will_skip = compress_for_output_listing(self._paths)
         else:
             # In verbose mode, display all the files that are going to be
             # deleted.
-            will_remove = set(self.paths)
+            will_remove = set(self._paths)
             will_skip = set()
 
-        _display('Would remove:', will_remove)
-        _display('Would not remove (might be manually added):', will_skip)
-        _display('Would not remove (outside of prefix):', self._refuse)
+        _display("Would remove:", will_remove)
+        _display("Would not remove (might be manually added):", will_skip)
+        _display("Would not remove (outside of prefix):", self._refuse)
         if verbose:
-            _display('Will actually move:', compress_for_rename(self.paths))
+            _display("Will actually move:", compress_for_rename(self._paths))
 
-        return ask('Proceed (y/n)? ', ('y', 'n')) == 'y'
+        return ask("Proceed (Y/n)? ", ("y", "n", "")) != "n"
 
-    def rollback(self):
-        # type: () -> None
+    def rollback(self) -> None:
         """Rollback the changes previously made by remove()."""
         if not self._moved_paths.can_rollback:
             logger.error(
                 "Can't roll back %s; was not uninstalled",
-                self.dist.project_name,
+                self._dist.raw_name,
             )
             return
-        logger.info('Rolling back uninstall of %s', self.dist.project_name)
+        logger.info("Rolling back uninstall of %s", self._dist.raw_name)
         self._moved_paths.rollback()
-        for pth in self.pth.values():
+        for pth in self._pth.values():
             pth.rollback()
 
-    def commit(self):
-        # type: () -> None
+    def commit(self) -> None:
         """Remove temporary save dir: rollback will no longer be possible."""
         self._moved_paths.commit()
 
     @classmethod
-    def from_dist(cls, dist):
-        # type: (Distribution) -> UninstallPathSet
-        dist_path = normalize_path(dist.location)
-        if not dist_is_local(dist):
+    def from_dist(cls, dist: BaseDistribution) -> "UninstallPathSet":
+        dist_location = dist.location
+        info_location = dist.info_location
+        if dist_location is None:
+            logger.info(
+                "Not uninstalling %s since it is not installed",
+                dist.canonical_name,
+            )
+            return cls(dist)
+
+        normalized_dist_location = normalize_path(dist_location)
+        if not dist.local:
             logger.info(
                 "Not uninstalling %s at %s, outside environment %s",
-                dist.key,
-                dist_path,
+                dist.canonical_name,
+                normalized_dist_location,
                 sys.prefix,
             )
             return cls(dist)
 
-        if dist_path in {p for p in {sysconfig.get_path("stdlib"),
-                                     sysconfig.get_path("platstdlib")}
-                         if p}:
+        if normalized_dist_location in {
+            p
+            for p in {sysconfig.get_path("stdlib"), sysconfig.get_path("platstdlib")}
+            if p
+        }:
             logger.info(
                 "Not uninstalling %s at %s, as it is in the standard library.",
-                dist.key,
-                dist_path,
+                dist.canonical_name,
+                normalized_dist_location,
             )
             return cls(dist)
 
         paths_to_remove = cls(dist)
-        develop_egg_link = egg_link_path(dist)
-        develop_egg_link_egg_info = '{}.egg-info'.format(
-            pkg_resources.to_filename(dist.project_name))
-        egg_info_exists = dist.egg_info and os.path.exists(dist.egg_info)
-        # Special case for distutils installed package
-        distutils_egg_info = getattr(dist._provider, 'path', None)
+        develop_egg_link = egg_link_path_from_location(dist.raw_name)
+
+        # Distribution is installed with metadata in a "flat" .egg-info
+        # directory. This means it is not a modern .dist-info installation, an
+        # egg, or legacy editable.
+        setuptools_flat_installation = (
+            dist.installed_with_setuptools_egg_info
+            and info_location is not None
+            and os.path.exists(info_location)
+            # If dist is editable and the location points to a ``.egg-info``,
+            # we are in fact in the legacy editable case.
+            and not info_location.endswith(f"{dist.setuptools_filename}.egg-info")
+        )
 
         # Uninstall cases order do matter as in the case of 2 installs of the
         # same package, pip needs to uninstall the currently detected version
-        if (egg_info_exists and dist.egg_info.endswith('.egg-info') and
-                not dist.egg_info.endswith(develop_egg_link_egg_info)):
-            # if dist.egg_info.endswith(develop_egg_link_egg_info), we
-            # are in fact in the develop_egg_link case
-            paths_to_remove.add(dist.egg_info)
-            if dist.has_metadata('installed-files.txt'):
-                for installed_file in dist.get_metadata(
-                        'installed-files.txt').splitlines():
-                    path = os.path.normpath(
-                        os.path.join(dist.egg_info, installed_file)
-                    )
-                    paths_to_remove.add(path)
+        if setuptools_flat_installation:
+            if info_location is not None:
+                paths_to_remove.add(info_location)
+            installed_files = dist.iter_declared_entries()
+            if installed_files is not None:
+                for installed_file in installed_files:
+                    paths_to_remove.add(os.path.join(dist_location, installed_file))
             # FIXME: need a test for this elif block
             # occurs with --single-version-externally-managed/--record outside
             # of pip
-            elif dist.has_metadata('top_level.txt'):
-                if dist.has_metadata('namespace_packages.txt'):
-                    namespaces = dist.get_metadata('namespace_packages.txt')
-                else:
+            elif dist.is_file("top_level.txt"):
+                try:
+                    namespace_packages = dist.read_text("namespace_packages.txt")
+                except FileNotFoundError:
                     namespaces = []
+                else:
+                    namespaces = namespace_packages.splitlines(keepends=False)
                 for top_level_pkg in [
-                        p for p
-                        in dist.get_metadata('top_level.txt').splitlines()
-                        if p and p not in namespaces]:
-                    path = os.path.join(dist.location, top_level_pkg)
+                    p
+                    for p in dist.read_text("top_level.txt").splitlines()
+                    if p and p not in namespaces
+                ]:
+                    path = os.path.join(dist_location, top_level_pkg)
                     paths_to_remove.add(path)
-                    paths_to_remove.add(path + '.py')
-                    paths_to_remove.add(path + '.pyc')
-                    paths_to_remove.add(path + '.pyo')
+                    paths_to_remove.add(f"{path}.py")
+                    paths_to_remove.add(f"{path}.pyc")
+                    paths_to_remove.add(f"{path}.pyo")
 
-        elif distutils_egg_info:
+        elif dist.installed_by_distutils:
             raise UninstallationError(
                 "Cannot uninstall {!r}. It is a distutils installed project "
                 "and thus we cannot accurately determine which files belong "
                 "to it which would lead to only a partial uninstall.".format(
-                    dist.project_name,
+                    dist.raw_name,
                 )
             )
 
-        elif dist.location.endswith('.egg'):
+        elif dist.installed_as_egg:
             # package installed by easy_install
             # We cannot match on dist.egg_name because it can slightly vary
             # i.e. setuptools-0.6c11-py2.6.egg vs setuptools-0.6rc11-py2.6.egg
-            paths_to_remove.add(dist.location)
-            easy_install_egg = os.path.split(dist.location)[1]
-            easy_install_pth = os.path.join(os.path.dirname(dist.location),
-                                            'easy-install.pth')
-            paths_to_remove.add_pth(easy_install_pth, './' + easy_install_egg)
+            paths_to_remove.add(dist_location)
+            easy_install_egg = os.path.split(dist_location)[1]
+            easy_install_pth = os.path.join(
+                os.path.dirname(dist_location),
+                "easy-install.pth",
+            )
+            paths_to_remove.add_pth(easy_install_pth, "./" + easy_install_egg)
 
-        elif egg_info_exists and dist.egg_info.endswith('.dist-info'):
+        elif dist.installed_with_dist_info:
             for path in uninstallation_paths(dist):
                 paths_to_remove.add(path)
 
         elif develop_egg_link:
-            # develop egg
+            # PEP 660 modern editable is handled in the ``.dist-info`` case
+            # above, so this only covers the setuptools-style editable.
             with open(develop_egg_link) as fh:
                 link_pointer = os.path.normcase(fh.readline().strip())
-            assert (link_pointer == dist.location), (
-                'Egg-link {} does not match installed location of {} '
-                '(at {})'.format(
-                    link_pointer, dist.project_name, dist.location)
+                normalized_link_pointer = paths_to_remove._normalize_path_cached(
+                    link_pointer
+                )
+            assert os.path.samefile(
+                normalized_link_pointer, normalized_dist_location
+            ), (
+                f"Egg-link {develop_egg_link} (to {link_pointer}) does not match "
+                f"installed location of {dist.raw_name} (at {dist_location})"
             )
             paths_to_remove.add(develop_egg_link)
-            easy_install_pth = os.path.join(os.path.dirname(develop_egg_link),
-                                            'easy-install.pth')
-            paths_to_remove.add_pth(easy_install_pth, dist.location)
+            easy_install_pth = os.path.join(
+                os.path.dirname(develop_egg_link), "easy-install.pth"
+            )
+            paths_to_remove.add_pth(easy_install_pth, dist_location)
 
         else:
             logger.debug(
-                'Not sure how to uninstall: %s - Check: %s',
-                dist, dist.location,
+                "Not sure how to uninstall: %s - Check: %s",
+                dist,
+                dist_location,
             )
 
+        if dist.in_usersite:
+            bin_dir = get_bin_user()
+        else:
+            bin_dir = get_bin_prefix()
+
         # find distutils scripts= scripts
-        if dist.has_metadata('scripts') and dist.metadata_isdir('scripts'):
-            for script in dist.metadata_listdir('scripts'):
-                if dist_in_usersite(dist):
-                    bin_dir = get_bin_user()
-                else:
-                    bin_dir = get_bin_prefix()
+        try:
+            for script in dist.iter_distutils_script_names():
                 paths_to_remove.add(os.path.join(bin_dir, script))
                 if WINDOWS:
-                    paths_to_remove.add(os.path.join(bin_dir, script) + '.bat')
-
-        # find console_scripts
-        _scripts_to_remove = []
-        console_scripts = dist.get_entry_map(group='console_scripts')
-        for name in console_scripts.keys():
-            _scripts_to_remove.extend(_script_names(dist, name, False))
-        # find gui_scripts
-        gui_scripts = dist.get_entry_map(group='gui_scripts')
-        for name in gui_scripts.keys():
-            _scripts_to_remove.extend(_script_names(dist, name, True))
-
-        for s in _scripts_to_remove:
+                    paths_to_remove.add(os.path.join(bin_dir, f"{script}.bat"))
+        except (FileNotFoundError, NotADirectoryError):
+            pass
+
+        # find console_scripts and gui_scripts
+        def iter_scripts_to_remove(
+            dist: BaseDistribution,
+            bin_dir: str,
+        ) -> Generator[str, None, None]:
+            for entry_point in dist.iter_entry_points():
+                if entry_point.group == "console_scripts":
+                    yield from _script_names(bin_dir, entry_point.name, False)
+                elif entry_point.group == "gui_scripts":
+                    yield from _script_names(bin_dir, entry_point.name, True)
+
+        for s in iter_scripts_to_remove(dist, bin_dir):
             paths_to_remove.add(s)
 
         return paths_to_remove
 
 
 class UninstallPthEntries:
-    def __init__(self, pth_file):
-        # type: (str) -> None
+    def __init__(self, pth_file: str) -> None:
         self.file = pth_file
-        self.entries = set()  # type: Set[str]
-        self._saved_lines = None  # type: Optional[List[bytes]]
+        self.entries: Set[str] = set()
+        self._saved_lines: Optional[List[bytes]] = None
 
-    def add(self, entry):
-        # type: (str) -> None
+    def add(self, entry: str) -> None:
         entry = os.path.normcase(entry)
         # On Windows, os.path.normcase converts the entry to use
         # backslashes.  This is correct for entries that describe absolute
@@ -594,47 +610,41 @@ class UninstallPthEntries:
         # have more than "\\sever\share". Valid examples: "\\server\share\" or
         # "\\server\share\folder".
         if WINDOWS and not os.path.splitdrive(entry)[0]:
-            entry = entry.replace('\\', '/')
+            entry = entry.replace("\\", "/")
         self.entries.add(entry)
 
-    def remove(self):
-        # type: () -> None
-        logger.debug('Removing pth entries from %s:', self.file)
+    def remove(self) -> None:
+        logger.verbose("Removing pth entries from %s:", self.file)
 
         # If the file doesn't exist, log a warning and return
         if not os.path.isfile(self.file):
-            logger.warning(
-                "Cannot remove entries from nonexistent file %s", self.file
-            )
+            logger.warning("Cannot remove entries from nonexistent file %s", self.file)
             return
-        with open(self.file, 'rb') as fh:
+        with open(self.file, "rb") as fh:
             # windows uses '\r\n' with py3k, but uses '\n' with py2.x
             lines = fh.readlines()
             self._saved_lines = lines
-        if any(b'\r\n' in line for line in lines):
-            endline = '\r\n'
+        if any(b"\r\n" in line for line in lines):
+            endline = "\r\n"
         else:
-            endline = '\n'
+            endline = "\n"
         # handle missing trailing newline
         if lines and not lines[-1].endswith(endline.encode("utf-8")):
             lines[-1] = lines[-1] + endline.encode("utf-8")
         for entry in self.entries:
             try:
-                logger.debug('Removing entry: %s', entry)
+                logger.verbose("Removing entry: %s", entry)
                 lines.remove((entry + endline).encode("utf-8"))
             except ValueError:
                 pass
-        with open(self.file, 'wb') as fh:
+        with open(self.file, "wb") as fh:
             fh.writelines(lines)
 
-    def rollback(self):
-        # type: () -> bool
+    def rollback(self) -> bool:
         if self._saved_lines is None:
-            logger.error(
-                'Cannot roll back changes to %s, none were made', self.file
-            )
+            logger.error("Cannot roll back changes to %s, none were made", self.file)
             return False
-        logger.debug('Rolling %s back to previous state', self.file)
-        with open(self.file, 'wb') as fh:
+        logger.debug("Rolling %s back to previous state", self.file)
+        with open(self.file, "wb") as fh:
             fh.writelines(self._saved_lines)
         return True
diff --git a/env/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 67cb3e32a8e33f9b46accd2807416b3b289d311a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 224
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<YIU}X
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP
u%1g}AFG?-W&nYd*%+J%0kI&4@EQycTE2zB1VUwGmQks)$2XfwLkT(G63_REX

diff --git a/env/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index 2c19d10d12f8efa3a2b94e9a2a325a3488bcb2c6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 967
zcmYe~<>g{vU|^UdaWK`GiGkrUh=Yuo85kHG7#J9ey%-o6QW#Pga~N_NqZo6UqL>&#
ze5M@cT$U&nFq=7tHJ2@ljgcXhF_k@)C7mgiC5=gvA&SGDA%!J{wS^&twV5f3Gleaf
zL6iL@$QDheTO7`bIXQ_*IjOf;d@_qmG#PIRdFB<DB<AD<r52WE7NzE<=7B`{khsCA
zCCMP|$e0P{P#FdWhE#?q#uSDqrWD2$rWS@M<`m`>mKKI6mK4@t22HkGJWh$lsX?j5
z`8j2&Madv9!b}3O85tNDoIzd&g-i)UGeZ+&3PUi%N=CnxjJJgS@=H8(3v$5DN=<Ps
zD#|a?WWL2xoSKt%i?b*{za+jWwXpb>SaL>ca&~-iX+c4LQAuh_e0fG{YEJP=h9X`D
z28Lga&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW
z!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g
z`tg~0C8<Sui8=a3AkUVTWaj7TCnXlA>J?PpVh4+rrGk7}3<^C4rYaHSfYF00NCrzn
zLkPsi5kN)k3=9lK91IK$noLC?Q$bb~#uulSfc*?1_!t-%Zi%I*mc(a5VmT4ysQCP%
zl++@S9Ly!kC@#US-cOVD7Ds%1USe))eEco0`1suXl+qj!n<qZLurx6TB2&Z<a+e^8
z0EIoo9bgv7!Xh>X1_n-0bh9upFmNz(uz*GUG`ViEl~fjF=A{>b{9FV|8BwwYnFV_A
zP}M6+Ed*hhSBgL;L`h;-0}2LKkms3;ONwquVW#nbqWrSVl++@y^+=9{yYv=^4a9?X
Spa>`i1+)MY4<iqg05br5FZxRW

diff --git a/env/Lib/site-packages/pip/_internal/resolution/base.py b/env/Lib/site-packages/pip/_internal/resolution/base.py
index 1be0cb27..42dade18 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/base.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/base.py
@@ -1,16 +1,20 @@
-from typing import Callable, List
+from typing import Callable, List, Optional
 
 from pip._internal.req.req_install import InstallRequirement
 from pip._internal.req.req_set import RequirementSet
 
-InstallRequirementProvider = Callable[[str, InstallRequirement], InstallRequirement]
+InstallRequirementProvider = Callable[
+    [str, Optional[InstallRequirement]], InstallRequirement
+]
 
 
 class BaseResolver:
-    def resolve(self, root_reqs, check_supported_wheels):
-        # type: (List[InstallRequirement], bool) -> RequirementSet
+    def resolve(
+        self, root_reqs: List[InstallRequirement], check_supported_wheels: bool
+    ) -> RequirementSet:
         raise NotImplementedError()
 
-    def get_installation_order(self, req_set):
-        # type: (RequirementSet) -> List[InstallRequirement]
+    def get_installation_order(
+        self, req_set: RequirementSet
+    ) -> List[InstallRequirement]:
         raise NotImplementedError()
diff --git a/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index ea3a4b2153a625cdb95fd39d873f5ed338e4668a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 231
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>T$M;
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP
z%1g}AFG?-W&nYd*%+J%$Nli~ouGEi@&&<m#iI3MSsJz8tlbfGXnv-e=a^+``Zve3Z
BKZ5`O

diff --git a/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/legacy/__pycache__/resolver.cpython-39.pyc
deleted file mode 100644
index 5af41912d9c3ae6880175189d955c46494e0023b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py b/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py
index 17de7f09..b17b7e45 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/legacy/resolver.py
@@ -20,7 +20,7 @@ from itertools import chain
 from typing import DefaultDict, Iterable, List, Optional, Set, Tuple
 
 from pip._vendor.packaging import specifiers
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.packaging.requirements import Requirement
 
 from pip._internal.cache import WheelCache
 from pip._internal.exceptions import (
@@ -28,10 +28,14 @@ from pip._internal.exceptions import (
     DistributionNotFound,
     HashError,
     HashErrors,
+    InstallationError,
+    NoneMetadataError,
     UnsupportedPythonVersion,
 )
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata import BaseDistribution
 from pip._internal.models.link import Link
+from pip._internal.models.wheel import Wheel
 from pip._internal.operations.prepare import RequirementPreparer
 from pip._internal.req.req_install import (
     InstallRequirement,
@@ -39,10 +43,12 @@ from pip._internal.req.req_install import (
 )
 from pip._internal.req.req_set import RequirementSet
 from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider
+from pip._internal.utils import compatibility_tags
 from pip._internal.utils.compatibility_tags import get_supported
+from pip._internal.utils.direct_url_helpers import direct_url_from_link
 from pip._internal.utils.logging import indent_log
-from pip._internal.utils.misc import dist_in_usersite, normalize_version_info
-from pip._internal.utils.packaging import check_requires_python, get_requires_python
+from pip._internal.utils.misc import normalize_version_info
+from pip._internal.utils.packaging import check_requires_python
 
 logger = logging.getLogger(__name__)
 
@@ -50,11 +56,10 @@ DiscoveredDependencies = DefaultDict[str, List[InstallRequirement]]
 
 
 def _check_dist_requires_python(
-    dist,  # type: Distribution
-    version_info,  # type: Tuple[int, int, int]
-    ignore_requires_python=False,  # type: bool
-):
-    # type: (...) -> None
+    dist: BaseDistribution,
+    version_info: Tuple[int, int, int],
+    ignore_requires_python: bool = False,
+) -> None:
     """
     Check whether the given Python version is compatible with a distribution's
     "Requires-Python" value.
@@ -67,14 +72,21 @@ def _check_dist_requires_python(
     :raises UnsupportedPythonVersion: When the given Python version isn't
         compatible.
     """
-    requires_python = get_requires_python(dist)
+    # This idiosyncratically converts the SpecifierSet to str and let
+    # check_requires_python then parse it again into SpecifierSet. But this
+    # is the legacy resolver so I'm just not going to bother refactoring.
+    try:
+        requires_python = str(dist.requires_python)
+    except FileNotFoundError as e:
+        raise NoneMetadataError(dist, str(e))
     try:
         is_compatible = check_requires_python(
-            requires_python, version_info=version_info
+            requires_python,
+            version_info=version_info,
         )
     except specifiers.InvalidSpecifier as exc:
         logger.warning(
-            "Package %r has an invalid Requires-Python: %s", dist.project_name, exc
+            "Package %r has an invalid Requires-Python: %s", dist.raw_name, exc
         )
         return
 
@@ -84,8 +96,8 @@ def _check_dist_requires_python(
     version = ".".join(map(str, version_info))
     if ignore_requires_python:
         logger.debug(
-            "Ignoring failed Requires-Python check for package %r: " "%s not in %r",
-            dist.project_name,
+            "Ignoring failed Requires-Python check for package %r: %s not in %r",
+            dist.raw_name,
             version,
             requires_python,
         )
@@ -93,7 +105,7 @@ def _check_dist_requires_python(
 
     raise UnsupportedPythonVersion(
         "Package {!r} requires a different Python: {} not in {!r}".format(
-            dist.project_name, version, requires_python
+            dist.raw_name, version, requires_python
         )
     )
 
@@ -107,19 +119,18 @@ class Resolver(BaseResolver):
 
     def __init__(
         self,
-        preparer,  # type: RequirementPreparer
-        finder,  # type: PackageFinder
-        wheel_cache,  # type: Optional[WheelCache]
-        make_install_req,  # type: InstallRequirementProvider
-        use_user_site,  # type: bool
-        ignore_dependencies,  # type: bool
-        ignore_installed,  # type: bool
-        ignore_requires_python,  # type: bool
-        force_reinstall,  # type: bool
-        upgrade_strategy,  # type: str
-        py_version_info=None,  # type: Optional[Tuple[int, ...]]
-    ):
-        # type: (...) -> None
+        preparer: RequirementPreparer,
+        finder: PackageFinder,
+        wheel_cache: Optional[WheelCache],
+        make_install_req: InstallRequirementProvider,
+        use_user_site: bool,
+        ignore_dependencies: bool,
+        ignore_installed: bool,
+        ignore_requires_python: bool,
+        force_reinstall: bool,
+        upgrade_strategy: str,
+        py_version_info: Optional[Tuple[int, ...]] = None,
+    ) -> None:
         super().__init__()
         assert upgrade_strategy in self._allowed_strategies
 
@@ -142,12 +153,11 @@ class Resolver(BaseResolver):
         self.use_user_site = use_user_site
         self._make_install_req = make_install_req
 
-        self._discovered_dependencies = defaultdict(
-            list
-        )  # type: DiscoveredDependencies
+        self._discovered_dependencies: DiscoveredDependencies = defaultdict(list)
 
-    def resolve(self, root_reqs, check_supported_wheels):
-        # type: (List[InstallRequirement], bool) -> RequirementSet
+    def resolve(
+        self, root_reqs: List[InstallRequirement], check_supported_wheels: bool
+    ) -> RequirementSet:
         """Resolve what operations need to be done
 
         As a side-effect of this method, the packages (and their dependencies)
@@ -162,13 +172,13 @@ class Resolver(BaseResolver):
         for req in root_reqs:
             if req.constraint:
                 check_invalid_constraint_type(req)
-            requirement_set.add_requirement(req)
+            self._add_requirement_to_set(requirement_set, req)
 
         # Actually prepare the files, and collect any exceptions. Most hash
         # exceptions cannot be checked ahead of time, because
         # _populate_link() needs to be called before we can make decisions
         # based on link type.
-        discovered_reqs = []  # type: List[InstallRequirement]
+        discovered_reqs: List[InstallRequirement] = []
         hash_errors = HashErrors()
         for req in chain(requirement_set.all_requirements, discovered_reqs):
             try:
@@ -182,8 +192,125 @@ class Resolver(BaseResolver):
 
         return requirement_set
 
-    def _is_upgrade_allowed(self, req):
-        # type: (InstallRequirement) -> bool
+    def _add_requirement_to_set(
+        self,
+        requirement_set: RequirementSet,
+        install_req: InstallRequirement,
+        parent_req_name: Optional[str] = None,
+        extras_requested: Optional[Iterable[str]] = None,
+    ) -> Tuple[List[InstallRequirement], Optional[InstallRequirement]]:
+        """Add install_req as a requirement to install.
+
+        :param parent_req_name: The name of the requirement that needed this
+            added. The name is used because when multiple unnamed requirements
+            resolve to the same name, we could otherwise end up with dependency
+            links that point outside the Requirements set. parent_req must
+            already be added. Note that None implies that this is a user
+            supplied requirement, vs an inferred one.
+        :param extras_requested: an iterable of extras used to evaluate the
+            environment markers.
+        :return: Additional requirements to scan. That is either [] if
+            the requirement is not applicable, or [install_req] if the
+            requirement is applicable and has just been added.
+        """
+        # If the markers do not match, ignore this requirement.
+        if not install_req.match_markers(extras_requested):
+            logger.info(
+                "Ignoring %s: markers '%s' don't match your environment",
+                install_req.name,
+                install_req.markers,
+            )
+            return [], None
+
+        # If the wheel is not supported, raise an error.
+        # Should check this after filtering out based on environment markers to
+        # allow specifying different wheels based on the environment/OS, in a
+        # single requirements file.
+        if install_req.link and install_req.link.is_wheel:
+            wheel = Wheel(install_req.link.filename)
+            tags = compatibility_tags.get_supported()
+            if requirement_set.check_supported_wheels and not wheel.supported(tags):
+                raise InstallationError(
+                    "{} is not a supported wheel on this platform.".format(
+                        wheel.filename
+                    )
+                )
+
+        # This next bit is really a sanity check.
+        assert (
+            not install_req.user_supplied or parent_req_name is None
+        ), "a user supplied req shouldn't have a parent"
+
+        # Unnamed requirements are scanned again and the requirement won't be
+        # added as a dependency until after scanning.
+        if not install_req.name:
+            requirement_set.add_unnamed_requirement(install_req)
+            return [install_req], None
+
+        try:
+            existing_req: Optional[
+                InstallRequirement
+            ] = requirement_set.get_requirement(install_req.name)
+        except KeyError:
+            existing_req = None
+
+        has_conflicting_requirement = (
+            parent_req_name is None
+            and existing_req
+            and not existing_req.constraint
+            and existing_req.extras == install_req.extras
+            and existing_req.req
+            and install_req.req
+            and existing_req.req.specifier != install_req.req.specifier
+        )
+        if has_conflicting_requirement:
+            raise InstallationError(
+                "Double requirement given: {} (already in {}, name={!r})".format(
+                    install_req, existing_req, install_req.name
+                )
+            )
+
+        # When no existing requirement exists, add the requirement as a
+        # dependency and it will be scanned again after.
+        if not existing_req:
+            requirement_set.add_named_requirement(install_req)
+            # We'd want to rescan this requirement later
+            return [install_req], install_req
+
+        # Assume there's no need to scan, and that we've already
+        # encountered this for scanning.
+        if install_req.constraint or not existing_req.constraint:
+            return [], existing_req
+
+        does_not_satisfy_constraint = install_req.link and not (
+            existing_req.link and install_req.link.path == existing_req.link.path
+        )
+        if does_not_satisfy_constraint:
+            raise InstallationError(
+                "Could not satisfy constraints for '{}': "
+                "installation from path or url cannot be "
+                "constrained to a version".format(install_req.name)
+            )
+        # If we're now installing a constraint, mark the existing
+        # object for real installation.
+        existing_req.constraint = False
+        # If we're now installing a user supplied requirement,
+        # mark the existing object as such.
+        if install_req.user_supplied:
+            existing_req.user_supplied = True
+        existing_req.extras = tuple(
+            sorted(set(existing_req.extras) | set(install_req.extras))
+        )
+        logger.debug(
+            "Setting %s extras to: %s",
+            existing_req,
+            existing_req.extras,
+        )
+        # Return the existing requirement for addition to the parent and
+        # scanning again.
+        return [existing_req], existing_req
+
+    def _is_upgrade_allowed(self, req: InstallRequirement) -> bool:
         if self.upgrade_strategy == "to-satisfy-only":
             return False
         elif self.upgrade_strategy == "eager":
@@ -192,19 +319,19 @@ class Resolver(BaseResolver):
             assert self.upgrade_strategy == "only-if-needed"
             return req.user_supplied or req.constraint
 
-    def _set_req_to_reinstall(self, req):
-        # type: (InstallRequirement) -> None
+    def _set_req_to_reinstall(self, req: InstallRequirement) -> None:
         """
         Set a requirement to be installed.
         """
         # Don't uninstall the conflict if doing a user install and the
         # conflict is not a user install.
-        if not self.use_user_site or dist_in_usersite(req.satisfied_by):
+        if not self.use_user_site or req.satisfied_by.in_usersite:
             req.should_reinstall = True
         req.satisfied_by = None
 
-    def _check_skip_installed(self, req_to_install):
-        # type: (InstallRequirement) -> Optional[str]
+    def _check_skip_installed(
+        self, req_to_install: InstallRequirement
+    ) -> Optional[str]:
         """Check if req_to_install should be skipped.
 
         This will check if the req is installed, and whether we should upgrade
@@ -256,8 +383,7 @@ class Resolver(BaseResolver):
         self._set_req_to_reinstall(req_to_install)
         return None
 
-    def _find_requirement_link(self, req):
-        # type: (InstallRequirement) -> Optional[Link]
+    def _find_requirement_link(self, req: InstallRequirement) -> Optional[Link]:
         upgrade = self._is_upgrade_allowed(req)
         best_candidate = self.finder.find_requirement(req, upgrade)
         if not best_candidate:
@@ -279,8 +405,7 @@ class Resolver(BaseResolver):
 
         return link
 
-    def _populate_link(self, req):
-        # type: (InstallRequirement) -> None
+    def _populate_link(self, req: InstallRequirement) -> None:
         """Ensure that if a link can be found for this, that it is found.
 
         Note that req.link may still be None - if the requirement is already
@@ -306,11 +431,18 @@ class Resolver(BaseResolver):
         if cache_entry is not None:
             logger.debug("Using cached wheel link: %s", cache_entry.link)
             if req.link is req.original_link and cache_entry.persistent:
-                req.original_link_is_in_wheel_cache = True
+                req.cached_wheel_source_link = req.link
+            if cache_entry.origin is not None:
+                req.download_info = cache_entry.origin
+            else:
+                # Legacy cache entry that does not have origin.json.
+                # download_info may miss the archive_info.hashes field.
+                req.download_info = direct_url_from_link(
+                    req.link, link_is_in_wheel_cache=cache_entry.persistent
+                )
             req.link = cache_entry.link
 
-    def _get_dist_for(self, req):
-        # type: (InstallRequirement) -> Distribution
+    def _get_dist_for(self, req: InstallRequirement) -> BaseDistribution:
         """Takes a InstallRequirement and returns a single AbstractDist \
         representing a prepared variant of the same.
         """
@@ -351,17 +483,16 @@ class Resolver(BaseResolver):
                 self._set_req_to_reinstall(req)
             else:
                 logger.info(
-                    "Requirement already satisfied (use --upgrade to upgrade):" " %s",
+                    "Requirement already satisfied (use --upgrade to upgrade): %s",
                     req,
                 )
         return dist
 
     def _resolve_one(
         self,
-        requirement_set,  # type: RequirementSet
-        req_to_install,  # type: InstallRequirement
-    ):
-        # type: (...) -> List[InstallRequirement]
+        requirement_set: RequirementSet,
+        req_to_install: InstallRequirement,
+    ) -> List[InstallRequirement]:
         """Prepare a single requirements file.
 
         :return: A list of additional InstallRequirements to also install.
@@ -384,16 +515,16 @@ class Resolver(BaseResolver):
             ignore_requires_python=self.ignore_requires_python,
         )
 
-        more_reqs = []  # type: List[InstallRequirement]
+        more_reqs: List[InstallRequirement] = []
 
-        def add_req(subreq, extras_requested):
-            # type: (Distribution, Iterable[str]) -> None
-            sub_install_req = self._make_install_req(
-                str(subreq),
-                req_to_install,
-            )
+        def add_req(subreq: Requirement, extras_requested: Iterable[str]) -> None:
+            # This idiosyncratically converts the Requirement to str and let
+            # make_install_req then parse it again into Requirement. But this is
+            # the legacy resolver so I'm just not going to bother refactoring.
+            sub_install_req = self._make_install_req(str(subreq), req_to_install)
             parent_req_name = req_to_install.name
-            to_scan_again, add_to_parent = requirement_set.add_requirement(
+            to_scan_again, add_to_parent = self._add_requirement_to_set(
+                requirement_set,
                 sub_install_req,
                 parent_req_name=parent_req_name,
                 extras_requested=extras_requested,
@@ -410,7 +541,9 @@ class Resolver(BaseResolver):
                 # 'unnamed' requirements can only come from being directly
                 # provided by the user.
                 assert req_to_install.user_supplied
-                requirement_set.add_requirement(req_to_install, parent_req_name=None)
+                self._add_requirement_to_set(
+                    requirement_set, req_to_install, parent_req_name=None
+                )
 
             if not self.ignore_dependencies:
                 if req_to_install.extras:
@@ -419,21 +552,27 @@ class Resolver(BaseResolver):
                         ",".join(req_to_install.extras),
                     )
                 missing_requested = sorted(
-                    set(req_to_install.extras) - set(dist.extras)
+                    set(req_to_install.extras) - set(dist.iter_provided_extras())
                 )
                 for missing in missing_requested:
-                    logger.warning("%s does not provide the extra '%s'", dist, missing)
+                    logger.warning(
+                        "%s %s does not provide the extra '%s'",
+                        dist.raw_name,
+                        dist.version,
+                        missing,
+                    )
 
                 available_requested = sorted(
-                    set(dist.extras) & set(req_to_install.extras)
+                    set(dist.iter_provided_extras()) & set(req_to_install.extras)
                 )
-                for subreq in dist.requires(available_requested):
+                for subreq in dist.iter_dependencies(available_requested):
                     add_req(subreq, extras_requested=available_requested)
 
         return more_reqs
 
-    def get_installation_order(self, req_set):
-        # type: (RequirementSet) -> List[InstallRequirement]
+    def get_installation_order(
+        self, req_set: RequirementSet
+    ) -> List[InstallRequirement]:
         """Create the installation order.
 
         The installation order is topological - requirements are installed
@@ -444,10 +583,9 @@ class Resolver(BaseResolver):
         # installs the user specified things in the order given, except when
         # dependencies must come earlier to achieve topological order.
         order = []
-        ordered_reqs = set()  # type: Set[InstallRequirement]
+        ordered_reqs: Set[InstallRequirement] = set()
 
-        def schedule(req):
-            # type: (InstallRequirement) -> None
+        def schedule(req: InstallRequirement) -> None:
             if req.satisfied_by or req in ordered_reqs:
                 return
             if req.constraint:
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 234cf5ef336c279d8578e747367caa788f389a39..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 235
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<n&4~|
z6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&5
z8l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d=EnOBlp
zl$V&JUzA#$pHo_rnV$z?mZj!oCh5n=XXa&=#K-FuRNmsS$<0qG%}KQbx%4y0M*zqy
BK}i4r

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index 2195c90242273d4b1b46da84ea848ec6fda777fd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6337
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
z%0A$78Ks2@>T|+_R}<38zr|agS&|VCZ69KcD+p$mq!z`eq!y&+rKIL1XQmd<hP#HT
zN*c-Y=<28y1h>RN)h;y7VeSNtGtNhHh$6xvI8>A19K7{3xbj?#WVIB+YRrn67p-D0
z@&l!AM4b%EIYpp8dJ(931&-~aP>_-^5P`Fv2Gu-;AUA*pI}r6Ww37qs=zuY(-uBa!
zxy4peS&*5RUIa=NMW8CX2-GSo0u2-tfhyQ2g@Viiz4)@!yp;SRJ;<nKW?s4;e4wnj
z2s9LROB%bf(vr-a;v&$<26%imN*22^Xi-oE8qF`_2DMTo!3tsHqI$XcDXBTddZ2!B
z5h&e)TM1Cp;EIY;3-yXp3t@!-WY|Fp)gZ8g^dMt<Md0x>et0DLfSY)?1mFVDQEu>X
zCb(Y+Zs~wq8{irq(r5)YO~3@Gp>&JG2GV)81GRIDr5G3(WSDpu1sDaG1Q>Z3d6+~P
Od6+pk_zd`zIoJVliNCb~

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/candidates.cpython-39.pyc
deleted file mode 100644
index 48b07213ca5ccb95f524a0b1d971c0c3ec33c051..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 17917
zcmYe~<>g{vU|^UdaWIv`kAdMah=Yt-7#J8F7#J9e*Dx|Lq%fo~<}gG-XvQeU6owS0
z9Hw06DCS(2D3)B-DAruID7IYoDE3^AD2`mtD9&82C@w~jdgdJNT%IVNT;3>NFrOud
zFPA@xKUW}10L*925zG~e5(2Z?as+dQqeQ@L_8ie%u_!Sxn<Ga&S0YLxS29Wx%;(IJ
z%9W0i&XtLh0rR<XWOL=B<iKq19Qj;@D1}_bC`B-zCr2q)IZ7GK=FL&bRgF^3Rf|#s
z^Z9brb2Xwg7#ULdQv`A}bG4$ha<!whb9JJ0a&@D085vTUComRqrSPW+=IG_>N9i*%
zq%tfpNHtu@7-f{onIa^~5M`XImCBxKEXj}}JclVoBt^7^CCVg4EJeJ9A<8sGB1N)=
zA<8U8Dn+`5A<EpHAw?!dwuK=@HdU*cIm*JFAw@1lzJ(!0KGmX`Im*(VAw?lYv4tT;
z5zM!8XGl>>QEp*KQ3k8Gc4tUYNl|TKNKpmzZQL1B)Kb)27*f>1eA^VpU<OT%m!Np`
z)8x3t8xk4d8t?4k>g?_5=YEUXF|YC#r(02eRcc;vYRN4Q&yv)l#H5_mTO9rcC7Jno
zi8;4eLrM#BQg5+_=4IyR-C{{jEH2Sxx+UP5SC*KQnG#%(nw*)InOby<2hI#m1*zck
z%P-1J%*m`uP4P?2O}!<UoS2uNmzfL}iqA{TP1R()#U7SgRGgWgr^$GWwIH#m7$nBy
zl383*l$lfta)2h&El!Wb;tbcKqWq#;BEG35i7AOCiJp1M`FX{e#U-hEAiG$6GV`);
z3FKtvWf#Y%7M5m~CFX!+7;mwLXQZa)XfoZB%*-n;NzBQKFG?+pPb<pLjZaO<ECKsf
z6hkT}GY{kvAy0^&AdrzosktB{nQjTBWEPjiXBHz25X*ykHNFhupZLtYw0up*Tf*t7
zB_JD1GmBD-;|nTFGV=3YGBPkQXtLbmbWY4m$xKNsNxdZiXF|i{7B`Zex46?l=9j<&
z%`GvxB)_OqllhjUV@^?OVoD{{p{XfwgKi1BLj8vj;spg0oC^xtWVjR9ic(8Ti}I2|
zjsv9@5N2XvU|?ooU~mTIdKm@=h7yJn#uBD9=32%Q<{E|?#%87>i5iAr25>54s!|Qf
zNL45*%`3^wO;vz~ghGCrf>UB~D%@H<KTVb*B?bnDB4rSv!oa|Aiz~Aj90z&HshUhh
zsvse;q{QOXc)0uGlXDV_i&KkNG8AbtFfja@<ZKlaTAW%`9Fv-pl35hvpO@-Vlv$Rl
zpsNt-=NaZ26zmz|7_8vw=i=|@8tmy96YT2i8XV#pq+k{k5a1J&Xrh~wpPpG<l9?To
znpYO%lbIA#oLQ2pTacKXotU0l98-{4pdX)^SCU$kmzbkplv<ph15S|;W?5=ZW|BVK
zdBu7KmA3>Fi{nvU4f0$uA1El9nHZTEnf|h{axt<n7HKmuFeHOQ7bFG3pt6+*7Sb6E
z3=B1lSqw#dUJNOW&5TWqHH=w|MG7TMAi9~cmMM>|h9Qf&mZ^lL1|-H>!<fZZ!<fZh
z!<fZU!<fZc!d1hV#a+Xg#Z$wW#hb#^%bdd8%U;V|!<fZa!yM07!%)K<&tJnF%%I8Q
zS0z%Cnp=>QSdyxcS*!rd6)Tx<@q^<eCnr81Tox4H;!DrTPfA4a*)kG~Gg6CJvfbh>
zElw?pFD@-8$jMAixy6;7pPO0?&Stl`N{dtD3sMVA4b5+HWESUxECQ>@D=sNY%*-pf
z#SS%JQ{WZ{%=%l*MX80in2Sq_ZZVe@<rIm7(uyI7Fai<AAi@Mhn1T`uOG;*PNs%sy
zuLt7ufE)&QHgA4WW_o5`Vop4$fVjm1A~jix>_93xV15S+r`}@8EJ`f|Cou@21yUrH
zo0y#%4+{-=0Rl3|0F*T}KvBrV$H>OW!^8%PXGRt{WP-5%vixM@<zQrEEOJ7Rdr&%n
z$33Wm1;u?aJnl;vYZ$UXu?&hmmKw$^cx;z|<GO}13mn_9Scb%@D9m39dHE&qNG;L<
z1rf;2nmk43AhsBYumTad0=LK-BnuDQA{$WY#RLw$B72Y&C_f?vmK^rLf<>$+D8N8v
z2?G-!BQ$UzK?LLdW%*eIDsfOU2rB~v13Zu#z(r9FLlz?_Gt@9<F%`*_fP#mqnX#5R
zPpgJ8i>1h{hG{lK3MlKaWU<a>n9E$toF@PlW2#}uVuOg3u-Aa}p#&r-+m!HvvkGGt
ze+^@nKnim&a|%l@do4>1Lk&y3U=2$!gC?tA6|;haLKTy(EmE)w74d>n3{OE(epYHS
zq{uF^00omJhybOzB2aMO;saNADX<Cye*(uA2e){N6H79S(=t<2;*%;hS#Pm`>Lo~&
zxPa^eC8Z)q5DP7aa3p7t_GnP-fYLkz6Bj5sGqN#?FbUvE(rk=H9-ssb$^pn2RBeD9
zP`r$RfgzOv)If}4N@0v*PGO2-Nl{5*NnveajABh;OJQ$eh+<3ONa1W@h+<FSO5tu{
zh~h}$N#Si_h~iA;O5sc4Z((R=jN(q^N)bpA1haWkxl)8ugu!gyR4#BM3#5h*+RWmI
zHnRkv%`8DkBP&V>(zuEehBT_8L?Df+DA5#9QK))LDIQvpBGtZ5iOJbW^=jgGCI$va
z1$fD?kOY=jNUBsw%u`56z%(EsL63_|K|w(wBqOs}p(wSWD782>ucTNZQ2|=nC={g@
zmZlb$D3oWGWGIwmq$-po7Nw__fb(urYGz)#LL#J|2b+_b2Ue4sSC(0np9gA{=qM!S
zr6}a3rlu4tl;kTUr7EPQmLzASrhvtv1y^c{o&u<X201u0FCA<YcK3qnfuhvn0#Fkx
zDJNASEx$-1H@~<9RF{KXmy?>VP@Z3uZLLs}ky#8j2wXiYq*fH<7pE30Bo-7D<rfrX
zg6ot#Nb4mtKM&+KkbZDwT9#S_4Hv6|#G=Gp1yFHn1$H5brBDE>?^9q}usamfL!fZR
zu2!KuGbcx(v^W*)Xs~S{!@&Us4o^_}hc!F(z@CCStT?~4C^;2ec_6tD<aMNEpaiXC
zN>YoJ6hQ4uklQkg6`<h*a#u=bT3TvRYF-IgULhd?<j;fzh4PG4NQ{E`ps-KNFU?C)
zfJSpUr~#{xoS2-E3UL+4D1_ep(wr29g8a<95|D2|p^KzJN1;3;GY9Hpup)5!D9K0#
z`wwIi#IB;$-29SMNT6t>>ZR*JoLEp<kg1nnl&%S}+08GR9VwH8*r3V_R9F{-s^uES
z8isg=8m1bCc*Yu*8ishL8s-{?c;*_`8ish58nzmSc-9(*1#Al$Y8c|#Qy797Rx*Nm
zC9L4Ey~Puc6w<di;?p3_+*_>ipi21`YdomaaEk+0WZvS4FDObaNGwV%atGB(?6+8o
zQ*+Y5HPbC_B%{EE;4OBTaV%hC*rDxHNX-Q<AwlKdEsps3%)HE!`1p2EQ3!6kaj`KX
zV3juEGC~h#21;uh)UpN@i{RiA0=4lNvKYWs6hjsxs5%N}&}8!a#i+27sVEdwY=<#0
zFsx)O3Iegg4g?cmSF*>)7nc;p$Ik>g5)=mvOjTM$ISi}~!(E{EC)iyQ3=9k@j9Cnz
z$~B7#)XL9dX=Y4e>SYRM&}8<j5~~L1bZ}JEYE*+#tYT5ErY6%ZE`$U)3N%@7u|abF
zEzWpI^F2Nu6uh9|kB=_`*N5I9zeRxvu;0K0*n=GL@t~42K7KC9ha8|($Hc<O#>nxH
z$OwSw#_%XS0tDb~2vGAXjj5S2n4!oEl#ZBhv4EP7MR6c!;d3BJRebyskOQGnKwR2@
z=tF7Vfb_$iCI@jEsNDzZVM&#M8Z4k@3Uf0Pq_4G-$<IxbrAQs*La;MMKrE13S2BUq
z%PrRYl8n?M^u)~;AD>znAHM?RWHxY^@-Xr-R%sHIazHvU!V{FJ!3hUsTn$4O11uC7
zi+n(C!V<Sd!3+!x>p)Hb`I>>bN{<NZk+L&}8$iZ@-2e(WkQ-7MOBsqJAPwg%=4ME#
z1a_My(=RJf9SH5P7pJBufRZDuVuQBYz|{ewhA&D@ODzHwoS>eoKgd_0HXgXpDFU~&
zuz3<Bu^Hq^P{1&-aDl>Ep9qgaodC{Y7(T@n+AA4xI|Nje>;^dm6if`vRq8}I0u&|~
zmV@-81~UV$V1{HQmZAVqTbLKz(uI}UkYEE9ZAI9E4J2^@<XUjBF@uARn1T&jnqxQ`
z)NcSg8q^g}VO#(%*g!cR)Pc@oDUt!xta&UTdLgJ4$mCbWUtOzEU8|r0s>T(nYc)05
zief?04hqU5kPC}IS?v~kW^sI4W=`rYP7oPikXVv|%}=)kAjM#OT7FS{Drg+*ILL$G
z!B!?nM^WT&l`#>~f^H6mZ{bk{>ME5$2M<8?tR|CRm56^?YEe;UN-C&jQCyk?F0Vmj
zRDSs-p1B1%;PI{06!1tJR)2`X>f3narqX$kXFwJ+FjZL);R&pUpcICn$_O5BIncro
z+Sg;qVoG5wWh^oR$01WTbCD6Gl1c#;lAvxfV>3$=V+pvE4C)QmFl4cVb!328HO$$}
zMHx^X%q1Kkv1U*okqx8^JdDLsW#ycanw$-8^}<IPlPf`G1T=F($_!AG8=CAua-cBL
z^F!3!nw;RSAS7dgOASz+U*rc$NSPo4oRB~{1Y8wrvVaS2aQ3*x2Old1mjgwvAobwN
z5lnz<Na^@wkTc_Rp+lnaNN&9hiW3D;0ng0EC<5+SgS*;)SlAGJ4n~$gRd&S07;cMD
zQXr@T1Ep$kegjpdRXjBe3m6tM)G~%M<ms_6lrUCWF*4LLF)~z%LE<l-xrrg1A(A15
zp_ZwRDUS<68!#9!)G#bysbO5m$jDFwubEkk@<0J02qM7YXaQmsfGcgJ&|^$RtM`fm
z85kIzgTe&do?~KS<YDAv;b4?t<YFYQIRR~GqIegSMB(1ef+SPOkOX55V+yEj6a!_w
zDjv|d9cZ8;oFUJOg`tGGGKP_%mYI>EN-2f0mZgMc0V}AnoW)kdypWj@797lV%plz<
z47JR4%#Z-dVqd^f!?X}IqR-@4r5gYlsZ>xcQpiXw2K7EOA!G6i(B5mYZUA_|*-AmR
zSd+6z8WdQdmU0m{hy`-`Ew-He^z_uCTkPeDMR}Qd>5$~>3o5o1z~eZeo+;AUHEb*!
z)ale@1&8@9el#_=Sc(f$lZy&LhOp<R78fU`qesXs`FJb?<MAn}1*v%{sd>qjUqF!s
zYSe(nAvhRW7{O7-$igVVD8X3eL`<T^ZvoZ<CmCcbXw;&Hv4{`UkXXRDkRgvLg|U{Y
zhRKB?R;rd6lx!C;m$1};n-y8C3z@<g7#Rx1Al(`e8x(6Rnf$;>P?H^!pE+PbR0IxM
z$N&sf3>1{$k<xf@uz{P!;KW@4O4pE5;TA7wWB?ZU#YI)1uw}$(-U()wq!uAUF*CK8
zk&%I+7}9zcVgx1lDib2Y4#OCfbPsBTfG{|lgQ{szNFkbiV7Ftb+HZ-2Vgx!C0rLvT
z^Bf>ILMsp}B3y^V7)>TWKTWZscu>%A#mDF7r<CTT#>d~{iH|QVP0Rr`Y2xE=vB$@!
z<R^oKGmBv(x~VBe;h-D=8vH6s0I`xlL>kB>4$weGYEelgxYY_N%n{81P~`+ElR$+K
zxR@ydMO#rF$bfnf0WPo+1gPjP0*!%|g3=mjB$k7bg`b6kfsx@Smk<XF2RjD~2OAS3
z7Yh?37dw<@<KW<6;Sk~A<>2LD2kQo<R8a8_$DleB#3=?@fHL03-p-K5n8KXG(!v?V
zlERw8*1{0Q+Rnhj5XBbEpvh4LY8bisC4(XoWB>?*S`VN^11ivq-+_9njJ0ev%nKN5
z7;9J-GS#xzu%|GTG8XBSFfL$9VXR@#VqVC^$N-{i8B17d7;BiCnQA#|II@^)7_*s*
zUA!2Y7(u)&)}l>dnyq+K2|Jj@(ac!OS;ASvnZ?!2Sj$zzQp1(aRNUspP{T5tDTS$q
zYc^8~^IR72EC?&u)=eecHJn*I&5X6&HLNw<*-XWoyckkg7Vv_2H7pC6!D=Bcyi~)U
z#aDExhAE4=hAE4`l%eQS3Tq8Vyg-RyGeee84Py;k4Mz=g4NDDc3R^E5Xbw1-L6hCD
zN;<R{H0%Z*c1Zz^(4^*oM@K+qX%&ltqOC#|7r2E09&M?TtX3?l1&M-b(0CbGT%o!)
zWF;H8I}Axb;NjR1P`ZF8B2D32qM#%V)({W2Fg`V}q^Po}2$TR>Q&N*k(;-HHrVc=J
zDDhymMW8yTNED=q1JnQorEo}-18g>^s)ICEL2cJtTm_(+N$`Yeku6A%JaoVcGAja_
z&&<q&7z}a5E!N`Fg47~#*3jeu7xfTVfCv3i{Q&mdEpBATgM50673|PkTwn^^l)1$V
zVM7~ED;Xi(Y;XnvC0(#}0-zEBG*r&O$->CP$iWDjS^;$h1Q>Z3xfo@bI2b`Zw*PFb
zZ2y^<SpG3FbNyvvWrI$>fT!9RnSND?q0D#U9+d%Q9&l*}s&PQ2Sr%g!s5!};f*AP-
z(PX^E4;rY<$w|$LPb$sKNh#K3ft2SQ(B?tWEh#7qJfM}Df?Ui&T7FmxMsNXQ4e~NL
z4>EBuvi+}8MsqsMTu>_$Hb@C7@m8{fOS~e`lt@t{C|<ddW~RZR2{!*0FLVqhIW;FI
zJ|0{<L5PW<)CdlGP)WcGatEksz`@AE&cMj<i%%O|LQt{50ZsdcpcXhFkHZTb(A;nd
zLo-7bV+~^sBdGBNDo&u8lo6gunf!`cK{X_EQ4h!m;1V1ZiJEK#(kj@)s0q#$<ZIA~
z5CbP<{*D7Y<-zo;N(y5Z9d|MU6_+3v6oX8HB%=l3WCUum!Ment20+ndP(;bV;uJPD
zMto`s2e}toWvXLwA<Sg-)KWAR6jWfpg9&g@fa4w%DNZ0$QQ}?*JV%ca_aKjgnn}ei
z*d}*CRSiQFE3~R%OJPsp08j03rf`9$cDPe`pi?`%DSY559MIGbe~JK@4Vu~!Oc4UJ
zK~p=zDI#DtUy5joSPMfGe~NgDL<>WdK#F9FR0~6tU<zntQX0IXAjB^jl$AkM7zl$J
z=pa5gPC!*HWPG{=l&+YXL8H{r@o7*qyoNao)DQ<vwX%RJGf*=Q)N2-m&b%nVXWKN{
zz>PZaycZ->BjQvR7V^+`4r&nqZ81Z%!;8^d+{M|M1@T3xiN*POkUR;F9B{mVl63+s
zUKrTf7<m}k*jN~=lpG-wLeS|ZqzNkA=@XP-z+nN3;}Y;l2x8Qe3ET^XI1O7N1#TRH
z90D?hfvHLnp92UCGJ}d)#2_<h<OMOnEQdP4jGTfY1I<M-pv=RAETPE)8J__Ug@PJ@
zxV-^t-j#v80V-}7z(dL`|L}(<j*(<|$^!WY5}KgS0mwIL%!qJhDM|$8Ik3~f^)k5I
zk1d2jjm}z-)1V=YH;M_3A%m7Alz`f6pdKkxkqX#pj9E<CO!-P6C)O}#F=s<ZlZ!wZ
z9A!8e;m{P2<H5-hOn}oQsA1d)aww?SW?<q0b;%U)B?qh{#~@#VQzNLg2?@U}<WYD?
zQwH2$1&yU*8<7Gx$J;?J0U5@?T&0HF70{s@a3h51?o1JADGpYfK_S$GWV0M@n?da|
z3>!fX#_N0V5E0n-I1>y=Vj_|o@MKA7a|^dKuonrEpx6gH0$YNe#=yWZ4at60++l#!
zCc$t6N=5=zn}|8F6sEbLr54P7MG*`P3{^Y|8u0Q?vnUeeIBf0$^~z?$-NjU;h1*>i
zBdVZy0o5HK465cpbqFYXK<77$IY9LS$dRC-0q~FjsD@_(4+$`VW*Xo_0zx2_kXj#F
zVSsw=;09w+HOT4kp1vkCq{UJL60HRh;JgMVz!?tIo172w5UkK*0nH|8<MtK_9e7aa
z!(9rgeXxZos4u$=<OFa4F;yAjwj9)%fmVOWEgDTBw3cd7Gsvr;$skBG6<ouB%I6|b
zNmv9bWr{!z3~(-o3`~Jid=V(w6@lWIKrb8Aj*J008Pu)?jUllxaiI6GLA`7+2KBtb
zZ3s|ggCZY}L8$=T*qMRR*hyh-VTfV@uVn!>cyO#`N#%sBW@%=O;!5R2TF=6XSkD4k
z%@W0%%86LZlFA8L&C<*m#h=OvS<%wW7=>j`OE80`{4IXhijtzlV)#1C#J4OAC<|3e
zG7?L`BZcazV3q1R3YmE+naPPIpq_4GN=hbZ!EIuW0(=-QGqo7HL<2ga2pX;_1}%C3
zFEPn40xe;IEOde_T|w5Vqfnfmn_7|qGCU_U8?xdcEk8dRY<sL8Xgy4-0+>^*kdmLL
zUZRkgmX?}a0-k+?7T5aFf=dCi3I>|2Qd7Xo7g92dQj<$^Ds>c+N=smV0WEe&EKw*=
z1uutDz~wE4@KlA|{FKxj1yHbnjZ3Oj$Ve;$IX5v+A+e|=Gc7YYGciX2EnLAG6v~Sd
z3yQ%mRRS&fR00JGWHB!^#6Yu*=sF<_K#C!2D?m#%Kw3ewF(7tYeojt)Imr6*#L8kT
z$dVyLJq1rlq$Mhp=4BR^rh?}lbU+gh5KTq73dn&9USpJ;SPEK&15yB6Y6JG6f&zGr
zNKtBHi9%+H0%*`!p%}D+0<=yiFCQ{91kweM$4Z6tqQrs>$np;(J%w=4QkC*l^`caT
z^wbh?!U3s=&y}hdqof`kn6-(Tpa2IAaAu}eLPIcBp*%4U65HTZfT9!RxboDT9Ei;d
z3JOVJ6B1KW6cP~%D-}SCiZW6azyS$&1zeMYf<ka=szOp~PJTIbv<755cv%iOeWa#9
z)Eeu7+y_|#t>BlR2U+t3@>*$LN@`I~B`98?bq`Wr&;dCUqzYs|%&%}~Kvo<T6y=wJ
zC*4XQtF+2fp{X6>`+SAeycC7f0%!&*Eyw}oNO;BrB_pKR!0KIv%wni#6pHg9feUgI
zEb2i?Q@sT2x|GypkW)ZO9+UuzGr+5dic*vFb8|t?fTtwGSor#FLp=lVDl)j7Q7qUj
zSk5%kGtg7;fMlGKjQrwMkbRJ>080#@SW3&!w?#6_)=19)Yz%0fS!!}gW?5=ZB`AuL
zQz6+3?)s8^1&{;N^D@Cpw-P}q1`>gZ3d#9-X*rq6C6Gu=1{Kw?avQ{Ef~}|qcgP{j
z06^V7MtFs%$#jba6nD4Sz)7$eRuzL*ofORj)lcAB7)*exVo-nV2&hs4)td}#Y>ZVB
zXt^AF{|n?CP;(jF<^!$5g|v8^!2_r%ObeM}m}(honNpY+FxN1quq*)0N3$+utYHGr
zNwY#4Kt(d3RuE@(ZFF^QtU`6|FGd|rHb}n><ltMZ#RWN;CE&i$EtahO%sj9cV15EM
zS#Plvr52Y!s(FN`KsE1KxTl!J7^}oFJ%znb2WlUI{e-%32;9YB$YKF4N`@>P(nIOj
zfx_Ij8bm4<)#^ZN0o!UwB!K&Q%;0`r5y)Q<U$BDx1sN^`_wnFTSR3e|hQuY1pFk~J
zXh)Bc<uA7A!qLG4MH$#@pwt72E>JHDWvLLPbBEt0pw`SSkV`<xk%0-D3uxP$LpTpt
zZ|)w*d7$J8?ahf{MnBd*9DEuG)G!6LinHKzwM>wx!`pRx0<snyD$G?f=vG2o0P$G6
zPgvpxGGYr_A*IP!lnxphWGMnofg`yCoT0I`Zb4ZCv@NF?>=>3R5p>63bp&DGhk;5E
zY!-qf-Xr-QBfmjQSB%aQXw4-!QG(Vw!Pc`ZU|PtK0_lS=WU)3gE@WH?8Wdypt75ON
zRR9$hRZKbxuvIMJ<N$6zF9eOGuodSQm87PCGa1&L1XB71<W@)mVPO>eU!{N^Ko}h<
zP~gDIVh|gI!4AinRKVQ<Y=H%m_yuwRICiik738Trj1VJiF}Op4&0>(me<X{g(S41t
zTT9qpaMuT$y&wq|CI$vba%8T;uornX95_&*Aq@&!PznKcVv0ej9g-(O)7RjUXoiK1
zpegDa#$q{86$mP&!8Hv-7HbysLPqfPHuD0|<|3E~O9^`oOEV+5r^{Nxv4ArLv@DS!
zi>rnqi@Sz(Aqyizp%>T|)&)E@%nLy(RchI4m=^Gs@YS$^d&CS`{Gg=`plQRRk{Wi9
z3kpj>_JhV(RaJ`>R6!kp)MD^*cUW@?)Pez52MX${#p;>@kZcSZX}u+nyfOjQC4o$z
z!`ofpq<o79ymzY@)V9da0}lw^;(|25Q}dEjixz{jCTNDOs2Icol>m_0GH@>)t%J^i
z)IkT$eBI&!Z+?siJFxf`A9UdbjL!-dF9LPtZ*e0{^P|_hpng3kD4x|o@yEo$!Ux(3
z!y?2e#K;3)^S}lo|FE$OF|si7{byljVXRWbNQ3Be{<w1hsLcWjckrkL#4*^CAE>Xd
z267fSX|YzRqg#oihwrB;jNZj>0);K8%~S+xW1vm0W9{98N*l<?04Vo?Cl(3x^XD)y
zFsugUQcwepgONpogOh_5JYx=<M`s1iqr+#_A^m;XB9J~%MgfIA9D^zraBm;fen6Q=
z2kl!yo7zZahfHoXGe&WwvZsJ2IGP!wI8)hEz>^%H9)AjWk|T;6w4u0#A&MsjJh>6Y
z3!b(Rz9kOrO%y|x>cD&NZhj~$R6x#xH?=@Bqu>=rj737AF<#KxqCCD5#w;e#uIyGO
zNrqac66O@91uWoce+JOn6;P!B%8c=>pah`F>h}_4<Sj-$l+*%>aF94COB92)hSe~{
z^3^gzECJ_RCXjY;`q5+rw>&kOZZYW@++s|Iq$hZz@)oB}dTL&3MM06B1rr0qXHW=N
z8RPIRyv?j<larsEm{V-02iL91RwM<gr<jW?i*NBj>qYSX+9L22H>eT=FEoX=b8qn%
zRKgaULX?4);i9<?JmO>oO5>m+lL0iL%*4l71z$OZ78`K)p@bHwga?HfxLN~^VnfQt
z*$i`;f*Dpa`Bkw)j8Rz02zDUW+7*;9>_83ynZ&?UC67CZu(!ZL@db7PsG$qmpqs)7
zZUiy;Rms{w9ROa)3NskGD$GuksfZJlJwYzV>NHT>%?a)_mMRsP2@q4^X;lwzQw<bK
zVE2KV51^U?x>N}N*t!SYUgjzpT=wE`m7&|W4dhvD<sGOo=8I$>&M1H;KH?KW(N<79
zlo3*~V6z%j+6BR_W~$P_<yDOK6*#$oG8F>@1BeX|W^f@7YKB*W{0qvDnoLO57f1k-
z89>D)xM&SSa)2f-2he6nISR>YeOy-KsBSd*&}$n|LlIJAAgUZ}Bgmjo2m8DTRMkO3
z11(%uGcYjdfgA@ad!U2IJRG2^16-MaD-;$EmLiZkO}ks{pmmg>^^==GMHO2~WdVo-
zikBi#{wxATN)f04F9M~?B2XKx2vqWbb6}K0L1uwod|7H<N`8?ZWKUpbUb-G+xGXcZ
zsJIA}x53LcZ%JcUTUwHtQ(Oej%Am~&QL@;TK~pfK<m3k>5YRl+ElCvB+3E41(HGFB
zx8fpD=l7NbSRUM<%1g}AORY#wg=`5g0<XmdEo_FG0apVaTrJiEZ4fFF23Z7}CcPzv
zY7kTrcu5dsC6gSgf}+$yJ<z)5lA==3kq5;^ph^k6R~G6+xP2g%pq<&!A>ty?cm%q;
z!GWZgn^~M(1fJOf#qBLfNWsm4sDVcUWYsLV%Onf(1*qFqBoAVN`<9@_V38sy&N<Ul
zOMJkKX(6c+)U>?Ci*oV-c-udC|2KGlGh_h)Xe}Ukg$;PA1$YVq+%f^DENn^h7KaUF
zZKEA1%NK*zgmEx(FlsOfFoKpx@i6j0SpqCPAQ2`BCeXfgE+!^MrvEJLB0L<D96}sY
S0`&}%0;U2|0{#N^3@iYh%kN77

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/factory.cpython-39.pyc
deleted file mode 100644
index d0361bc53a2b1a578c6e225fc0e00a75e89f34dd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/found_candidates.cpython-39.pyc
deleted file mode 100644
index b968b76f13c1684f7cd6acab67d83b19b01b61b8..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4683
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
aLHb#^I2dJ^co=z@c$g%ZIfOVwIphJ!l@Cw=

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/provider.cpython-39.pyc
deleted file mode 100644
index f8278ed7886972a330510fe19f0b8cce6b23f479..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6603
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
Qg^`Dmhlz(tfQdyE0AA}41ONa4

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/reporter.cpython-39.pyc
deleted file mode 100644
index 882b0e3cb0a8b38c113681c0fae98ce9ee16b304..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/requirements.cpython-39.pyc
deleted file mode 100644
index 92f11c46100fe5551b474e91a74c25ef37be1b94..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7072
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
Ohe?82KvTd@zyJUOM)q+4

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/__pycache__/resolver.cpython-39.pyc
deleted file mode 100644
index 86f04fab60a8c8e2d9b97ea9c22243cf2ba26aad..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8079
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
ZcsxuZj66(ij66(y%v{U@^$flodH|#_dUXH*

diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py
index 26821a1f..b206692a 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/base.py
@@ -12,8 +12,7 @@ CandidateLookup = Tuple[Optional["Candidate"], Optional[InstallRequirement]]
 CandidateVersion = Union[LegacyVersion, Version]
 
 
-def format_name(project, extras):
-    # type: (str, FrozenSet[str]) -> str
+def format_name(project: str, extras: FrozenSet[str]) -> str:
     if not extras:
         return project
     canonical_extras = sorted(canonicalize_name(e) for e in extras)
@@ -21,33 +20,26 @@ def format_name(project, extras):
 
 
 class Constraint:
-    def __init__(self, specifier, hashes, links):
-        # type: (SpecifierSet, Hashes, FrozenSet[Link]) -> None
+    def __init__(
+        self, specifier: SpecifierSet, hashes: Hashes, links: FrozenSet[Link]
+    ) -> None:
         self.specifier = specifier
         self.hashes = hashes
         self.links = links
 
     @classmethod
-    def empty(cls):
-        # type: () -> Constraint
+    def empty(cls) -> "Constraint":
         return Constraint(SpecifierSet(), Hashes(), frozenset())
 
     @classmethod
-    def from_ireq(cls, ireq):
-        # type: (InstallRequirement) -> Constraint
+    def from_ireq(cls, ireq: InstallRequirement) -> "Constraint":
         links = frozenset([ireq.link]) if ireq.link else frozenset()
         return Constraint(ireq.specifier, ireq.hashes(trust_internet=False), links)
 
-    def __nonzero__(self):
-        # type: () -> bool
+    def __bool__(self) -> bool:
         return bool(self.specifier) or bool(self.hashes) or bool(self.links)
 
-    def __bool__(self):
-        # type: () -> bool
-        return self.__nonzero__()
-
-    def __and__(self, other):
-        # type: (InstallRequirement) -> Constraint
+    def __and__(self, other: InstallRequirement) -> "Constraint":
         if not isinstance(other, InstallRequirement):
             return NotImplemented
         specifier = self.specifier & other.specifier
@@ -57,8 +49,7 @@ class Constraint:
             links = links.union([other.link])
         return Constraint(specifier, hashes, links)
 
-    def is_satisfied_by(self, candidate):
-        # type: (Candidate) -> bool
+    def is_satisfied_by(self, candidate: "Candidate") -> bool:
         # Reject if there are any mismatched URL constraints on this package.
         if self.links and not all(_match_link(link, candidate) for link in self.links):
             return False
@@ -70,8 +61,7 @@ class Constraint:
 
 class Requirement:
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         """The "project name" of a requirement.
 
         This is different from ``name`` if this requirement contains extras,
@@ -81,8 +71,7 @@ class Requirement:
         raise NotImplementedError("Subclass should override")
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         """The name identifying this requirement in the resolver.
 
         This is different from ``project_name`` if this requirement contains
@@ -90,21 +79,17 @@ class Requirement:
         """
         raise NotImplementedError("Subclass should override")
 
-    def is_satisfied_by(self, candidate):
-        # type: (Candidate) -> bool
+    def is_satisfied_by(self, candidate: "Candidate") -> bool:
         return False
 
-    def get_candidate_lookup(self):
-        # type: () -> CandidateLookup
+    def get_candidate_lookup(self) -> CandidateLookup:
         raise NotImplementedError("Subclass should override")
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         raise NotImplementedError("Subclass should override")
 
 
-def _match_link(link, candidate):
-    # type: (Link, Candidate) -> bool
+def _match_link(link: Link, candidate: "Candidate") -> bool:
     if candidate.source_link:
         return links_equivalent(link, candidate.source_link)
     return False
@@ -112,8 +97,7 @@ def _match_link(link, candidate):
 
 class Candidate:
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         """The "project name" of the candidate.
 
         This is different from ``name`` if this candidate contains extras,
@@ -123,8 +107,7 @@ class Candidate:
         raise NotImplementedError("Override in subclass")
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         """The name identifying this candidate in the resolver.
 
         This is different from ``project_name`` if this candidate contains
@@ -133,33 +116,26 @@ class Candidate:
         raise NotImplementedError("Override in subclass")
 
     @property
-    def version(self):
-        # type: () -> CandidateVersion
+    def version(self) -> CandidateVersion:
         raise NotImplementedError("Override in subclass")
 
     @property
-    def is_installed(self):
-        # type: () -> bool
+    def is_installed(self) -> bool:
         raise NotImplementedError("Override in subclass")
 
     @property
-    def is_editable(self):
-        # type: () -> bool
+    def is_editable(self) -> bool:
         raise NotImplementedError("Override in subclass")
 
     @property
-    def source_link(self):
-        # type: () -> Optional[Link]
+    def source_link(self) -> Optional[Link]:
         raise NotImplementedError("Override in subclass")
 
-    def iter_dependencies(self, with_requires):
-        # type: (bool) -> Iterable[Optional[Requirement]]
+    def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]:
         raise NotImplementedError("Override in subclass")
 
-    def get_install_requirement(self):
-        # type: () -> Optional[InstallRequirement]
+    def get_install_requirement(self) -> Optional[InstallRequirement]:
         raise NotImplementedError("Override in subclass")
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         raise NotImplementedError("Subclass should override")
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py
index da516ad3..de04e1d7 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/candidates.py
@@ -2,13 +2,15 @@ import logging
 import sys
 from typing import TYPE_CHECKING, Any, FrozenSet, Iterable, Optional, Tuple, Union, cast
 
-from pip._vendor.packaging.specifiers import InvalidSpecifier, SpecifierSet
 from pip._vendor.packaging.utils import NormalizedName, canonicalize_name
 from pip._vendor.packaging.version import Version
-from pip._vendor.packaging.version import parse as parse_version
-from pip._vendor.pkg_resources import Distribution
 
-from pip._internal.exceptions import HashError, MetadataInconsistent
+from pip._internal.exceptions import (
+    HashError,
+    InstallationSubprocessError,
+    MetadataInconsistent,
+)
+from pip._internal.metadata import BaseDistribution
 from pip._internal.models.link import Link, links_equivalent
 from pip._internal.models.wheel import Wheel
 from pip._internal.req.constructors import (
@@ -16,8 +18,8 @@ from pip._internal.req.constructors import (
     install_req_from_line,
 )
 from pip._internal.req.req_install import InstallRequirement
-from pip._internal.utils.misc import dist_is_editable, normalize_version_info
-from pip._internal.utils.packaging import get_requires_python
+from pip._internal.utils.direct_url_helpers import direct_url_from_link
+from pip._internal.utils.misc import normalize_version_info
 
 from .base import Candidate, CandidateVersion, Requirement, format_name
 
@@ -32,6 +34,9 @@ BaseCandidate = Union[
     "LinkCandidate",
 ]
 
+# Avoid conflicting with the PyPI package "Python".
+REQUIRES_PYTHON_IDENTIFIER = cast(NormalizedName, "<Python from Requires-Python>")
+
 
 def as_base_candidate(candidate: Candidate) -> Optional[BaseCandidate]:
     """The runtime version of BaseCandidate."""
@@ -45,8 +50,9 @@ def as_base_candidate(candidate: Candidate) -> Optional[BaseCandidate]:
     return None
 
 
-def make_install_req_from_link(link, template):
-    # type: (Link, InstallRequirement) -> InstallRequirement
+def make_install_req_from_link(
+    link: Link, template: InstallRequirement
+) -> InstallRequirement:
     assert not template.editable, "template is editable"
     if template.req:
         line = str(template.req)
@@ -59,44 +65,45 @@ def make_install_req_from_link(link, template):
         use_pep517=template.use_pep517,
         isolated=template.isolated,
         constraint=template.constraint,
-        options=dict(
-            install_options=template.install_options,
-            global_options=template.global_options,
-            hashes=template.hash_options,
-        ),
+        global_options=template.global_options,
+        hash_options=template.hash_options,
+        config_settings=template.config_settings,
     )
     ireq.original_link = template.original_link
     ireq.link = link
+    ireq.extras = template.extras
     return ireq
 
 
-def make_install_req_from_editable(link, template):
-    # type: (Link, InstallRequirement) -> InstallRequirement
+def make_install_req_from_editable(
+    link: Link, template: InstallRequirement
+) -> InstallRequirement:
     assert template.editable, "template not editable"
-    return install_req_from_editable(
+    ireq = install_req_from_editable(
         link.url,
         user_supplied=template.user_supplied,
         comes_from=template.comes_from,
         use_pep517=template.use_pep517,
         isolated=template.isolated,
         constraint=template.constraint,
-        options=dict(
-            install_options=template.install_options,
-            global_options=template.global_options,
-            hashes=template.hash_options,
-        ),
+        permit_editable_wheels=template.permit_editable_wheels,
+        global_options=template.global_options,
+        hash_options=template.hash_options,
+        config_settings=template.config_settings,
     )
+    ireq.extras = template.extras
+    return ireq
 
 
-def make_install_req_from_dist(dist, template):
-    # type: (Distribution, InstallRequirement) -> InstallRequirement
-    project_name = canonicalize_name(dist.project_name)
+def _make_install_req_from_dist(
+    dist: BaseDistribution, template: InstallRequirement
+) -> InstallRequirement:
     if template.req:
         line = str(template.req)
     elif template.link:
-        line = f"{project_name} @ {template.link.url}"
+        line = f"{dist.canonical_name} @ {template.link.url}"
     else:
-        line = f"{project_name}=={dist.parsed_version}"
+        line = f"{dist.canonical_name}=={dist.version}"
     ireq = install_req_from_line(
         line,
         user_supplied=template.user_supplied,
@@ -104,11 +111,9 @@ def make_install_req_from_dist(dist, template):
         use_pep517=template.use_pep517,
         isolated=template.isolated,
         constraint=template.constraint,
-        options=dict(
-            install_options=template.install_options,
-            global_options=template.global_options,
-            hashes=template.hash_options,
-        ),
+        global_options=template.global_options,
+        hash_options=template.hash_options,
+        config_settings=template.config_settings,
     )
     ireq.satisfied_by = dist
     return ireq
@@ -130,18 +135,18 @@ class _InstallRequirementBackedCandidate(Candidate):
         found remote link (e.g. from pypi.org).
     """
 
+    dist: BaseDistribution
     is_installed = False
 
     def __init__(
         self,
-        link,  # type: Link
-        source_link,  # type: Link
-        ireq,  # type: InstallRequirement
-        factory,  # type: Factory
-        name=None,  # type: Optional[NormalizedName]
-        version=None,  # type: Optional[CandidateVersion]
-    ):
-        # type: (...) -> None
+        link: Link,
+        source_link: Link,
+        ireq: InstallRequirement,
+        factory: "Factory",
+        name: Optional[NormalizedName] = None,
+        version: Optional[CandidateVersion] = None,
+    ) -> None:
         self._link = link
         self._source_link = source_link
         self._factory = factory
@@ -150,86 +155,72 @@ class _InstallRequirementBackedCandidate(Candidate):
         self._version = version
         self.dist = self._prepare()
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return f"{self.name} {self.version}"
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}({link!r})".format(
             class_name=self.__class__.__name__,
             link=str(self._link),
         )
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash((self.__class__, self._link))
 
-    def __eq__(self, other):
-        # type: (Any) -> bool
+    def __eq__(self, other: Any) -> bool:
         if isinstance(other, self.__class__):
             return links_equivalent(self._link, other._link)
         return False
 
     @property
-    def source_link(self):
-        # type: () -> Optional[Link]
+    def source_link(self) -> Optional[Link]:
         return self._source_link
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         """The normalised name of the project the candidate refers to"""
         if self._name is None:
-            self._name = canonicalize_name(self.dist.project_name)
+            self._name = self.dist.canonical_name
         return self._name
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         return self.project_name
 
     @property
-    def version(self):
-        # type: () -> CandidateVersion
+    def version(self) -> CandidateVersion:
         if self._version is None:
-            self._version = parse_version(self.dist.version)
+            self._version = self.dist.version
         return self._version
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return "{} {} (from {})".format(
             self.name,
             self.version,
             self._link.file_path if self._link.is_file else self._link,
         )
 
-    def _prepare_distribution(self):
-        # type: () -> Distribution
+    def _prepare_distribution(self) -> BaseDistribution:
         raise NotImplementedError("Override in subclass")
 
-    def _check_metadata_consistency(self, dist):
-        # type: (Distribution) -> None
+    def _check_metadata_consistency(self, dist: BaseDistribution) -> None:
         """Check for consistency of project name and version of dist."""
-        canonical_name = canonicalize_name(dist.project_name)
-        if self._name is not None and self._name != canonical_name:
+        if self._name is not None and self._name != dist.canonical_name:
             raise MetadataInconsistent(
                 self._ireq,
                 "name",
                 self._name,
-                dist.project_name,
+                dist.canonical_name,
             )
-        parsed_version = parse_version(dist.version)
-        if self._version is not None and self._version != parsed_version:
+        if self._version is not None and self._version != dist.version:
             raise MetadataInconsistent(
                 self._ireq,
                 "version",
                 str(self._version),
-                dist.version,
+                str(dist.version),
             )
 
-    def _prepare(self):
-        # type: () -> Distribution
+    def _prepare(self) -> BaseDistribution:
         try:
             dist = self._prepare_distribution()
         except HashError as e:
@@ -238,31 +229,21 @@ class _InstallRequirementBackedCandidate(Candidate):
             # offending line to the user.
             e.req = self._ireq
             raise
+        except InstallationSubprocessError as exc:
+            # The output has been presented already, so don't duplicate it.
+            exc.context = "See above for output."
+            raise
+
         self._check_metadata_consistency(dist)
         return dist
 
-    def _get_requires_python_dependency(self):
-        # type: () -> Optional[Requirement]
-        requires_python = get_requires_python(self.dist)
-        if requires_python is None:
-            return None
-        try:
-            spec = SpecifierSet(requires_python)
-        except InvalidSpecifier as e:
-            message = "Package %r has an invalid Requires-Python: %s"
-            logger.warning(message, self.name, e)
-            return None
-        return self._factory.make_requires_python_requirement(spec)
-
-    def iter_dependencies(self, with_requires):
-        # type: (bool) -> Iterable[Optional[Requirement]]
-        requires = self.dist.requires() if with_requires else ()
+    def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]:
+        requires = self.dist.iter_dependencies() if with_requires else ()
         for r in requires:
             yield self._factory.make_requirement_from_spec(str(r), self._ireq)
-        yield self._get_requires_python_dependency()
+        yield self._factory.make_requires_python_requirement(self.dist.requires_python)
 
-    def get_install_requirement(self):
-        # type: () -> Optional[InstallRequirement]
+    def get_install_requirement(self) -> Optional[InstallRequirement]:
         return self._ireq
 
 
@@ -271,15 +252,14 @@ class LinkCandidate(_InstallRequirementBackedCandidate):
 
     def __init__(
         self,
-        link,  # type: Link
-        template,  # type: InstallRequirement
-        factory,  # type: Factory
-        name=None,  # type: Optional[NormalizedName]
-        version=None,  # type: Optional[CandidateVersion]
-    ):
-        # type: (...) -> None
+        link: Link,
+        template: InstallRequirement,
+        factory: "Factory",
+        name: Optional[NormalizedName] = None,
+        version: Optional[CandidateVersion] = None,
+    ) -> None:
         source_link = link
-        cache_entry = factory.get_wheel_cache_entry(link, name)
+        cache_entry = factory.get_wheel_cache_entry(source_link, name)
         if cache_entry is not None:
             logger.debug("Using cached wheel link: %s", cache_entry.link)
             link = cache_entry.link
@@ -296,12 +276,19 @@ class LinkCandidate(_InstallRequirementBackedCandidate):
                     version, wheel_version, name
                 )
 
-        if (
-            cache_entry is not None
-            and cache_entry.persistent
-            and template.link is template.original_link
-        ):
-            ireq.original_link_is_in_wheel_cache = True
+        if cache_entry is not None:
+            assert ireq.link.is_wheel
+            assert ireq.link.is_file
+            if cache_entry.persistent and template.link is template.original_link:
+                ireq.cached_wheel_source_link = source_link
+            if cache_entry.origin is not None:
+                ireq.download_info = cache_entry.origin
+            else:
+                # Legacy cache entry that does not have origin.json.
+                # download_info may miss the archive_info.hashes field.
+                ireq.download_info = direct_url_from_link(
+                    source_link, link_is_in_wheel_cache=cache_entry.persistent
+                )
 
         super().__init__(
             link=link,
@@ -312,11 +299,9 @@ class LinkCandidate(_InstallRequirementBackedCandidate):
             version=version,
         )
 
-    def _prepare_distribution(self):
-        # type: () -> Distribution
-        return self._factory.preparer.prepare_linked_requirement(
-            self._ireq, parallel_builds=True
-        )
+    def _prepare_distribution(self) -> BaseDistribution:
+        preparer = self._factory.preparer
+        return preparer.prepare_linked_requirement(self._ireq, parallel_builds=True)
 
 
 class EditableCandidate(_InstallRequirementBackedCandidate):
@@ -324,13 +309,12 @@ class EditableCandidate(_InstallRequirementBackedCandidate):
 
     def __init__(
         self,
-        link,  # type: Link
-        template,  # type: InstallRequirement
-        factory,  # type: Factory
-        name=None,  # type: Optional[NormalizedName]
-        version=None,  # type: Optional[CandidateVersion]
-    ):
-        # type: (...) -> None
+        link: Link,
+        template: InstallRequirement,
+        factory: "Factory",
+        name: Optional[NormalizedName] = None,
+        version: Optional[CandidateVersion] = None,
+    ) -> None:
         super().__init__(
             link=link,
             source_link=link,
@@ -340,8 +324,7 @@ class EditableCandidate(_InstallRequirementBackedCandidate):
             version=version,
         )
 
-    def _prepare_distribution(self):
-        # type: () -> Distribution
+    def _prepare_distribution(self) -> BaseDistribution:
         return self._factory.preparer.prepare_editable_requirement(self._ireq)
 
 
@@ -351,76 +334,67 @@ class AlreadyInstalledCandidate(Candidate):
 
     def __init__(
         self,
-        dist,  # type: Distribution
-        template,  # type: InstallRequirement
-        factory,  # type: Factory
-    ):
-        # type: (...) -> None
+        dist: BaseDistribution,
+        template: InstallRequirement,
+        factory: "Factory",
+    ) -> None:
         self.dist = dist
-        self._ireq = make_install_req_from_dist(dist, template)
+        self._ireq = _make_install_req_from_dist(dist, template)
         self._factory = factory
+        self._version = None
 
         # This is just logging some messages, so we can do it eagerly.
         # The returned dist would be exactly the same as self.dist because we
-        # set satisfied_by in make_install_req_from_dist.
+        # set satisfied_by in _make_install_req_from_dist.
         # TODO: Supply reason based on force_reinstall and upgrade_strategy.
         skip_reason = "already satisfied"
         factory.preparer.prepare_installed_requirement(self._ireq, skip_reason)
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return str(self.dist)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}({distribution!r})".format(
             class_name=self.__class__.__name__,
             distribution=self.dist,
         )
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash((self.__class__, self.name, self.version))
 
-    def __eq__(self, other):
-        # type: (Any) -> bool
+    def __eq__(self, other: Any) -> bool:
         if isinstance(other, self.__class__):
             return self.name == other.name and self.version == other.version
         return False
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
-        return canonicalize_name(self.dist.project_name)
+    def project_name(self) -> NormalizedName:
+        return self.dist.canonical_name
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         return self.project_name
 
     @property
-    def version(self):
-        # type: () -> CandidateVersion
-        return parse_version(self.dist.version)
+    def version(self) -> CandidateVersion:
+        if self._version is None:
+            self._version = self.dist.version
+        return self._version
 
     @property
-    def is_editable(self):
-        # type: () -> bool
-        return dist_is_editable(self.dist)
+    def is_editable(self) -> bool:
+        return self.dist.editable
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return f"{self.name} {self.version} (Installed)"
 
-    def iter_dependencies(self, with_requires):
-        # type: (bool) -> Iterable[Optional[Requirement]]
+    def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]:
         if not with_requires:
             return
-        for r in self.dist.requires():
+        for r in self.dist.iter_dependencies():
             yield self._factory.make_requirement_from_spec(str(r), self._ireq)
 
-    def get_install_requirement(self):
-        # type: () -> Optional[InstallRequirement]
+    def get_install_requirement(self) -> Optional[InstallRequirement]:
         return None
 
 
@@ -451,75 +425,62 @@ class ExtrasCandidate(Candidate):
 
     def __init__(
         self,
-        base,  # type: BaseCandidate
-        extras,  # type: FrozenSet[str]
-    ):
-        # type: (...) -> None
+        base: BaseCandidate,
+        extras: FrozenSet[str],
+    ) -> None:
         self.base = base
         self.extras = extras
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         name, rest = str(self.base).split(" ", 1)
         return "{}[{}] {}".format(name, ",".join(self.extras), rest)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}(base={base!r}, extras={extras!r})".format(
             class_name=self.__class__.__name__,
             base=self.base,
             extras=self.extras,
         )
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash((self.base, self.extras))
 
-    def __eq__(self, other):
-        # type: (Any) -> bool
+    def __eq__(self, other: Any) -> bool:
         if isinstance(other, self.__class__):
             return self.base == other.base and self.extras == other.extras
         return False
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         return self.base.project_name
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         """The normalised name of the project the candidate refers to"""
         return format_name(self.base.project_name, self.extras)
 
     @property
-    def version(self):
-        # type: () -> CandidateVersion
+    def version(self) -> CandidateVersion:
         return self.base.version
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return "{} [{}]".format(
             self.base.format_for_error(), ", ".join(sorted(self.extras))
         )
 
     @property
-    def is_installed(self):
-        # type: () -> bool
+    def is_installed(self) -> bool:
         return self.base.is_installed
 
     @property
-    def is_editable(self):
-        # type: () -> bool
+    def is_editable(self) -> bool:
         return self.base.is_editable
 
     @property
-    def source_link(self):
-        # type: () -> Optional[Link]
+    def source_link(self) -> Optional[Link]:
         return self.base.source_link
 
-    def iter_dependencies(self, with_requires):
-        # type: (bool) -> Iterable[Optional[Requirement]]
+    def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]:
         factory = self.base._factory
 
         # Add a dependency on the exact base
@@ -530,8 +491,8 @@ class ExtrasCandidate(Candidate):
 
         # The user may have specified extras that the candidate doesn't
         # support. We ignore any unsupported extras here.
-        valid_extras = self.extras.intersection(self.base.dist.extras)
-        invalid_extras = self.extras.difference(self.base.dist.extras)
+        valid_extras = self.extras.intersection(self.base.dist.iter_provided_extras())
+        invalid_extras = self.extras.difference(self.base.dist.iter_provided_extras())
         for extra in sorted(invalid_extras):
             logger.warning(
                 "%s %s does not provide the extra '%s'",
@@ -540,15 +501,14 @@ class ExtrasCandidate(Candidate):
                 extra,
             )
 
-        for r in self.base.dist.requires(valid_extras):
+        for r in self.base.dist.iter_dependencies(valid_extras):
             requirement = factory.make_requirement_from_spec(
                 str(r), self.base._ireq, valid_extras
             )
             if requirement:
                 yield requirement
 
-    def get_install_requirement(self):
-        # type: () -> Optional[InstallRequirement]
+    def get_install_requirement(self) -> Optional[InstallRequirement]:
         # We don't return anything here, because we always
         # depend on the base candidate, and we'll get the
         # install requirement from that.
@@ -559,8 +519,7 @@ class RequiresPythonCandidate(Candidate):
     is_installed = False
     source_link = None
 
-    def __init__(self, py_version_info):
-        # type: (Optional[Tuple[int, ...]]) -> None
+    def __init__(self, py_version_info: Optional[Tuple[int, ...]]) -> None:
         if py_version_info is not None:
             version_info = normalize_version_info(py_version_info)
         else:
@@ -571,34 +530,26 @@ class RequiresPythonCandidate(Candidate):
     # only one RequiresPythonCandidate in a resolution, i.e. the host Python.
     # The built-in object.__eq__() and object.__ne__() do exactly what we want.
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return f"Python {self._version}"
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
-        # Avoid conflicting with the PyPI package "Python".
-        return cast(NormalizedName, "<Python from Requires-Python>")
+    def project_name(self) -> NormalizedName:
+        return REQUIRES_PYTHON_IDENTIFIER
 
     @property
-    def name(self):
-        # type: () -> str
-        return self.project_name
+    def name(self) -> str:
+        return REQUIRES_PYTHON_IDENTIFIER
 
     @property
-    def version(self):
-        # type: () -> CandidateVersion
+    def version(self) -> CandidateVersion:
         return self._version
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return f"Python {self.version}"
 
-    def iter_dependencies(self, with_requires):
-        # type: (bool) -> Iterable[Optional[Requirement]]
+    def iter_dependencies(self, with_requires: bool) -> Iterable[Optional[Requirement]]:
         return ()
 
-    def get_install_requirement(self):
-        # type: () -> Optional[InstallRequirement]
+    def get_install_requirement(self) -> Optional[InstallRequirement]:
         return None
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py
index 5816a0ed..0331297b 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/factory.py
@@ -9,6 +9,7 @@ from typing import (
     Iterator,
     List,
     Mapping,
+    NamedTuple,
     Optional,
     Sequence,
     Set,
@@ -18,35 +19,32 @@ from typing import (
 )
 
 from pip._vendor.packaging.requirements import InvalidRequirement
-from pip._vendor.packaging.requirements import Requirement as PackagingRequirement
 from pip._vendor.packaging.specifiers import SpecifierSet
 from pip._vendor.packaging.utils import NormalizedName, canonicalize_name
-from pip._vendor.pkg_resources import Distribution
 from pip._vendor.resolvelib import ResolutionImpossible
 
 from pip._internal.cache import CacheEntry, WheelCache
 from pip._internal.exceptions import (
     DistributionNotFound,
     InstallationError,
-    InstallationSubprocessError,
     MetadataInconsistent,
     UnsupportedPythonVersion,
     UnsupportedWheel,
 )
 from pip._internal.index.package_finder import PackageFinder
+from pip._internal.metadata import BaseDistribution, get_default_environment
 from pip._internal.models.link import Link
 from pip._internal.models.wheel import Wheel
 from pip._internal.operations.prepare import RequirementPreparer
 from pip._internal.req.constructors import install_req_from_link_and_ireq
-from pip._internal.req.req_install import InstallRequirement
+from pip._internal.req.req_install import (
+    InstallRequirement,
+    check_invalid_constraint_type,
+)
 from pip._internal.resolution.base import InstallRequirementProvider
 from pip._internal.utils.compatibility_tags import get_supported
 from pip._internal.utils.hashes import Hashes
-from pip._internal.utils.misc import (
-    dist_in_site_packages,
-    dist_in_usersite,
-    get_installed_distributions,
-)
+from pip._internal.utils.packaging import get_requirement
 from pip._internal.utils.virtualenv import running_under_virtualenv
 
 from .base import Candidate, CandidateVersion, Constraint, Requirement
@@ -81,20 +79,25 @@ C = TypeVar("C")
 Cache = Dict[Link, C]
 
 
+class CollectedRootRequirements(NamedTuple):
+    requirements: List[Requirement]
+    constraints: Dict[str, Constraint]
+    user_requested: Dict[str, int]
+
+
 class Factory:
     def __init__(
         self,
-        finder,  # type: PackageFinder
-        preparer,  # type: RequirementPreparer
-        make_install_req,  # type: InstallRequirementProvider
-        wheel_cache,  # type: Optional[WheelCache]
-        use_user_site,  # type: bool
-        force_reinstall,  # type: bool
-        ignore_installed,  # type: bool
-        ignore_requires_python,  # type: bool
-        py_version_info=None,  # type: Optional[Tuple[int, ...]]
-    ):
-        # type: (...) -> None
+        finder: PackageFinder,
+        preparer: RequirementPreparer,
+        make_install_req: InstallRequirementProvider,
+        wheel_cache: Optional[WheelCache],
+        use_user_site: bool,
+        force_reinstall: bool,
+        ignore_installed: bool,
+        ignore_requires_python: bool,
+        py_version_info: Optional[Tuple[int, ...]] = None,
+    ) -> None:
         self._finder = finder
         self.preparer = preparer
         self._wheel_cache = wheel_cache
@@ -104,27 +107,25 @@ class Factory:
         self._force_reinstall = force_reinstall
         self._ignore_requires_python = ignore_requires_python
 
-        self._build_failures = {}  # type: Cache[InstallationError]
-        self._link_candidate_cache = {}  # type: Cache[LinkCandidate]
-        self._editable_candidate_cache = {}  # type: Cache[EditableCandidate]
-        self._installed_candidate_cache = (
-            {}
-        )  # type: Dict[str, AlreadyInstalledCandidate]
-        self._extras_candidate_cache = (
-            {}
-        )  # type: Dict[Tuple[int, FrozenSet[str]], ExtrasCandidate]
+        self._build_failures: Cache[InstallationError] = {}
+        self._link_candidate_cache: Cache[LinkCandidate] = {}
+        self._editable_candidate_cache: Cache[EditableCandidate] = {}
+        self._installed_candidate_cache: Dict[str, AlreadyInstalledCandidate] = {}
+        self._extras_candidate_cache: Dict[
+            Tuple[int, FrozenSet[str]], ExtrasCandidate
+        ] = {}
 
         if not ignore_installed:
+            env = get_default_environment()
             self._installed_dists = {
-                canonicalize_name(dist.project_name): dist
-                for dist in get_installed_distributions(local_only=False)
+                dist.canonical_name: dist
+                for dist in env.iter_installed_distributions(local_only=False)
             }
         else:
             self._installed_dists = {}
 
     @property
-    def force_reinstall(self):
-        # type: () -> bool
+    def force_reinstall(self) -> bool:
         return self._force_reinstall
 
     def _fail_if_link_is_unsupported_wheel(self, link: Link) -> None:
@@ -136,8 +137,9 @@ class Factory:
         msg = f"{link.filename} is not a supported wheel on this platform."
         raise UnsupportedWheel(msg)
 
-    def _make_extras_candidate(self, base, extras):
-        # type: (BaseCandidate, FrozenSet[str]) -> ExtrasCandidate
+    def _make_extras_candidate(
+        self, base: BaseCandidate, extras: FrozenSet[str]
+    ) -> ExtrasCandidate:
         cache_key = (id(base), extras)
         try:
             candidate = self._extras_candidate_cache[cache_key]
@@ -148,29 +150,27 @@ class Factory:
 
     def _make_candidate_from_dist(
         self,
-        dist,  # type: Distribution
-        extras,  # type: FrozenSet[str]
-        template,  # type: InstallRequirement
-    ):
-        # type: (...) -> Candidate
+        dist: BaseDistribution,
+        extras: FrozenSet[str],
+        template: InstallRequirement,
+    ) -> Candidate:
         try:
-            base = self._installed_candidate_cache[dist.key]
+            base = self._installed_candidate_cache[dist.canonical_name]
         except KeyError:
             base = AlreadyInstalledCandidate(dist, template, factory=self)
-            self._installed_candidate_cache[dist.key] = base
+            self._installed_candidate_cache[dist.canonical_name] = base
         if not extras:
             return base
         return self._make_extras_candidate(base, extras)
 
     def _make_candidate_from_link(
         self,
-        link,  # type: Link
-        extras,  # type: FrozenSet[str]
-        template,  # type: InstallRequirement
-        name,  # type: Optional[NormalizedName]
-        version,  # type: Optional[CandidateVersion]
-    ):
-        # type: (...) -> Optional[Candidate]
+        link: Link,
+        extras: FrozenSet[str],
+        template: InstallRequirement,
+        name: Optional[NormalizedName],
+        version: Optional[CandidateVersion],
+    ) -> Optional[Candidate]:
         # TODO: Check already installed candidate, and use it if the link and
         # editable flag match.
 
@@ -189,11 +189,17 @@ class Factory:
                         name=name,
                         version=version,
                     )
-                except (InstallationSubprocessError, MetadataInconsistent) as e:
-                    logger.warning("Discarding %s. %s", link, e)
+                except MetadataInconsistent as e:
+                    logger.info(
+                        "Discarding [blue underline]%s[/]: [yellow]%s[reset]",
+                        link,
+                        e,
+                        extra={"markup": True},
+                    )
                     self._build_failures[link] = e
                     return None
-            base = self._editable_candidate_cache[link]  # type: BaseCandidate
+
+            base: BaseCandidate = self._editable_candidate_cache[link]
         else:
             if link not in self._link_candidate_cache:
                 try:
@@ -204,8 +210,13 @@ class Factory:
                         name=name,
                         version=version,
                     )
-                except (InstallationSubprocessError, MetadataInconsistent) as e:
-                    logger.warning("Discarding %s. %s", link, e)
+                except MetadataInconsistent as e:
+                    logger.info(
+                        "Discarding [blue underline]%s[/]: [yellow]%s[reset]",
+                        link,
+                        e,
+                        extra={"markup": True},
+                    )
                     self._build_failures[link] = e
                     return None
             base = self._link_candidate_cache[link]
@@ -233,7 +244,7 @@ class Factory:
         assert template.req, "Candidates found on index must be PEP 508"
         name = canonicalize_name(template.req.name)
 
-        extras = frozenset()  # type: FrozenSet[str]
+        extras: FrozenSet[str] = frozenset()
         for ireq in ireqs:
             assert ireq.req, "Candidates found on index must be PEP 508"
             specifier &= ireq.req.specifier
@@ -259,13 +270,12 @@ class Factory:
                 extras=extras,
                 template=template,
             )
-            # The candidate is a known incompatiblity. Don't use it.
+            # The candidate is a known incompatibility. Don't use it.
             if id(candidate) in incompatible_ids:
                 return None
             return candidate
 
-        def iter_index_candidate_infos():
-            # type: () -> Iterator[IndexCandidateInfo]
+        def iter_index_candidate_infos() -> Iterator[IndexCandidateInfo]:
             result = self._finder.find_best_candidate(
                 project_name=name,
                 specifier=specifier,
@@ -273,14 +283,27 @@ class Factory:
             )
             icans = list(result.iter_applicable())
 
-            # PEP 592: Yanked releases must be ignored unless only yanked
-            # releases can satisfy the version range. So if this is false,
-            # all yanked icans need to be skipped.
+            # PEP 592: Yanked releases are ignored unless the specifier
+            # explicitly pins a version (via '==' or '===') that can be
+            # solely satisfied by a yanked release.
             all_yanked = all(ican.link.is_yanked for ican in icans)
 
+            def is_pinned(specifier: SpecifierSet) -> bool:
+                for sp in specifier:
+                    if sp.operator == "===":
+                        return True
+                    if sp.operator != "==":
+                        continue
+                    if sp.version.endswith(".*"):
+                        continue
+                    return True
+                return False
+
+            pinned = is_pinned(specifier)
+
             # PackageFinder returns earlier versions first, so we reverse.
             for ican in reversed(icans):
-                if not all_yanked and ican.link.is_yanked:
+                if not (all_yanked and pinned) and ican.link.is_yanked:
                     continue
                 func = functools.partial(
                     self._make_candidate_from_link,
@@ -347,14 +370,14 @@ class Factory:
     def find_candidates(
         self,
         identifier: str,
-        requirements: Mapping[str, Iterator[Requirement]],
+        requirements: Mapping[str, Iterable[Requirement]],
         incompatibilities: Mapping[str, Iterator[Candidate]],
         constraint: Constraint,
         prefers_installed: bool,
     ) -> Iterable[Candidate]:
         # Collect basic lookup information from the requirements.
-        explicit_candidates = set()  # type: Set[Candidate]
-        ireqs = []  # type: List[InstallRequirement]
+        explicit_candidates: Set[Candidate] = set()
+        ireqs: List[InstallRequirement] = []
         for req in requirements[identifier]:
             cand, ireq = req.get_candidate_lookup()
             if cand is not None:
@@ -365,7 +388,7 @@ class Factory:
         # If the current identifier contains extras, add explicit candidates
         # from entries from extra-less identifier.
         with contextlib.suppress(InvalidRequirement):
-            parsed_requirement = PackagingRequirement(identifier)
+            parsed_requirement = get_requirement(identifier)
             explicit_candidates.update(
                 self._iter_explicit_candidates_from_base(
                     requirements.get(parsed_requirement.name, ()),
@@ -374,7 +397,7 @@ class Factory:
             )
 
         # Add explicit candidates from constraints. We only do this if there are
-        # kown ireqs, which represent requirements not already explicit. If
+        # known ireqs, which represent requirements not already explicit. If
         # there are no ireqs, we're constraining already-explicit requirements,
         # which is handled later when we return the explicit candidates.
         if ireqs:
@@ -414,8 +437,9 @@ class Factory:
             and all(req.is_satisfied_by(c) for req in requirements[identifier])
         )
 
-    def make_requirement_from_install_req(self, ireq, requested_extras):
-        # type: (InstallRequirement, Iterable[str]) -> Optional[Requirement]
+    def _make_requirement_from_install_req(
+        self, ireq: InstallRequirement, requested_extras: Iterable[str]
+    ) -> Optional[Requirement]:
         if not ireq.match_markers(requested_extras):
             logger.info(
                 "Ignoring %s: markers '%s' don't match your environment",
@@ -445,28 +469,64 @@ class Factory:
             return UnsatisfiableRequirement(canonicalize_name(ireq.name))
         return self.make_requirement_from_candidate(cand)
 
-    def make_requirement_from_candidate(self, candidate):
-        # type: (Candidate) -> ExplicitRequirement
+    def collect_root_requirements(
+        self, root_ireqs: List[InstallRequirement]
+    ) -> CollectedRootRequirements:
+        collected = CollectedRootRequirements([], {}, {})
+        for i, ireq in enumerate(root_ireqs):
+            if ireq.constraint:
+                # Ensure we only accept valid constraints
+                problem = check_invalid_constraint_type(ireq)
+                if problem:
+                    raise InstallationError(problem)
+                if not ireq.match_markers():
+                    continue
+                assert ireq.name, "Constraint must be named"
+                name = canonicalize_name(ireq.name)
+                if name in collected.constraints:
+                    collected.constraints[name] &= ireq
+                else:
+                    collected.constraints[name] = Constraint.from_ireq(ireq)
+            else:
+                req = self._make_requirement_from_install_req(
+                    ireq,
+                    requested_extras=(),
+                )
+                if req is None:
+                    continue
+                if ireq.user_supplied and req.name not in collected.user_requested:
+                    collected.user_requested[req.name] = i
+                collected.requirements.append(req)
+        return collected
+
+    def make_requirement_from_candidate(
+        self, candidate: Candidate
+    ) -> ExplicitRequirement:
         return ExplicitRequirement(candidate)
 
     def make_requirement_from_spec(
         self,
-        specifier,  # type: str
-        comes_from,  # type: InstallRequirement
-        requested_extras=(),  # type: Iterable[str]
-    ):
-        # type: (...) -> Optional[Requirement]
+        specifier: str,
+        comes_from: Optional[InstallRequirement],
+        requested_extras: Iterable[str] = (),
+    ) -> Optional[Requirement]:
         ireq = self._make_install_req_from_spec(specifier, comes_from)
-        return self.make_requirement_from_install_req(ireq, requested_extras)
+        return self._make_requirement_from_install_req(ireq, requested_extras)
 
-    def make_requires_python_requirement(self, specifier):
-        # type: (Optional[SpecifierSet]) -> Optional[Requirement]
-        if self._ignore_requires_python or specifier is None:
+    def make_requires_python_requirement(
+        self,
+        specifier: SpecifierSet,
+    ) -> Optional[Requirement]:
+        if self._ignore_requires_python:
+            return None
+        # Don't bother creating a dependency for an empty Requires-Python.
+        if not str(specifier):
             return None
         return RequiresPythonRequirement(specifier, self._python_candidate)
 
-    def get_wheel_cache_entry(self, link, name):
-        # type: (Link, Optional[str]) -> Optional[CacheEntry]
+    def get_wheel_cache_entry(
+        self, link: Link, name: Optional[str]
+    ) -> Optional[CacheEntry]:
         """Look up the link in the wheel cache.
 
         If ``preparer.require_hashes`` is True, don't use the wheel cache,
@@ -475,7 +535,7 @@ class Factory:
         hash mismatches. Furthermore, cached wheels at present have
         nondeterministic contents due to file modification times.
         """
-        if self._wheel_cache is None or self.preparer.require_hashes:
+        if self._wheel_cache is None:
             return None
         return self._wheel_cache.get_cache_entry(
             link=link,
@@ -483,8 +543,7 @@ class Factory:
             supported_tags=get_supported(),
         )
 
-    def get_dist_to_uninstall(self, candidate):
-        # type: (Candidate) -> Optional[Distribution]
+    def get_dist_to_uninstall(self, candidate: Candidate) -> Optional[BaseDistribution]:
         # TODO: Are there more cases this needs to return True? Editable?
         dist = self._installed_dists.get(candidate.project_name)
         if dist is None:  # Not installed, no uninstallation required.
@@ -497,25 +556,24 @@ class Factory:
             return dist
 
         # We're installing into user site. Remove the user site installation.
-        if dist_in_usersite(dist):
+        if dist.in_usersite:
             return dist
 
         # We're installing into user site, but the installed incompatible
         # package is in global site. We can't uninstall that, and would let
         # the new user installation to "shadow" it. But shadowing won't work
         # in virtual environments, so we error out.
-        if running_under_virtualenv() and dist_in_site_packages(dist):
-            raise InstallationError(
-                "Will not install to the user site because it will "
-                "lack sys.path precedence to {} in {}".format(
-                    dist.project_name,
-                    dist.location,
-                )
+        if running_under_virtualenv() and dist.in_site_packages:
+            message = (
+                f"Will not install to the user site because it will lack "
+                f"sys.path precedence to {dist.raw_name} in {dist.location}"
             )
+            raise InstallationError(message)
         return None
 
-    def _report_requires_python_error(self, causes):
-        # type: (Sequence[ConflictCause]) -> UnsupportedPythonVersion
+    def _report_requires_python_error(
+        self, causes: Sequence["ConflictCause"]
+    ) -> UnsupportedPythonVersion:
         assert causes, "Requires-Python error reported with no cause"
 
         version = self._python_candidate.version
@@ -535,32 +593,45 @@ class Factory:
             message += f"\n{specifier!r} (required by {package})"
         return UnsupportedPythonVersion(message)
 
-    def _report_single_requirement_conflict(self, req, parent):
-        # type: (Requirement, Optional[Candidate]) -> DistributionNotFound
+    def _report_single_requirement_conflict(
+        self, req: Requirement, parent: Optional[Candidate]
+    ) -> DistributionNotFound:
         if parent is None:
             req_disp = str(req)
         else:
             req_disp = f"{req} (from {parent.name})"
 
         cands = self._finder.find_all_candidates(req.project_name)
+        skipped_by_requires_python = self._finder.requires_python_skipped_reasons()
         versions = [str(v) for v in sorted({c.version for c in cands})]
 
+        if skipped_by_requires_python:
+            logger.critical(
+                "Ignored the following versions that require a different python "
+                "version: %s",
+                "; ".join(skipped_by_requires_python) or "none",
+            )
         logger.critical(
             "Could not find a version that satisfies the requirement %s "
             "(from versions: %s)",
             req_disp,
             ", ".join(versions) or "none",
         )
+        if str(req) == "requirements.txt":
+            logger.info(
+                "HINT: You are attempting to install a package literally "
+                'named "requirements.txt" (which cannot exist). Consider '
+                "using the '-r' flag to install the packages listed in "
+                "requirements.txt"
+            )
 
         return DistributionNotFound(f"No matching distribution found for {req}")
 
     def get_installation_error(
         self,
-        e,  # type: ResolutionImpossible[Requirement, Candidate]
-        constraints,  # type: Dict[str, Constraint]
-    ):
-        # type: (...) -> InstallationError
-
+        e: "ResolutionImpossible[Requirement, Candidate]",
+        constraints: Dict[str, Constraint],
+    ) -> InstallationError:
         assert e.causes, "Installation error reported with no cause"
 
         # If one of the things we can't solve is "we need Python X.Y",
@@ -573,7 +644,7 @@ class Factory:
         ]
         if requires_python_causes:
             # The comprehension above makes sure all Requirement instances are
-            # RequiresPythonRequirement, so let's cast for convinience.
+            # RequiresPythonRequirement, so let's cast for convenience.
             return self._report_requires_python_error(
                 cast("Sequence[ConflictCause]", requires_python_causes),
             )
@@ -592,15 +663,13 @@ class Factory:
         # satisfied at once.
 
         # A couple of formatting helpers
-        def text_join(parts):
-            # type: (List[str]) -> str
+        def text_join(parts: List[str]) -> str:
             if len(parts) == 1:
                 return parts[0]
 
             return ", ".join(parts[:-1]) + " and " + parts[-1]
 
-        def describe_trigger(parent):
-            # type: (Candidate) -> str
+        def describe_trigger(parent: Candidate) -> str:
             ireq = parent.get_install_requirement()
             if not ireq or not ireq.comes_from:
                 return f"{parent.name}=={parent.version}"
@@ -656,6 +725,6 @@ class Factory:
 
         return DistributionNotFound(
             "ResolutionImpossible: for help visit "
-            "https://pip.pypa.io/en/latest/user_guide/"
-            "#fixing-conflicting-dependencies"
+            "https://pip.pypa.io/en/latest/topics/dependency-resolution/"
+            "#dealing-with-dependency-conflicts"
         )
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py
index 21fa08ec..8663097b 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/found_candidates.py
@@ -9,24 +9,38 @@ something.
 """
 
 import functools
-from typing import Callable, Iterator, Optional, Set, Tuple
+from collections.abc import Sequence
+from typing import TYPE_CHECKING, Any, Callable, Iterator, Optional, Set, Tuple
 
 from pip._vendor.packaging.version import _BaseVersion
-from pip._vendor.six.moves import collections_abc  # type: ignore
 
 from .base import Candidate
 
 IndexCandidateInfo = Tuple[_BaseVersion, Callable[[], Optional[Candidate]]]
 
-
-def _iter_built(infos):
-    # type: (Iterator[IndexCandidateInfo]) -> Iterator[Candidate]
+if TYPE_CHECKING:
+    SequenceCandidate = Sequence[Candidate]
+else:
+    # For compatibility: Python before 3.9 does not support using [] on the
+    # Sequence class.
+    #
+    # >>> from collections.abc import Sequence
+    # >>> Sequence[str]
+    # Traceback (most recent call last):
+    #   File "<stdin>", line 1, in <module>
+    # TypeError: 'ABCMeta' object is not subscriptable
+    #
+    # TODO: Remove this block after dropping Python 3.8 support.
+    SequenceCandidate = Sequence
+
+
+def _iter_built(infos: Iterator[IndexCandidateInfo]) -> Iterator[Candidate]:
     """Iterator for ``FoundCandidates``.
 
     This iterator is used when the package is not already installed. Candidates
     from index come later in their normal ordering.
     """
-    versions_found = set()  # type: Set[_BaseVersion]
+    versions_found: Set[_BaseVersion] = set()
     for version, func in infos:
         if version in versions_found:
             continue
@@ -37,8 +51,9 @@ def _iter_built(infos):
         versions_found.add(version)
 
 
-def _iter_built_with_prepended(installed, infos):
-    # type: (Candidate, Iterator[IndexCandidateInfo]) -> Iterator[Candidate]
+def _iter_built_with_prepended(
+    installed: Candidate, infos: Iterator[IndexCandidateInfo]
+) -> Iterator[Candidate]:
     """Iterator for ``FoundCandidates``.
 
     This iterator is used when the resolver prefers the already-installed
@@ -47,7 +62,7 @@ def _iter_built_with_prepended(installed, infos):
     normal ordering, except skipped when the version is already installed.
     """
     yield installed
-    versions_found = {installed.version}  # type: Set[_BaseVersion]
+    versions_found: Set[_BaseVersion] = {installed.version}
     for version, func in infos:
         if version in versions_found:
             continue
@@ -58,8 +73,9 @@ def _iter_built_with_prepended(installed, infos):
         versions_found.add(version)
 
 
-def _iter_built_with_inserted(installed, infos):
-    # type: (Candidate, Iterator[IndexCandidateInfo]) -> Iterator[Candidate]
+def _iter_built_with_inserted(
+    installed: Candidate, infos: Iterator[IndexCandidateInfo]
+) -> Iterator[Candidate]:
     """Iterator for ``FoundCandidates``.
 
     This iterator is used when the resolver prefers to upgrade an
@@ -70,7 +86,7 @@ def _iter_built_with_inserted(installed, infos):
     the installed candidate exactly once before we start yielding older or
     equivalent candidates, or after all other candidates if they are all newer.
     """
-    versions_found = set()  # type: Set[_BaseVersion]
+    versions_found: Set[_BaseVersion] = set()
     for version, func in infos:
         if version in versions_found:
             continue
@@ -89,7 +105,7 @@ def _iter_built_with_inserted(installed, infos):
         yield installed
 
 
-class FoundCandidates(collections_abc.Sequence):
+class FoundCandidates(SequenceCandidate):
     """A lazy sequence to provide candidates to the resolver.
 
     The intended usage is to return this from `find_matches()` so the resolver
@@ -110,15 +126,13 @@ class FoundCandidates(collections_abc.Sequence):
         self._prefers_installed = prefers_installed
         self._incompatible_ids = incompatible_ids
 
-    def __getitem__(self, index):
-        # type: (int) -> Candidate
+    def __getitem__(self, index: Any) -> Any:
         # Implemented to satisfy the ABC check. This is not needed by the
         # resolver, and should not be used by the provider either (for
         # performance reasons).
         raise NotImplementedError("don't do this")
 
-    def __iter__(self):
-        # type: () -> Iterator[Candidate]
+    def __iter__(self) -> Iterator[Candidate]:
         infos = self._get_infos()
         if not self._installed:
             iterator = _iter_built(infos)
@@ -128,18 +142,14 @@ class FoundCandidates(collections_abc.Sequence):
             iterator = _iter_built_with_inserted(self._installed, infos)
         return (c for c in iterator if id(c) not in self._incompatible_ids)
 
-    def __len__(self):
-        # type: () -> int
+    def __len__(self) -> int:
         # Implemented to satisfy the ABC check. This is not needed by the
         # resolver, and should not be used by the provider either (for
         # performance reasons).
         raise NotImplementedError("don't do this")
 
     @functools.lru_cache(maxsize=1)
-    def __bool__(self):
-        # type: () -> bool
+    def __bool__(self) -> bool:
         if self._prefers_installed and self._installed:
             return True
         return any(self)
-
-    __nonzero__ = __bool__  # XXX: Python 2.
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py
index 0be58fd3..315fb9c8 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/provider.py
@@ -1,8 +1,20 @@
-from typing import TYPE_CHECKING, Dict, Iterable, Iterator, Mapping, Sequence, Union
+import collections
+import math
+from typing import (
+    TYPE_CHECKING,
+    Dict,
+    Iterable,
+    Iterator,
+    Mapping,
+    Sequence,
+    TypeVar,
+    Union,
+)
 
 from pip._vendor.resolvelib.providers import AbstractProvider
 
 from .base import Candidate, Constraint, Requirement
+from .candidates import REQUIRES_PYTHON_IDENTIFIER
 from .factory import Factory
 
 if TYPE_CHECKING:
@@ -34,6 +46,35 @@ else:
 # services to those objects (access to pip's finder and preparer).
 
 
+D = TypeVar("D")
+V = TypeVar("V")
+
+
+def _get_with_identifier(
+    mapping: Mapping[str, V],
+    identifier: str,
+    default: D,
+) -> Union[D, V]:
+    """Get item from a package name lookup mapping with a resolver identifier.
+
+    This extra logic is needed when the target mapping is keyed by package
+    name, which cannot be directly looked up with an identifier (which may
+    contain requested extras). Additional logic is added to also look up a value
+    by "cleaning up" the extras from the identifier.
+    """
+    if identifier in mapping:
+        return mapping[identifier]
+    # HACK: Theoretically we should check whether this identifier is a valid
+    # "NAME[EXTRAS]" format, and parse out the name part with packaging or
+    # some regular expression. But since pip's resolver only spits out three
+    # kinds of identifiers: normalized PEP 503 names, normalized names plus
+    # extras, and Requires-Python, we can cheat a bit here.
+    name, open_bracket, _ = identifier.partition("[")
+    if open_bracket and name in mapping:
+        return mapping[name]
+    return default
+
+
 class PipProvider(_ProviderBase):
     """Pip's provider implementation for resolvelib.
 
@@ -47,21 +88,20 @@ class PipProvider(_ProviderBase):
 
     def __init__(
         self,
-        factory,  # type: Factory
-        constraints,  # type: Dict[str, Constraint]
-        ignore_dependencies,  # type: bool
-        upgrade_strategy,  # type: str
-        user_requested,  # type: Dict[str, int]
-    ):
-        # type: (...) -> None
+        factory: Factory,
+        constraints: Dict[str, Constraint],
+        ignore_dependencies: bool,
+        upgrade_strategy: str,
+        user_requested: Dict[str, int],
+    ) -> None:
         self._factory = factory
         self._constraints = constraints
         self._ignore_dependencies = ignore_dependencies
         self._upgrade_strategy = upgrade_strategy
         self._user_requested = user_requested
+        self._known_depths: Dict[str, float] = collections.defaultdict(lambda: math.inf)
 
-    def identify(self, requirement_or_candidate):
-        # type: (Union[Requirement, Candidate]) -> str
+    def identify(self, requirement_or_candidate: Union[Requirement, Candidate]) -> str:
         return requirement_or_candidate.name
 
     def get_preference(
@@ -69,69 +109,91 @@ class PipProvider(_ProviderBase):
         identifier: str,
         resolutions: Mapping[str, Candidate],
         candidates: Mapping[str, Iterator[Candidate]],
-        information: Mapping[str, Iterator["PreferenceInformation"]],
+        information: Mapping[str, Iterable["PreferenceInformation"]],
+        backtrack_causes: Sequence["PreferenceInformation"],
     ) -> "Preference":
         """Produce a sort key for given requirement based on preference.
 
         The lower the return value is, the more preferred this group of
         arguments is.
 
-        Currently pip considers the followings in order:
-
-        * Prefer if any of the known requirements points to an explicit URL.
-        * If equal, prefer if any requirements contain ``===`` and ``==``.
-        * If equal, prefer if requirements include version constraints, e.g.
-          ``>=`` and ``<``.
-        * If equal, prefer user-specified (non-transitive) requirements, and
-          order user-specified requirements by the order they are specified.
+        Currently pip considers the following in order:
+
+        * Prefer if any of the known requirements is "direct", e.g. points to an
+          explicit URL.
+        * If equal, prefer if any requirement is "pinned", i.e. contains
+          operator ``===`` or ``==``.
+        * If equal, calculate an approximate "depth" and resolve requirements
+          closer to the user-specified requirements first. If the depth cannot
+          by determined (eg: due to no matching parents), it is considered
+          infinite.
+        * Order user-specified requirements by the order they are specified.
+        * If equal, prefers "non-free" requirements, i.e. contains at least one
+          operator, such as ``>=`` or ``<``.
         * If equal, order alphabetically for consistency (helps debuggability).
         """
-
-        def _get_restrictive_rating(requirements):
-            # type: (Iterable[Requirement]) -> int
-            """Rate how restrictive a set of requirements are.
-
-            ``Requirement.get_candidate_lookup()`` returns a 2-tuple for
-            lookup. The first element is ``Optional[Candidate]`` and the
-            second ``Optional[InstallRequirement]``.
-
-            * If the requirement is an explicit one, the explicitly-required
-              candidate is returned as the first element.
-            * If the requirement is based on a PEP 508 specifier, the backing
-              ``InstallRequirement`` is returned as the second element.
-
-            We use the first element to check whether there is an explicit
-            requirement, and the second for equality operator.
-            """
-            lookups = (r.get_candidate_lookup() for r in requirements)
-            cands, ireqs = zip(*lookups)
-            if any(cand is not None for cand in cands):
-                return 0
-            spec_sets = (ireq.specifier for ireq in ireqs if ireq)
-            operators = [
-                specifier.operator for spec_set in spec_sets for specifier in spec_set
-            ]
-            if any(op in ("==", "===") for op in operators):
-                return 1
-            if operators:
-                return 2
-            # A "bare" requirement without any version requirements.
-            return 3
-
-        rating = _get_restrictive_rating(r for r, _ in information[identifier])
-        order = self._user_requested.get(identifier, float("inf"))
-
-        # HACK: Setuptools have a very long and solid backward compatibility
-        # track record, and extremely few projects would request a narrow,
-        # non-recent version range of it since that would break a lot things.
-        # (Most projects specify it only to request for an installer feature,
-        # which does not work, but that's another topic.) Intentionally
-        # delaying Setuptools helps reduce branches the resolver has to check.
-        # This serves as a temporary fix for issues like "apache-airlfow[all]"
-        # while we work on "proper" branch pruning techniques.
-        delay_this = identifier == "setuptools"
-
-        return (delay_this, rating, order, identifier)
+        try:
+            next(iter(information[identifier]))
+        except StopIteration:
+            # There is no information for this identifier, so there's no known
+            # candidates.
+            has_information = False
+        else:
+            has_information = True
+
+        if has_information:
+            lookups = (r.get_candidate_lookup() for r, _ in information[identifier])
+            candidate, ireqs = zip(*lookups)
+        else:
+            candidate, ireqs = None, ()
+
+        operators = [
+            specifier.operator
+            for specifier_set in (ireq.specifier for ireq in ireqs if ireq)
+            for specifier in specifier_set
+        ]
+
+        direct = candidate is not None
+        pinned = any(op[:2] == "==" for op in operators)
+        unfree = bool(operators)
+
+        try:
+            requested_order: Union[int, float] = self._user_requested[identifier]
+        except KeyError:
+            requested_order = math.inf
+            if has_information:
+                parent_depths = (
+                    self._known_depths[parent.name] if parent is not None else 0.0
+                    for _, parent in information[identifier]
+                )
+                inferred_depth = min(d for d in parent_depths) + 1.0
+            else:
+                inferred_depth = math.inf
+        else:
+            inferred_depth = 1.0
+        self._known_depths[identifier] = inferred_depth
+
+        requested_order = self._user_requested.get(identifier, math.inf)
+
+        # Requires-Python has only one candidate and the check is basically
+        # free, so we always do it first to avoid needless work if it fails.
+        requires_python = identifier == REQUIRES_PYTHON_IDENTIFIER
+
+        # Prefer the causes of backtracking on the assumption that the problem
+        # resolving the dependency tree is related to the failures that caused
+        # the backtracking
+        backtrack_cause = self.is_backtrack_cause(identifier, backtrack_causes)
+
+        return (
+            not requires_python,
+            not direct,
+            not pinned,
+            not backtrack_cause,
+            inferred_depth,
+            requested_order,
+            not unfree,
+            identifier,
+        )
 
     def find_matches(
         self,
@@ -139,8 +201,7 @@ class PipProvider(_ProviderBase):
         requirements: Mapping[str, Iterator[Requirement]],
         incompatibilities: Mapping[str, Iterator[Candidate]],
     ) -> Iterable[Candidate]:
-        def _eligible_for_upgrade(name):
-            # type: (str) -> bool
+        def _eligible_for_upgrade(identifier: str) -> bool:
             """Are upgrades allowed for this project?
 
             This checks the upgrade strategy, and whether the project was one
@@ -154,22 +215,41 @@ class PipProvider(_ProviderBase):
             if self._upgrade_strategy == "eager":
                 return True
             elif self._upgrade_strategy == "only-if-needed":
-                return name in self._user_requested
+                user_order = _get_with_identifier(
+                    self._user_requested,
+                    identifier,
+                    default=None,
+                )
+                return user_order is not None
             return False
 
+        constraint = _get_with_identifier(
+            self._constraints,
+            identifier,
+            default=Constraint.empty(),
+        )
         return self._factory.find_candidates(
             identifier=identifier,
             requirements=requirements,
-            constraint=self._constraints.get(identifier, Constraint.empty()),
+            constraint=constraint,
             prefers_installed=(not _eligible_for_upgrade(identifier)),
             incompatibilities=incompatibilities,
         )
 
-    def is_satisfied_by(self, requirement, candidate):
-        # type: (Requirement, Candidate) -> bool
+    def is_satisfied_by(self, requirement: Requirement, candidate: Candidate) -> bool:
         return requirement.is_satisfied_by(candidate)
 
-    def get_dependencies(self, candidate):
-        # type: (Candidate) -> Sequence[Requirement]
+    def get_dependencies(self, candidate: Candidate) -> Sequence[Requirement]:
         with_requires = not self._ignore_dependencies
         return [r for r in candidate.iter_dependencies(with_requires) if r is not None]
+
+    @staticmethod
+    def is_backtrack_cause(
+        identifier: str, backtrack_causes: Sequence["PreferenceInformation"]
+    ) -> bool:
+        for backtrack_cause in backtrack_causes:
+            if identifier == backtrack_cause.requirement.name:
+                return True
+            if backtrack_cause.parent and identifier == backtrack_cause.parent.name:
+                return True
+        return False
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py
index 074583de..12adeff7 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/reporter.py
@@ -10,69 +10,71 @@ logger = getLogger(__name__)
 
 
 class PipReporter(BaseReporter):
-    def __init__(self):
-        # type: () -> None
-        self.backtracks_by_package = defaultdict(int)  # type: DefaultDict[str, int]
+    def __init__(self) -> None:
+        self.reject_count_by_package: DefaultDict[str, int] = defaultdict(int)
 
-        self._messages_at_backtrack = {
+        self._messages_at_reject_count = {
             1: (
                 "pip is looking at multiple versions of {package_name} to "
                 "determine which version is compatible with other "
                 "requirements. This could take a while."
             ),
             8: (
-                "pip is looking at multiple versions of {package_name} to "
+                "pip is still looking at multiple versions of {package_name} to "
                 "determine which version is compatible with other "
                 "requirements. This could take a while."
             ),
             13: (
                 "This is taking longer than usual. You might need to provide "
                 "the dependency resolver with stricter constraints to reduce "
-                "runtime. If you want to abort this run, you can press "
-                "Ctrl + C to do so. To improve how pip performs, tell us what "
-                "happened here: https://pip.pypa.io/surveys/backtracking"
+                "runtime. See https://pip.pypa.io/warnings/backtracking for "
+                "guidance. If you want to abort this run, press Ctrl + C."
             ),
         }
 
-    def backtracking(self, candidate):
-        # type: (Candidate) -> None
-        self.backtracks_by_package[candidate.name] += 1
+    def rejecting_candidate(self, criterion: Any, candidate: Candidate) -> None:
+        self.reject_count_by_package[candidate.name] += 1
 
-        count = self.backtracks_by_package[candidate.name]
-        if count not in self._messages_at_backtrack:
+        count = self.reject_count_by_package[candidate.name]
+        if count not in self._messages_at_reject_count:
             return
 
-        message = self._messages_at_backtrack[count]
+        message = self._messages_at_reject_count[count]
         logger.info("INFO: %s", message.format(package_name=candidate.name))
 
+        msg = "Will try a different candidate, due to conflict:"
+        for req_info in criterion.information:
+            req, parent = req_info.requirement, req_info.parent
+            # Inspired by Factory.get_installation_error
+            msg += "\n    "
+            if parent:
+                msg += f"{parent.name} {parent.version} depends on "
+            else:
+                msg += "The user requested "
+            msg += req.format_for_error()
+        logger.debug(msg)
+
 
 class PipDebuggingReporter(BaseReporter):
     """A reporter that does an info log for every event it sees."""
 
-    def starting(self):
-        # type: () -> None
+    def starting(self) -> None:
         logger.info("Reporter.starting()")
 
-    def starting_round(self, index):
-        # type: (int) -> None
+    def starting_round(self, index: int) -> None:
         logger.info("Reporter.starting_round(%r)", index)
 
-    def ending_round(self, index, state):
-        # type: (int, Any) -> None
+    def ending_round(self, index: int, state: Any) -> None:
         logger.info("Reporter.ending_round(%r, state)", index)
 
-    def ending(self, state):
-        # type: (Any) -> None
+    def ending(self, state: Any) -> None:
         logger.info("Reporter.ending(%r)", state)
 
-    def adding_requirement(self, requirement, parent):
-        # type: (Requirement, Candidate) -> None
+    def adding_requirement(self, requirement: Requirement, parent: Candidate) -> None:
         logger.info("Reporter.adding_requirement(%r, %r)", requirement, parent)
 
-    def backtracking(self, candidate):
-        # type: (Candidate) -> None
-        logger.info("Reporter.backtracking(%r)", candidate)
+    def rejecting_candidate(self, criterion: Any, candidate: Candidate) -> None:
+        logger.info("Reporter.rejecting_candidate(%r, %r)", criterion, candidate)
 
-    def pinning(self, candidate):
-        # type: (Candidate) -> None
+    def pinning(self, candidate: Candidate) -> None:
         logger.info("Reporter.pinning(%r)", candidate)
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py
index a7fcdd1e..06addc0d 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/requirements.py
@@ -7,78 +7,63 @@ from .base import Candidate, CandidateLookup, Requirement, format_name
 
 
 class ExplicitRequirement(Requirement):
-    def __init__(self, candidate):
-        # type: (Candidate) -> None
+    def __init__(self, candidate: Candidate) -> None:
         self.candidate = candidate
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return str(self.candidate)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}({candidate!r})".format(
             class_name=self.__class__.__name__,
             candidate=self.candidate,
         )
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
-        # No need to canonicalise - the candidate did this
+    def project_name(self) -> NormalizedName:
+        # No need to canonicalize - the candidate did this
         return self.candidate.project_name
 
     @property
-    def name(self):
-        # type: () -> str
-        # No need to canonicalise - the candidate did this
+    def name(self) -> str:
+        # No need to canonicalize - the candidate did this
         return self.candidate.name
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return self.candidate.format_for_error()
 
-    def get_candidate_lookup(self):
-        # type: () -> CandidateLookup
+    def get_candidate_lookup(self) -> CandidateLookup:
         return self.candidate, None
 
-    def is_satisfied_by(self, candidate):
-        # type: (Candidate) -> bool
+    def is_satisfied_by(self, candidate: Candidate) -> bool:
         return candidate == self.candidate
 
 
 class SpecifierRequirement(Requirement):
-    def __init__(self, ireq):
-        # type: (InstallRequirement) -> None
+    def __init__(self, ireq: InstallRequirement) -> None:
         assert ireq.link is None, "This is a link, not a specifier"
         self._ireq = ireq
         self._extras = frozenset(ireq.extras)
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return str(self._ireq.req)
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}({requirement!r})".format(
             class_name=self.__class__.__name__,
             requirement=str(self._ireq.req),
         )
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         assert self._ireq.req, "Specifier-backed ireq is always PEP 508"
         return canonicalize_name(self._ireq.req.name)
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         return format_name(self.project_name, self._extras)
 
-    def format_for_error(self):
-        # type: () -> str
-
+    def format_for_error(self) -> str:
         # Convert comma-separated specifiers into "A, B, ..., F and G"
         # This makes the specifier a bit more "human readable", without
         # risking a change in meaning. (Hopefully! Not all edge cases have
@@ -91,12 +76,10 @@ class SpecifierRequirement(Requirement):
 
         return ", ".join(parts[:-1]) + " and " + parts[-1]
 
-    def get_candidate_lookup(self):
-        # type: () -> CandidateLookup
+    def get_candidate_lookup(self) -> CandidateLookup:
         return None, self._ireq
 
-    def is_satisfied_by(self, candidate):
-        # type: (Candidate) -> bool
+    def is_satisfied_by(self, candidate: Candidate) -> bool:
         assert candidate.name == self.name, (
             f"Internal issue: Candidate is not for this requirement "
             f"{candidate.name} vs {self.name}"
@@ -112,44 +95,36 @@ class SpecifierRequirement(Requirement):
 class RequiresPythonRequirement(Requirement):
     """A requirement representing Requires-Python metadata."""
 
-    def __init__(self, specifier, match):
-        # type: (SpecifierSet, Candidate) -> None
+    def __init__(self, specifier: SpecifierSet, match: Candidate) -> None:
         self.specifier = specifier
         self._candidate = match
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return f"Python {self.specifier}"
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}({specifier!r})".format(
             class_name=self.__class__.__name__,
             specifier=str(self.specifier),
         )
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         return self._candidate.project_name
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         return self._candidate.name
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return str(self)
 
-    def get_candidate_lookup(self):
-        # type: () -> CandidateLookup
+    def get_candidate_lookup(self) -> CandidateLookup:
         if self.specifier.contains(self._candidate.version, prereleases=True):
             return self._candidate, None
         return None, None
 
-    def is_satisfied_by(self, candidate):
-        # type: (Candidate) -> bool
+    def is_satisfied_by(self, candidate: Candidate) -> bool:
         assert candidate.name == self._candidate.name, "Not Python candidate"
         # We can safely always allow prereleases here since PackageFinder
         # already implements the prerelease logic, and would have filtered out
@@ -160,39 +135,31 @@ class RequiresPythonRequirement(Requirement):
 class UnsatisfiableRequirement(Requirement):
     """A requirement that cannot be satisfied."""
 
-    def __init__(self, name):
-        # type: (NormalizedName) -> None
+    def __init__(self, name: NormalizedName) -> None:
         self._name = name
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return f"{self._name} (unavailable)"
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return "{class_name}({name!r})".format(
             class_name=self.__class__.__name__,
             name=str(self._name),
         )
 
     @property
-    def project_name(self):
-        # type: () -> NormalizedName
+    def project_name(self) -> NormalizedName:
         return self._name
 
     @property
-    def name(self):
-        # type: () -> str
+    def name(self) -> str:
         return self._name
 
-    def format_for_error(self):
-        # type: () -> str
+    def format_for_error(self) -> str:
         return str(self)
 
-    def get_candidate_lookup(self):
-        # type: () -> CandidateLookup
+    def get_candidate_lookup(self) -> CandidateLookup:
         return None, None
 
-    def is_satisfied_by(self, candidate):
-        # type: (Candidate) -> bool
+    def is_satisfied_by(self, candidate: Candidate) -> bool:
         return False
diff --git a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py
index b90f82cf..d5b23860 100644
--- a/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py
+++ b/env/Lib/site-packages/pip/_internal/resolution/resolvelib/resolver.py
@@ -4,19 +4,14 @@ import os
 from typing import TYPE_CHECKING, Dict, List, Optional, Set, Tuple, cast
 
 from pip._vendor.packaging.utils import canonicalize_name
-from pip._vendor.packaging.version import parse as parse_version
 from pip._vendor.resolvelib import BaseReporter, ResolutionImpossible
 from pip._vendor.resolvelib import Resolver as RLResolver
 from pip._vendor.resolvelib.structs import DirectedGraph
 
 from pip._internal.cache import WheelCache
-from pip._internal.exceptions import InstallationError
 from pip._internal.index.package_finder import PackageFinder
 from pip._internal.operations.prepare import RequirementPreparer
-from pip._internal.req.req_install import (
-    InstallRequirement,
-    check_invalid_constraint_type,
-)
+from pip._internal.req.req_install import InstallRequirement
 from pip._internal.req.req_set import RequirementSet
 from pip._internal.resolution.base import BaseResolver, InstallRequirementProvider
 from pip._internal.resolution.resolvelib.provider import PipProvider
@@ -24,11 +19,8 @@ from pip._internal.resolution.resolvelib.reporter import (
     PipDebuggingReporter,
     PipReporter,
 )
-from pip._internal.utils.deprecation import deprecated
-from pip._internal.utils.filetypes import is_archive_file
-from pip._internal.utils.misc import dist_is_editable
 
-from .base import Candidate, Constraint, Requirement
+from .base import Candidate, Requirement
 from .factory import Factory
 
 if TYPE_CHECKING:
@@ -45,17 +37,17 @@ class Resolver(BaseResolver):
 
     def __init__(
         self,
-        preparer,  # type: RequirementPreparer
-        finder,  # type: PackageFinder
-        wheel_cache,  # type: Optional[WheelCache]
-        make_install_req,  # type: InstallRequirementProvider
-        use_user_site,  # type: bool
-        ignore_dependencies,  # type: bool
-        ignore_installed,  # type: bool
-        ignore_requires_python,  # type: bool
-        force_reinstall,  # type: bool
-        upgrade_strategy,  # type: str
-        py_version_info=None,  # type: Optional[Tuple[int, ...]]
+        preparer: RequirementPreparer,
+        finder: PackageFinder,
+        wheel_cache: Optional[WheelCache],
+        make_install_req: InstallRequirementProvider,
+        use_user_site: bool,
+        ignore_dependencies: bool,
+        ignore_installed: bool,
+        ignore_requires_python: bool,
+        force_reinstall: bool,
+        upgrade_strategy: str,
+        py_version_info: Optional[Tuple[int, ...]] = None,
     ):
         super().__init__()
         assert upgrade_strategy in self._allowed_strategies
@@ -73,65 +65,38 @@ class Resolver(BaseResolver):
         )
         self.ignore_dependencies = ignore_dependencies
         self.upgrade_strategy = upgrade_strategy
-        self._result = None  # type: Optional[Result]
-
-    def resolve(self, root_reqs, check_supported_wheels):
-        # type: (List[InstallRequirement], bool) -> RequirementSet
-
-        constraints = {}  # type: Dict[str, Constraint]
-        user_requested = {}  # type: Dict[str, int]
-        requirements = []
-        for i, req in enumerate(root_reqs):
-            if req.constraint:
-                # Ensure we only accept valid constraints
-                problem = check_invalid_constraint_type(req)
-                if problem:
-                    raise InstallationError(problem)
-                if not req.match_markers():
-                    continue
-                assert req.name, "Constraint must be named"
-                name = canonicalize_name(req.name)
-                if name in constraints:
-                    constraints[name] &= req
-                else:
-                    constraints[name] = Constraint.from_ireq(req)
-            else:
-                if req.user_supplied and req.name:
-                    canonical_name = canonicalize_name(req.name)
-                    if canonical_name not in user_requested:
-                        user_requested[canonical_name] = i
-                r = self.factory.make_requirement_from_install_req(
-                    req, requested_extras=()
-                )
-                if r is not None:
-                    requirements.append(r)
+        self._result: Optional[Result] = None
 
+    def resolve(
+        self, root_reqs: List[InstallRequirement], check_supported_wheels: bool
+    ) -> RequirementSet:
+        collected = self.factory.collect_root_requirements(root_reqs)
         provider = PipProvider(
             factory=self.factory,
-            constraints=constraints,
+            constraints=collected.constraints,
             ignore_dependencies=self.ignore_dependencies,
             upgrade_strategy=self.upgrade_strategy,
-            user_requested=user_requested,
+            user_requested=collected.user_requested,
         )
         if "PIP_RESOLVER_DEBUG" in os.environ:
-            reporter = PipDebuggingReporter()  # type: BaseReporter
+            reporter: BaseReporter = PipDebuggingReporter()
         else:
             reporter = PipReporter()
-        resolver = RLResolver(
+        resolver: RLResolver[Requirement, Candidate, str] = RLResolver(
             provider,
             reporter,
-        )  # type: RLResolver[Requirement, Candidate, str]
+        )
 
         try:
-            try_to_avoid_resolution_too_deep = 2000000
+            limit_how_complex_resolution_can_be = 200000
             result = self._result = resolver.resolve(
-                requirements, max_rounds=try_to_avoid_resolution_too_deep
+                collected.requirements, max_rounds=limit_how_complex_resolution_can_be
             )
 
         except ResolutionImpossible as e:
             error = self.factory.get_installation_error(
                 cast("ResolutionImpossible[Requirement, Candidate]", e),
-                constraints,
+                collected.constraints,
             )
             raise error from e
 
@@ -150,10 +115,10 @@ class Resolver(BaseResolver):
             elif self.factory.force_reinstall:
                 # The --force-reinstall flag is set -- reinstall.
                 ireq.should_reinstall = True
-            elif parse_version(installed_dist.version) != candidate.version:
+            elif installed_dist.version != candidate.version:
                 # The installation is different in version -- reinstall.
                 ireq.should_reinstall = True
-            elif candidate.is_editable or dist_is_editable(installed_dist):
+            elif candidate.is_editable or installed_dist.editable:
                 # The incoming distribution is editable, or different in
                 # editable-ness to installation -- reinstall.
                 ireq.should_reinstall = True
@@ -169,25 +134,6 @@ class Resolver(BaseResolver):
                     )
                     continue
 
-                looks_like_sdist = (
-                    is_archive_file(candidate.source_link.file_path)
-                    and candidate.source_link.ext != ".zip"
-                )
-                if looks_like_sdist:
-                    # is a local sdist -- show a deprecation warning!
-                    reason = (
-                        "Source distribution is being reinstalled despite an "
-                        "installed package having the same name and version as "
-                        "the installed package."
-                    )
-                    replacement = "use --force-reinstall"
-                    deprecated(
-                        reason=reason,
-                        replacement=replacement,
-                        gone_in="21.2",
-                        issue=8711,
-                    )
-
                 # is a local sdist or path -- reinstall
                 ireq.should_reinstall = True
             else:
@@ -213,10 +159,14 @@ class Resolver(BaseResolver):
 
         reqs = req_set.all_requirements
         self.factory.preparer.prepare_linked_requirements_more(reqs)
+        for req in reqs:
+            req.prepared = True
+            req.needs_more_preparation = False
         return req_set
 
-    def get_installation_order(self, req_set):
-        # type: (RequirementSet) -> List[InstallRequirement]
+    def get_installation_order(
+        self, req_set: RequirementSet
+    ) -> List[InstallRequirement]:
         """Get order for installation of requirements in RequirementSet.
 
         The returned list contains a requirement before another that depends on
@@ -224,17 +174,19 @@ class Resolver(BaseResolver):
         get installed one-by-one.
 
         The current implementation creates a topological ordering of the
-        dependency graph, while breaking any cycles in the graph at arbitrary
-        points. We make no guarantees about where the cycle would be broken,
-        other than they would be broken.
+        dependency graph, giving more weight to packages with less
+        or no dependencies, while breaking any cycles in the graph at
+        arbitrary points. We make no guarantees about where the cycle
+        would be broken, other than it *would* be broken.
         """
         assert self._result is not None, "must call resolve() first"
 
+        if not req_set.requirements:
+            # Nothing is left to install, so we do not need an order.
+            return []
+
         graph = self._result.graph
-        weights = get_topological_weights(
-            graph,
-            expected_node_count=len(self._result.mapping) + 1,
-        )
+        weights = get_topological_weights(graph, set(req_set.requirements.keys()))
 
         sorted_items = sorted(
             req_set.requirements.items(),
@@ -244,29 +196,38 @@ class Resolver(BaseResolver):
         return [ireq for _, ireq in sorted_items]
 
 
-def get_topological_weights(graph, expected_node_count):
-    # type: (DirectedGraph[Optional[str]], int) -> Dict[Optional[str], int]
+def get_topological_weights(
+    graph: "DirectedGraph[Optional[str]]", requirement_keys: Set[str]
+) -> Dict[Optional[str], int]:
     """Assign weights to each node based on how "deep" they are.
 
     This implementation may change at any point in the future without prior
     notice.
 
-    We take the length for the longest path to any node from root, ignoring any
-    paths that contain a single node twice (i.e. cycles). This is done through
-    a depth-first search through the graph, while keeping track of the path to
-    the node.
+    We first simplify the dependency graph by pruning any leaves and giving them
+    the highest weight: a package without any dependencies should be installed
+    first. This is done again and again in the same way, giving ever less weight
+    to the newly found leaves. The loop stops when no leaves are left: all
+    remaining packages have at least one dependency left in the graph.
+
+    Then we continue with the remaining graph, by taking the length for the
+    longest path to any node from root, ignoring any paths that contain a single
+    node twice (i.e. cycles). This is done through a depth-first search through
+    the graph, while keeping track of the path to the node.
 
     Cycles in the graph result would result in node being revisited while also
-    being it's own path. In this case, take no action. This helps ensure we
+    being on its own path. In this case, take no action. This helps ensure we
     don't get stuck in a cycle.
 
     When assigning weight, the longer path (i.e. larger length) is preferred.
+
+    We are only interested in the weights of packages that are in the
+    requirement_keys.
     """
-    path = set()  # type: Set[Optional[str]]
-    weights = {}  # type: Dict[Optional[str], int]
+    path: Set[Optional[str]] = set()
+    weights: Dict[Optional[str], int] = {}
 
-    def visit(node):
-        # type: (Optional[str]) -> None
+    def visit(node: Optional[str]) -> None:
         if node in path:
             # We hit a cycle, so we'll break it here.
             return
@@ -277,24 +238,57 @@ def get_topological_weights(graph, expected_node_count):
             visit(child)
         path.remove(node)
 
+        if node not in requirement_keys:
+            return
+
         last_known_parent_count = weights.get(node, 0)
         weights[node] = max(last_known_parent_count, len(path))
 
+    # Simplify the graph, pruning leaves that have no dependencies.
+    # This is needed for large graphs (say over 200 packages) because the
+    # `visit` function is exponentially slower then, taking minutes.
+    # See https://github.com/pypa/pip/issues/10557
+    # We will loop until we explicitly break the loop.
+    while True:
+        leaves = set()
+        for key in graph:
+            if key is None:
+                continue
+            for _child in graph.iter_children(key):
+                # This means we have at least one child
+                break
+            else:
+                # No child.
+                leaves.add(key)
+        if not leaves:
+            # We are done simplifying.
+            break
+        # Calculate the weight for the leaves.
+        weight = len(graph) - 1
+        for leaf in leaves:
+            if leaf not in requirement_keys:
+                continue
+            weights[leaf] = weight
+        # Remove the leaves from the graph, making it simpler.
+        for leaf in leaves:
+            graph.remove(leaf)
+
+    # Visit the remaining graph.
     # `None` is guaranteed to be the root node by resolvelib.
     visit(None)
 
-    # Sanity checks
-    assert weights[None] == 0
-    assert len(weights) == expected_node_count
+    # Sanity check: all requirement keys should be in the weights,
+    # and no other keys should be in the weights.
+    difference = set(weights.keys()).difference(requirement_keys)
+    assert not difference, difference
 
     return weights
 
 
 def _req_set_item_sorter(
-    item,  # type: Tuple[str, InstallRequirement]
-    weights,  # type: Dict[Optional[str], int]
-):
-    # type: (...) -> Tuple[int, str]
+    item: Tuple[str, InstallRequirement],
+    weights: Dict[Optional[str], int],
+) -> Tuple[int, str]:
     """Key function used to sort install requirements for installation.
 
     Based on the "weight" mapping calculated in ``get_installation_order()``.
diff --git a/env/Lib/site-packages/pip/_internal/self_outdated_check.py b/env/Lib/site-packages/pip/_internal/self_outdated_check.py
index 6b24965b..41cc42c5 100644
--- a/env/Lib/site-packages/pip/_internal/self_outdated_check.py
+++ b/env/Lib/site-packages/pip/_internal/self_outdated_check.py
@@ -1,97 +1,149 @@
 import datetime
+import functools
 import hashlib
 import json
 import logging
 import optparse
 import os.path
 import sys
-from typing import Any, Dict
+from dataclasses import dataclass
+from typing import Any, Callable, Dict, Optional
 
 from pip._vendor.packaging.version import parse as parse_version
+from pip._vendor.rich.console import Group
+from pip._vendor.rich.markup import escape
+from pip._vendor.rich.text import Text
 
 from pip._internal.index.collector import LinkCollector
 from pip._internal.index.package_finder import PackageFinder
 from pip._internal.metadata import get_default_environment
+from pip._internal.metadata.base import DistributionVersion
 from pip._internal.models.selection_prefs import SelectionPreferences
 from pip._internal.network.session import PipSession
+from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.entrypoints import (
+    get_best_invocation_for_this_pip,
+    get_best_invocation_for_this_python,
+)
 from pip._internal.utils.filesystem import adjacent_tmp_file, check_path_owner, replace
 from pip._internal.utils.misc import ensure_dir
 
-SELFCHECK_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ"
+_DATE_FMT = "%Y-%m-%dT%H:%M:%SZ"
 
 
 logger = logging.getLogger(__name__)
 
 
-def _get_statefile_name(key):
-    # type: (str) -> str
+def _get_statefile_name(key: str) -> str:
     key_bytes = key.encode()
     name = hashlib.sha224(key_bytes).hexdigest()
     return name
 
 
 class SelfCheckState:
-    def __init__(self, cache_dir):
-        # type: (str) -> None
-        self.state = {}  # type: Dict[str, Any]
-        self.statefile_path = None
+    def __init__(self, cache_dir: str) -> None:
+        self._state: Dict[str, Any] = {}
+        self._statefile_path = None
 
         # Try to load the existing state
         if cache_dir:
-            self.statefile_path = os.path.join(
+            self._statefile_path = os.path.join(
                 cache_dir, "selfcheck", _get_statefile_name(self.key)
             )
             try:
-                with open(self.statefile_path, encoding="utf-8") as statefile:
-                    self.state = json.load(statefile)
+                with open(self._statefile_path, encoding="utf-8") as statefile:
+                    self._state = json.load(statefile)
             except (OSError, ValueError, KeyError):
                 # Explicitly suppressing exceptions, since we don't want to
                 # error out if the cache file is invalid.
                 pass
 
     @property
-    def key(self):
-        # type: () -> str
+    def key(self) -> str:
         return sys.prefix
 
-    def save(self, pypi_version, current_time):
-        # type: (str, datetime.datetime) -> None
+    def get(self, current_time: datetime.datetime) -> Optional[str]:
+        """Check if we have a not-outdated version loaded already."""
+        if not self._state:
+            return None
+
+        if "last_check" not in self._state:
+            return None
+
+        if "pypi_version" not in self._state:
+            return None
+
+        seven_days_in_seconds = 7 * 24 * 60 * 60
+
+        # Determine if we need to refresh the state
+        last_check = datetime.datetime.strptime(self._state["last_check"], _DATE_FMT)
+        seconds_since_last_check = (current_time - last_check).total_seconds()
+        if seconds_since_last_check > seven_days_in_seconds:
+            return None
+
+        return self._state["pypi_version"]
+
+    def set(self, pypi_version: str, current_time: datetime.datetime) -> None:
         # If we do not have a path to cache in, don't bother saving.
-        if not self.statefile_path:
+        if not self._statefile_path:
             return
 
         # Check to make sure that we own the directory
-        if not check_path_owner(os.path.dirname(self.statefile_path)):
+        if not check_path_owner(os.path.dirname(self._statefile_path)):
             return
 
         # Now that we've ensured the directory is owned by this user, we'll go
         # ahead and make sure that all our directories are created.
-        ensure_dir(os.path.dirname(self.statefile_path))
+        ensure_dir(os.path.dirname(self._statefile_path))
 
         state = {
             # Include the key so it's easy to tell which pip wrote the
             # file.
             "key": self.key,
-            "last_check": current_time.strftime(SELFCHECK_DATE_FMT),
+            "last_check": current_time.strftime(_DATE_FMT),
             "pypi_version": pypi_version,
         }
 
         text = json.dumps(state, sort_keys=True, separators=(",", ":"))
 
-        with adjacent_tmp_file(self.statefile_path) as f:
+        with adjacent_tmp_file(self._statefile_path) as f:
             f.write(text.encode())
 
         try:
             # Since we have a prefix-specific state file, we can just
             # overwrite whatever is there, no need to check.
-            replace(f.name, self.statefile_path)
+            replace(f.name, self._statefile_path)
         except OSError:
             # Best effort.
             pass
 
 
-def was_installed_by_pip(pkg):
-    # type: (str) -> bool
+@dataclass
+class UpgradePrompt:
+    old: str
+    new: str
+
+    def __rich__(self) -> Group:
+        if WINDOWS:
+            pip_cmd = f"{get_best_invocation_for_this_python()} -m pip"
+        else:
+            pip_cmd = get_best_invocation_for_this_pip()
+
+        notice = "[bold][[reset][blue]notice[reset][bold]][reset]"
+        return Group(
+            Text(),
+            Text.from_markup(
+                f"{notice} A new release of pip is available: "
+                f"[red]{self.old}[reset] -> [green]{self.new}[reset]"
+            ),
+            Text.from_markup(
+                f"{notice} To update, run: "
+                f"[green]{escape(pip_cmd)} install --upgrade pip"
+            ),
+        )
+
+
+def was_installed_by_pip(pkg: str) -> bool:
     """Checks whether pkg was installed by pip
 
     This is used not to display the upgrade message when pip is in fact
@@ -101,8 +153,69 @@ def was_installed_by_pip(pkg):
     return dist is not None and "pip" == dist.installer
 
 
-def pip_self_version_check(session, options):
-    # type: (PipSession, optparse.Values) -> None
+def _get_current_remote_pip_version(
+    session: PipSession, options: optparse.Values
+) -> Optional[str]:
+    # Lets use PackageFinder to see what the latest pip version is
+    link_collector = LinkCollector.create(
+        session,
+        options=options,
+        suppress_no_index=True,
+    )
+
+    # Pass allow_yanked=False so we don't suggest upgrading to a
+    # yanked version.
+    selection_prefs = SelectionPreferences(
+        allow_yanked=False,
+        allow_all_prereleases=False,  # Explicitly set to False
+    )
+
+    finder = PackageFinder.create(
+        link_collector=link_collector,
+        selection_prefs=selection_prefs,
+    )
+    best_candidate = finder.find_best_candidate("pip").best_candidate
+    if best_candidate is None:
+        return None
+
+    return str(best_candidate.version)
+
+
+def _self_version_check_logic(
+    *,
+    state: SelfCheckState,
+    current_time: datetime.datetime,
+    local_version: DistributionVersion,
+    get_remote_version: Callable[[], Optional[str]],
+) -> Optional[UpgradePrompt]:
+    remote_version_str = state.get(current_time)
+    if remote_version_str is None:
+        remote_version_str = get_remote_version()
+        if remote_version_str is None:
+            logger.debug("No remote pip version found")
+            return None
+        state.set(remote_version_str, current_time)
+
+    remote_version = parse_version(remote_version_str)
+    logger.debug("Remote version of pip: %s", remote_version)
+    logger.debug("Local version of pip:  %s", local_version)
+
+    pip_installed_by_pip = was_installed_by_pip("pip")
+    logger.debug("Was pip installed by pip? %s", pip_installed_by_pip)
+    if not pip_installed_by_pip:
+        return None  # Only suggest upgrade if pip is installed by pip.
+
+    local_version_is_older = (
+        local_version < remote_version
+        and local_version.base_version != remote_version.base_version
+    )
+    if local_version_is_older:
+        return UpgradePrompt(old=str(local_version), new=remote_version_str)
+
+    return None
+
+
+def pip_self_version_check(session: PipSession, options: optparse.Values) -> None:
     """Check for an update for pip.
 
     Limit the frequency of checks to once per week. State is stored either in
@@ -113,75 +226,17 @@ def pip_self_version_check(session, options):
     if not installed_dist:
         return
 
-    pip_version = installed_dist.version
-    pypi_version = None
-
     try:
-        state = SelfCheckState(cache_dir=options.cache_dir)
-
-        current_time = datetime.datetime.utcnow()
-        # Determine if we need to refresh the state
-        if "last_check" in state.state and "pypi_version" in state.state:
-            last_check = datetime.datetime.strptime(
-                state.state["last_check"],
-                SELFCHECK_DATE_FMT
-            )
-            if (current_time - last_check).total_seconds() < 7 * 24 * 60 * 60:
-                pypi_version = state.state["pypi_version"]
-
-        # Refresh the version if we need to or just see if we need to warn
-        if pypi_version is None:
-            # Lets use PackageFinder to see what the latest pip version is
-            link_collector = LinkCollector.create(
-                session,
-                options=options,
-                suppress_no_index=True,
-            )
-
-            # Pass allow_yanked=False so we don't suggest upgrading to a
-            # yanked version.
-            selection_prefs = SelectionPreferences(
-                allow_yanked=False,
-                allow_all_prereleases=False,  # Explicitly set to False
-            )
-
-            finder = PackageFinder.create(
-                link_collector=link_collector,
-                selection_prefs=selection_prefs,
-            )
-            best_candidate = finder.find_best_candidate("pip").best_candidate
-            if best_candidate is None:
-                return
-            pypi_version = str(best_candidate.version)
-
-            # save that we've performed a check
-            state.save(pypi_version, current_time)
-
-        remote_version = parse_version(pypi_version)
-
-        local_version_is_older = (
-            pip_version < remote_version and
-            pip_version.base_version != remote_version.base_version and
-            was_installed_by_pip('pip')
-        )
-
-        # Determine if our pypi_version is older
-        if not local_version_is_older:
-            return
-
-        # We cannot tell how the current pip is available in the current
-        # command context, so be pragmatic here and suggest the command
-        # that's always available. This does not accommodate spaces in
-        # `sys.executable`.
-        pip_cmd = f"{sys.executable} -m pip"
-        logger.warning(
-            "You are using pip version %s; however, version %s is "
-            "available.\nYou should consider upgrading via the "
-            "'%s install --upgrade pip' command.",
-            pip_version, pypi_version, pip_cmd
+        upgrade_prompt = _self_version_check_logic(
+            state=SelfCheckState(cache_dir=options.cache_dir),
+            current_time=datetime.datetime.utcnow(),
+            local_version=installed_dist.version,
+            get_remote_version=functools.partial(
+                _get_current_remote_pip_version, session, options
+            ),
         )
+        if upgrade_prompt is not None:
+            logger.warning("[present-rich] %s", upgrade_prompt)
     except Exception:
-        logger.debug(
-            "There was an error checking the latest version of pip",
-            exc_info=True,
-        )
+        logger.warning("There was an error checking the latest version of pip.")
+        logger.debug("See below for error", exc_info=True)
diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 2997301191e1b1b23f4222c74ddc7258de73b129..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 219
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<YH+rS
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOe7%qvMP
p%1g}AFD=Q;Db|mV&&<m#iI3MSsJz8tlbfGXnv-e=a@l8)4*;c^I<No$

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/appdirs.cpython-39.pyc
deleted file mode 100644
index fa92e190af6935c1655f39a0ffe775e7213df4c5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1284
zcmYe~<>g{vU|^UdaWM553j@Pr5C<7EGcYhXFfcF_J25aYq%cG=q%fv1<uFDurZA>3
z=P>0mM=>*k#8`4za#^F;7#UJnQ`lM<qS#Y-QaDmLTNtA_Qn*sMTNt7^Q<#DoG<mCj
za)o4M7Aqv@r=%*B7bO-HE0koUDwL(>rQ{c-rYIy96r^Mp6)WWCr<CTTDwO0a6z79g
z6s4Aw7Ue0FCFYc-7AqtcrE(?b=N2TEWG3aLDx~EXffXf}78RxDl_(Ts7C>xBN-R#*
z<Kha*NL9$pD@n~O$;{7F$Sek#Ta;Q}lv$Fh0Mk=ioS2?ktdL%mm{OXUlT)dqke!-Z
zkeQbbHn}9VxTIL2AhEbuhbu8JMIp5;HLnD$P9dczzd)e`<f+88lGGxF#GD)js9}jk
zsS3#%iFxU%DSBKlK>_Qh$#{#!C$qRjlkpZi)U(NqAQ>nIu~`@x7@R?&&d0#OP{NSK
zSOW@Ure078GW)q{GT!1$EGS4UEy>6)(qy{D5f3%!7GG&`YEgW0Vsb`md`e~!)Q-Hw
z+|-o}MH~za48Q7~tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1
z{QX>mJso3$U431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy?U5|gt*
z0T@$|S)d;e3hbi1#2o$7lFXc9eW?5N3Mz}(7#JA%L4IQbd6)^z4@m}dKmrU544^c}
z3JU=bq!6fKOkwI}u4O7=$YM%i&SoldDPhiHS-@Juw2-kF!e&chS;$z+RKoz3W3OSV
zVOYpi%TxmjJ61n8O{OAH=-y&4%1_MA%uBz;mXcUho|#w0Rj03)oS&DLnXa$NQ3SI8
z7C$63!GfURyv0^rSzMBudy6T*_!dh+VoAm=*39CR%%WRdsTBo@c_|?Ew^*|BGxIc=
zi`W?$7>Yo-s|e&>aOgt_PLKo-0|SEyC>THt1||VUF-9In7DhhCB9H(|iU5TT$UWc`
zVT2SODNHHMz09?Y;P7B6V=U6CVO+pm!ji?hkTHcdol%@2n4yL-oiUg}lg-a91m<<l
z+|rzqOpx<6nQpO`XXY6j6>&2#FjTSVr<NpZvOzr$iq&{Xh=4p_#LK|IaErCLASbh=
z2$U{wv4e~#PA$-60{itATS{h8Sz->vlc2;_1oG)E0W^b(6+qqw$%DMj#U#X7B+0<Q
zpvf4b$#si8K0YNsIX)g@16xTYC<7LOLf{s6L1uwoJfxr~0;LhKJHhD(9A;oskSqt;
g0C53_O)j`Ju><9;Vo><9aBwj4F!3;RuyXML0Ae>xK>z>%

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index 00817bf20d6db4842b9ce3ba876a0945676173be..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1486
zcmYe~<>g{vU|^UdaWJ)loq^#oh=Yuo85kHG7#J9evlti{QW&BbQW#U1au}l+!8B78
z6PRX>VoqmBVP3=-#gfXnfHjqEA!8JK3QG!W3quq~3R?<$3qurV215$RV#X-0ROT%1
z1w1L73mFSiK<pH*Y^MB_RHiK66z*)MD83Y?U<OT|D(~Qu(zG;%l8nR>g_O*+wA7+v
zh0HuCGc~V7A)vA(BR@}}EVZaOGe56bAu%sSp&%!*BrU%vmn$W+xTGjEsk8(nrS}r#
zB|lB(TRiEhCGiD`B^mLhnJKrpi%U{+GLzy9veS!iv4?y5x%h_%Cxg_&FcSj<0|x^G
zgEJ@yj2IXgs`yeEQy6j>Y8k>AKn`VLC}FHrU}ONnNQOKn15f}l=P>0m*D^9P)G!7!
zXtMYfF)}bPglIC};_(cQ4~X;+aP<og_R(ay#S&j!oO6rYGq)hWsKm9XD8J~IL_ubO
zUVK?<UP^wEUTINIPG*v^UTH~YP7x~u1A``05gP*o1DL&%p@@@#f#Fx3vsFxJacWU<
zOlnR_W>JiPUaCt`W?8C&u0p7vXP9eHuxE&4umZ?;ey+iujxoWmzOKO`u0aZBF#!QS
zF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylBsk#M;$=QkNsl_n`nFadsnRz9tMR|!i`XI*?
z>nG>u79^JF6;$40&qyqeFUcw91BDTYU|?cm<X~cB<Y8oE;$bS{W?*1Q2894DP(f)5
z<QZ_FCNVHDlrWSqrZ6@$6`7SVE?}x*C}GTEE@8}Kabj4=RLfYxxPY~WaUo+CTP;%w
z;{tXNn~@<;ql7VwV*zIk!$QX5fD*<9Tp$)mO&(tfcMZdAh7_i`OwEi<j5VP2#GI(f
z$iTp*prD`-lv+|+l&1hn1?t5LrI{&uTwrmR{M2HFy!;Y{wEUc${Bnij%G{jHyzF8t
zuq;StMoCFQv6a4ldS*#RX_8)Yey)B&WkI4oD0~V^b8_@8jZKwPGK-T-i$O^;zR1+r
zz}&#V7-D`vPGWLuib6?7X0bwAX<jlYX@XKTBqSA5N>dd|^5N+_Iki|JKTpBYGXj*b
z!A|f3CwLu5mMG51FU?6&NG(gvD=AIP$*ELG&sRt+PppLc#;PbWvpBU_!9N(BuB;To
zGg2X*R>&+?NQC)LA-_l=IWbSYL?J0vp(r&mMGtJ%EiV6fKYurWA0PklDt#0k)(YX7
zIXU2fDuRS$X=aK-T7D7C$YM<%aGFRgDJi<elwW*{CBGmw?-qxDe2|O3pHE~F4+8_k
zE!MQ+lEji*Y{ezutjL<2lV6;Aiv<)bx7ad^K_P#O1+0V}>IF^aA`y^IrnHn>9BG+3
zsUVHuEC3-u1z8a&!^(gXq5vqh@p3VWF!C_+F!M0+G4nBkW$i%8?-qM`ae8J^YT7N1
z#G>?q#G>NVTWkg3@V&)co|$)xIXNfu7E@k{CjTw=`1q9k<oNho>^b@A>6v-yMW94}
zi@CV67$ldNlM^3*i!(j7#3w&JJ+<f-M|^x<Vs2`D{4F++hSVZ(4glL-1h$(4R!ZIC
zDlSPZDk(0{EXlaV0@75(0?OT>Yz^@fm<96KEe@O9{FKt1R69^kDi&g3U|?b9VB}!r
QVB%orV&>rEP~>0%0G4^4O#lD@

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/compatibility_tags.cpython-39.pyc
deleted file mode 100644
index e8b73ef46e18441ca00f37a2447dde87cd82b284..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3862
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
WVB-+w5aZzC5aQtA;$mO~!#@D|tH;s+

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/datetime.cpython-39.pyc
deleted file mode 100644
index 5ae87dd241b31dc256f46cf157006f7374700288..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 490
zcmYe~<>g{vU|^UdaWM5i0|Ucj5C<7EF)%PVFfcF_OE54nq%cG=q%fv1<uFDurZA_l
zv@k?5r7#6EXtGx6x#brrlxL*oDHLQDD3mAWl@u$K<SQg+q$X!8lw_nTq$HN4D&!X_
zlw{_n>T$gU+2NPW45FZzm4Sf)gq=aQDKIcFlrUs5E?`>7P|IAxuz<0Kp@y-BX(4kh
zOAT`kOEya|gC?V&Ci5*0kij5BZ?S+_w^&Q^QxYpRS#PmarY08MV$IFZE6KRUoRU~s
z#KOS9aEmoPvn(}lB|{M>0|Uda24}07(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+uKhH4N
zpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~
z;>?m%-GapA?8Nlc;+TTW0{!^Rypq(Syu=*+(vr-aVttT9K~B~ysJtZ%c5i%UaePi<
zNorAiNk(EGJ17X)K;go~#mL80#Ld9KpvioTJw84qKRG_W2oxz`L9i!~2vA(!;;_lh
TPbtkwwPOSs1M)NrGY2yO5JP{Q

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/deprecation.cpython-39.pyc
deleted file mode 100644
index f87f203a1a780bafa8cdf38ab185f83a93683611..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2785
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
I66N3l0JTL9Q~&?~

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/direct_url_helpers.cpython-39.pyc
deleted file mode 100644
index d624dbad272b2a43a6082a5bbef9d23c32568e4a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2539
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
Y_ySb|JWM=H3LHF)JWO2791>hc00|_#m;e9(

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/distutils_args.cpython-39.pyc
deleted file mode 100644
index 22d93b2e905cf9ed1b6af5e7835d5f69efdfd641..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1084
zcmYe~<>g{vU|^UdaWM5A3j@Pr5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^Yc5+98zVzHLki0x#whkw=2Z4(#wd;y))clDhA7Sy_Fx80j+Y?w
zH5qRSx?~oYl$K=X6gw8ByA~DY7iluy;&w~SORjWJEy*t^(PX;C;*yzMa*M?$v$#Z)
zN0YgVC$%CqS+}4lH7&Ek*6$XBCUX^QMt*LptzQuv0|SW5o0(T!l9-dDo0M3LO*kd7
zBoU!n0H!)4H8CZ%s2Cx`1Cz<gOhSml)feO>mf(;nElR~MQ=D9sSx|yx2RqCoFvqhN
z<>!~cZM(%%TAW%0@mVq>DAb^sm4ShQlYxQ385A)d3=9mJ47H3k3@!|@R<%r3VkHb&
zj5SQ@j46!0j4@2L%(X1x40%E<3?)pJCX5Uq7|Bq`VZczsxPZBaC5vStBO^m0M-5{z
zgC<i|T|i<{ajHT=QGQuwN@|KiVo`c&Zfaghv5rDfYDsBPUS?jpLSmjmeo|Iya*0Ao
zMq-IVMq;r-Nk%G{f`WoVZemGt2C_aqF0i;`UZp~5UUpu7c^<+{g~Xy%h0OH4{G!wp
zJ+LxO##=0jMd`(wthWT?Q(y@sJ{_DOZm~h=B2cQl#a3F7l30>@iz7ZhB{R7sK3<cx
zh=YNF;TBs_YH?{!$t~u@qV!vg@wZsPZd%DuB*?(P@T<+)DkiizwWv5IH76yrD8@f8
z)ukx2ELA~QA=J+^%rz+3GsH1i!PC#h-_JGJ(=jI4)z>vR#5G94EG8hpCnnKEHzz+m
zv$!NPJ0>-+EXF4@DW*8HBvrQ{F*!RiJ+(NdAhSR}J~OW*wJ0w!M<1NR^$}hH`A)B(
z@|H*eD4>!22$GNl#i#%%n%P+xIT)E3#Ta>5*qHbji-Z{%82mK3ZVA9m(n|&9nPNy_
zh#`d2Ksg8+Vnxj004b>~$jnPGVqsulC;}y(TO9HE1tppJdBsJbbObgW96CsZ5J)G7
cO>TZlX-=vgDESqGiV7Y^9!3Es4nYoP0D@{N<^TWy

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/encoding.cpython-39.pyc
deleted file mode 100644
index 5f905df6bc2cc5f1a6aca28c3698c201a885b9fa..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1249
zcmYe~<>g{vU|^UdaWHim3j@Pr5C<7^FfcGUFfcF_H!(0Uq%fo~<}gG-XvQc;FrO)k
z2~0CbF{d!3Fy*l1vPQAyvPH2mGNdwOv8OPnF{LtOaip+-Y0eZ@FwK?12Bx`F*ugYU
z3I~|xP2o&qN@tJaOJ!QXpTf0}F-jnXJB6o(AxbcXF_=M<_a(@6ews|TSbQ>zOK!1-
zlosTqR<V|rr0H5zv4JQ<vnoyqt(%kzXXd0rWQ~m=LdHgLSz{yJoYZ151_p-Y{FKbR
z^k^&F*qCB1jcDDNa=ln>&16Q9olwlmz`y{)&Y(cq#K6E%!r;OXs}sXi%UH`)!?1v{
zhH)Wd5lan22~!PYGh+&4E0ZL{0_GZ~g^WxLj10jHg)B7;3s_Q^7BZ$VrZ9tKT^M3R
zYME=8Q&>`1LHrc9Y^EZY64nK5HOvbc5v*F48kQ8sQpVy6FNP+@8kPm@3mH;aK&Gd#
zFND~RY>!I~!vf|Kjs=`4919r>)|GHA;9khE5EO`<Rb9>*sma+2i3&-TC8@;<#U(|V
zdFcvi`9%te3QqpM3MKgp$@xV^smUcdl?o}TC8^0J3MCn-3aNRJAmZXuP*6~COU%hh
zN=(iMDbLAIPRvQwOHVB+C`wIBEh<V)fhpE-OUx-w)l|sI%uZFvFG$VP&{W9JQwXRm
z$;i($_WKM9Uapr+3=9lKAm&RD0Txug#hO^0oSEsS$#aXv$=^5l7FTgeVo^zPd1gt*
zE#{omyjyH3smb{%skc~*3vx0`ZgIQ%Is3bK`nkskx!z(cPE9OI&bY;vUX)*2P<)FG
z;>KGd*c^F_xwx|UmQZ?XNlI#3VrfnZ%=MbAw^&jVOA>D}C*|kf;(!U?V#&$OOTEQb
zlv-SxQ?inwNQ!}h;a7vRRZM7cYEf}aYEDXKQH+0Hs!LI3S*n7rLa3i-m}^k5XNY64
zf~TL0zn^Qcr(;a8tFLQth-;97Sxi8HPfVhTZccuBW^qYoc1&tsS&UC+QcQ7XNvdu^
zVsdt3dTMb@L1uw|d}dxrYEfQdj(%xLW=^p_%uRX)mAAMPOH1<OA)z7yN~02>gv-jq
z$i*nbB*rMk$i>LRD8wkh$igV_zet9Gfk9K~78@uGlZ%T485kIDF%_j234<7HC6xu4
zdFe&qm|+Hqa5(w<#)pQuS={1;vJA~`@xYn!POiv2A6K|CV<WhPu@SN|W21N<*CI}k
z;q1xzxdoXysYQIClmK!WI82cUX^=7wo80`A(wtN~P%<e7DdS*-Kmle54JCiFaB(pM
E03ae(Jpcdz

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/entrypoints.cpython-39.pyc
deleted file mode 100644
index 07ab05c6c17ce26a339cb64faf1c02702f886321..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1288
zcmYe~<>g{vU|^UdaWGYjg@NHQh=Yuo85kHG7#J9ejTjghQW#Pga~PsPG*b>^E>jd!
zE^`z!BZ$wO!;;Gy#mdN#!j{64!rH<Z#g@Vt%%I8s5@ed6CetkzpUmQtTO9rcC7Jno
zi8-2#w^(u$GxL%eK?<N4#0J^u46;##fq|ifA&YSVQwrlkMn;Ab<{E}(keN)0pBNb!
zoKy2kiV|}a%8L>U3Q~&{((;QG5_57C@^exYKvI<j`I&ho#d=&^3JMAe9+|}@`9+z@
zi8(oy3I&-33K@yT3K@wh3dN~qsUTyJv?!#cre)@(rsyd+r6wnq7N;uYrzvC>7ni0M
zgUw1T$}G;zOIJuM%Fk5@a18O#Q7En~)+<OX$<R^AEzK#(EXYY!2&gQ{$j>X*Q7Fks
z%`8&L%qvMPN=ycMzF0>gF)u|SH@~<9Y+imENKLLnMq(Mr*hH}VGV_W{5_57=Q*;zc
zi&Kk=6^cvK(o%~QK+dgHD9OxCRY=T3@~A?3Y6--7x%p+ODNt{R<b%Q_wJbBSBvqj#
zBePhcATcu!Vt+wVepzNpszRbdZfbHyVqRu(E;ta&6N~ad?toaEn3n=}WJ+dHYH|rk
zyd)zvSD_>yWPM^mK~a7|5!m#CoW$f*umKsVIR!cj<*5pJ`Q^~C1i3;XKMibBerXYU
zBq<~o!{V_RY(z;$szP#UQBi7Mi9&u}svcNlq6{MgL%3s*pQoR@6(o>~6_QdxZpzFn
z%g;_tQAnx;ISZ5oij#{n3rb+7>M4YPJYSxflcSK9n3<!HnWvDbkXBk!T9m3#mReMt
znV$!W<$}xtJ+6S9)WqUch2qpyg^ZGtf?_Lu{q)R|jM5~%<osOyg35wK{esK_eMpMX
zH#N1i1iLvgr7SZ!RUto5AuY24<S39QO7l`ui*hPKT(EjQE>M(|<!7cqqoXK4DJL~o
zp)$WzAvrNm0pby8;!!BiEXhz%*UbfaR$T#<BvKPoK<+Fm%>%~~C?!K;CZ|%5OOxdm
zb8%(yEw<v4l+>c4Tdd_pnI)-3EDQ_`pzM}dlwQ1&p@@@#f#FxPvsFweC|$**=A>j6
z#rWr?x)f!Wr7Gwug!*}gxdsJ$hByW*c>1~c`?&^tI>rRM`nm>(xCSYh#RLTS#3Y*N
z=H#bm7MEmZ$E4<!#rR|<#S~|jr0NzVCTAz6rxwS6f+!xG>hltF^h--JbBgtmGMQdM
z<t>hQXy#=H<#!HHA;8PV$n>9uqlg>qW<O2#B31?lhFfeUl?9o3=|xNo3=Bn}65^H^
yD5~J*>m}!8>Vb+AuxG)#!Tv-dK;_&m4x8Nkl+v73J4TR=Yzzzx9E<`?Jj?*@L5w~C

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/filesystem.cpython-39.pyc
deleted file mode 100644
index 0ab897ae70df52b983fb6e87b317b6445830dcd5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4958
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
Na&U8SaIkW40RW%Y)Uf~n

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/filetypes.cpython-39.pyc
deleted file mode 100644
index ff347931b644fbe420976179505f5db66e2c23ce..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 831
zcmYe~<>g{vU|^UdaWM5K69dCz5C<7EF)%PVFfcF_2QV-&q%cG=q%fv1<uK+lMKLjg
z*vvW1xhzpEj0`C(QLHJfQEVw}QS2$~sjO*CQ5-28QJkq9schm5shr{rsqEqmQCumU
zDO@cKQQRrq!3>%_Rbp<LIjJR;1*r;|d1?7Yxrrs2`FVO=FF|h5WW2>1Qd*Fcs>yhZ
zqqra^vm~{mq>4qaJR?Vwsft6dB(X>@smiE|MXw~ON|UvU9V}8&1rmUeIaN@>oT@5L
zuxw6MZekUSUR7p+CNoqn9jpODCKe?#f~<yOkncg*859Bv3=9k<3^feRj46zg3=0?+
zGSo8GFqSZtF%-$9Fa<NDFb6YevQ$|HrIwTy<tc;|m8L3WrYR)kCFZ6kC}b8ZBq}85
z=M`tBq!y*7C?pmuB<3k37A0q7mZd7BW#**ny#!eu;-<-5#LU3JaEmo3zdW_*mXKqR
zvxjGxYrJbjh^t?)r@vpYCetkzkg2zrQ!7eVG8Az#FfjaTbhe5KElw>ej!Df)$t;TT
z&r5YF0-3F=5bEa{<{A|28R8hM;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfO
zSzMBt9g~_@7UPqd6jPj8lB!#fn4F!Mo?0AJkXfJ~pP5&ZT9lWVqhDH*nNzF}ayTgZ
ziuDRAZ}Ddq$3uM-50VfA1sew_ESUuuIT%?Oi?|sW82mJOZn4M5r{pKc$KPTrsVvCM
zOD_V2@-2yi%mO{Q4SHZ3^l~$clOX}ZAMWAm>VpV}TYOGYMhI^3E#8PIWG-KnX8;O6
z#4!koU&O}1zyNj;H~^6dP?osGVUwGmQks)$2a1(qAqEBp7G@qM9wrt>7Dg6!kZ%N-
E0sWBQEC2ui

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/glibc.cpython-39.pyc
deleted file mode 100644
index 0a28d4e950dc2685cac33be4673a963912f0001e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1641
zcmYe~<>g{vU|^UdaWFNBhk@ZSh=Yuo7#J8F7#J9eT^JY`QW#Pga~Pr^G-DKF3PTE0
z4pT036mu?16bmCm3Udle3qurZ3Tp~m3qurJ3VRAi3qurp3TFye3quq~3S%&XCihE_
z`F@&Aw>bO@N;32F5_4{`hLjfMq$YzTkTD|z1A{ZjavlZ-h7yKmh61h<#%6|K22I8)
z%b?Vf(xSX#h4h@vq-2G%)S}|d{5*x?lA_GKbRC8KA_c$vyi|qEG=;qU5{1&@%)E4n
zQaw$kTQXox@lZ|i5KZyP`FUx@B}KQSvCEcJ7Ni!hWGG@|V1N+6YMrfOLW@(2iepl9
zQZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u
z5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-cvlG)(i(?8h3-seN^GZ^S@)C3OOG`3y
ziuJ*+(<`XFB?4xl`GOM^UZ7ZGU@qcdU|>KARFF6*zQKVCiqR5=EXEYZY^EZ<6sBN?
zDzOr#1<WbT3mF%%EM$mbs%5BU3}?ubVqqv@EnzERPh+mMV`KoqNCuF41BMz<jIvZY
z1QccFCKgpHWabv+q~@mPl_Y{<Rv|wP66R=bghoexu^u$Y^=`42XXY6j`P~wB4vu&C
z3yt^jbaIXdhoHZoCdV!2;>zM%90fUvC29FZxwn||i*K<*_1<DFF38C&xy9#LQc{$e
zR9ceiT2z!@bc@|T7{cHROUx;S2x>CjVvN7V4vlw2Oct?&;*^Dffq@?se0-op$j-&c
z!pOuV#wf(Z!B_;6LkUWd04RLHL0QDWz);1L!kEI8!%)i*&X6a<!cf9ksQ?NpMh19b
zF)Uz8VOq#o%UH!#!<fZf%LG-)Qt5@RGK;l_DW0u{shOdcxrDujxrC#csW`8Oc>yOV
zdTN<#n1dNKS*mQ^5_58r5|gt@3;ASlTGlH9WiY>6tck_RnVFhgx7Z-!x41oX3-XIf
zAi>At?Be5dOC&w7G(J7GBp#I8V9{A5z`($8iz7KcIU}(szTg&nQED;B<Xc>s#hH1<
zC5d^-skfLxS&A(sH90>eRg<Mi45US{peR2%wYWGwFEKZ@xF9h(wMY^q&JB$jP>w{8
z9aaVg21QWp$be#pg^7`ek%y6kjf;_qk&BUsnS+^wk&TIqk&CGaq!J~rK;8r;eQ;dK
zLCca_h8l(x#!`kNAy86IVXk3FV+v*f7f~!#lS7Is6-x3IQc_D&i*hsbQWZ)vQXy#>
zR@88DDJUo?z)GP+g%VH^21@ae(xg~HBPTOS2c}w6p*$lqIYS{OH7&6;rvzknYHmSE
zCA7dQ1{;={r;waj46!RGKR>&)Kp`zLGpAS&EDI_!8HzwbaEle3^EDa4Ib4(R7B83&
zj}~|d1y0wuIAC!W2ns$>qGe!bW8`3DVJcE#U|`VXEaC+ve{N6=u$5F6Wagz8fr6`u
z86*r+4^IBza0Tl?iW;z0pxkqd!zMRBr8Fni4wN&BK_xZ^BL|}ZGY1=o5QhN()l{ov

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/hashes.cpython-39.pyc
deleted file mode 100644
index 3726aca5e49fe4ee8a7d88b91f16c686416a02d1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/inject_securetransport.cpython-39.pyc
deleted file mode 100644
index e405e417c5547dc3244fcd9e8dfd977847221041..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 992
zcmYe~<>g{vU|^UdaWGYjnStRkh=Yuo7#J8F7#J9e<ro+kQW&BbQW#U1au}l+Q<zg&
zS{S03Qkj|=7#UKSf*CYf6LlFG7#tNcQgaGYixhJ6Q%ZAE6-qJ^OB6EmvQm>viWP!W
zlS_+ILy8jfiVO0KN^}(R^As|3K}<a^u8@pWC`X|<Bfm5!MIk9wAtgUARUxrhAvLim
zrxL^{$S*F=Ov*{sQ7Fk*NX;uQElO2L%*jzGN-Zo+EiNfmNX$#&Do!mf&dkp%R?x^V
zQYg<zEJ-a(Ez(p-EJ{^KE=o--Nlj5mOe;w(f;ucSFCE=!dR$z7`6W>2m!~S^=jBu?
zq~t4<fE)?-O=f-`$oaX6$^OAQ3gsE8d0@$$%)IQ>6b1i+)V$zeABD_fg_8VyuKb)7
zkb5%{^HOqB6+(Q1%MA65^tfJv!rCtxM8YsA#5oxl7@R?&Uc$h@P{NSKn8KLNT*Q~c
z5X?};lfsn3ki%5V5YCV%!opC(T&c&%0D_SWAbA6Z8ip*E6y|K!B0CVjN+5+Pg(ZhI
zm#vnO5u`@~q^E>Ejj1vXq>GUOu8(m6$3jqCGJxXJ?-pB1Vo`Z!UJ)Y$14Aai0E2)g
z<1PMTa0HgXB2bg_7ISfB@hy&moWzo}{G!}j%*Dkyx41pQaq3!BlwWj9%s;@@FF4pI
zKFl>J*wf!H-Y?YG$u;PfbU|i;UVK?<UP^wEUTINIPG*v^UUGh3Nl|7}5i<h=!!36I
zV2BaIkn|IunOBk@4^^tkRK&)>zyMaclA(x)fq~&ypR-j=XmM&$aZGAXN@h`ve_pCf
zQD#}Hg04cSpC{P<5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!kl
znAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mRIoGg6E45_9xROEPnc^`VYK3mUzG%3EUC
zrFcP6D+P*hW-dk+CMHH6Mjl2EC|iJ0fRTf#h>wARL6i9wdwhIKesX+#5evw#AVIKC
ckqD4sw>WHa!MV*26j{ZfaAD!(VCE190E5dGEdT%j

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/logging.cpython-39.pyc
deleted file mode 100644
index 275dd1841a21a89dadec9ec5c1bd5fe84a62fc85..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/misc.cpython-39.pyc
deleted file mode 100644
index d1d9cdd1045a77c3c7b91383a41f1d60575fea34..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/models.cpython-39.pyc
deleted file mode 100644
index 7e5658947d4e56549e61b81f2f7b8fcd5e0c8104..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1923
zcmYe~<>g{vU|^UdaWK`8m4V?gh=Yuo85kHG7#J9ejTjghQW&BbQW#U1au}l+Qy5d2
zbC`0OqnLA9qF8cSqgWXk+!<0>QdnCUQdparqS#WHf*CZ~s^mgTGIKIZGE<8c((;QG
zQc}}0^D^_&6>{@aQge#AUV?1%(`3HI?3h=1i^DlFCnqr}C-oLfNM%84GDs2`Gr^n_
z!N9<f$`Hkv!Vtxj!WhMz!j!_C&J@K0aX=Jn3R?<$3qurJ3P%cO3qurp3Renu3quq~
z3Qr1e3qurV3SSC;3qurFia?5B3qurlicpGh3qur7ibybnrsypZ@6<}C#NyNx=ltA)
z#G+K+%!<ssD)WG%{IblH)MABXuyAH^ex5>dVnJdO%!efzi6sh|#R^Fvy$bnx3W*BY
zsg<{Q;vpJR<3T+Bcvv9BC+8#<7bk-P8Rkn68{|u81_p*=0R{$!8paxic!nCL8ishr
z6oz1im5hFxOhs%A3=Bo=3=9mK%(qyIQ*+X8F@uceLp6CNLlF-H1H-R6XRDad;?$zz
znADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<7k@w3U{A-GU{_z);1Jg!1+$od
z0H2sd6WyHr^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P#PrnSn1aj#{rJqhlGLKS#2o$7
zlFXc9eMk)J6;$5hh>y?A%PfhH=LPwS1>{#IHpVJhY@w_NQ=7~PQU}E#Hau8BNw$Qc
zh9QfwnK785hyxT1Ot)Av5{omy0i(%S#0d%?kl(=pPz16U<O-0I_;?|ZD?p|(FyV9q
zL}fBq71RwNHpuPZsNn-e4Z{M48paaFET)A_Fn2KD;($f=Esp$x)S|?a{GwZI@$oq&
z@$oB}zz(~`nqQKUS_E+#*pVRj6$vviFo+>JO&Uk=fJ`F8VMT(VFah};?3~p2_#zRI
z2-pE&0_+Nq3#5o~MQVIJ#jZ#%!Ql#V1_lN>B3uD7fO1#h3JVDa1_mW!TtSVnNG-$>
z7Lp7M3~EHU0%QP2Spq6gzzG%<nkC@UB#W_`saT+dDHvR;WHHw;W-&Lz6EMpyuFT@h
zyyB9?yyR4H5p#>rFTcbyw;(4qH#M&$H3gE#n88W8NR)wr;TBtNYDq?Z3VMPDB{(gR
z!$GAL0}~G;3(ouoEg$_fc|qAUFEKYYKK>S0e0*+xN@)&=%@ZGASelpvm0^#MPsvY?
zkH5tkA77l4Us4<&Uj)jLMW7NBoRNw^>9`1#jEX?9SOf}0NDcrebp!!U^sEdF44`79
z7?dM87+IJ&m^fHDSP-xXq(YOuNCA{%AbF^yvLG`ry$Dn)6oEpy2vjzJ)ggrg*dCA-
Xw>WGdez5};WyPQnVPWQA6k!GcOKzja

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/packaging.cpython-39.pyc
deleted file mode 100644
index 41412e51b9b6baac7b12fd70ad64f779ecf6b91f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2547
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
Q!^p$L#mphbA;TdE0F#%^f&c&j

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/parallel.cpython-39.pyc
deleted file mode 100644
index 5ca6316e8195e4b8d041e10039cbaf0c7b5fba0b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/pkg_resources.cpython-39.pyc
deleted file mode 100644
index aab84fd75089bce6cde33da7db8cc0353125457d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1745
zcmYe~<>g{vU|^UdaWFNAg@NHQh=Yuo85kHG7#J9ejTjghQW#Pga~N_NqZo6UqL^}-
zqnH^%VoW(KxvWvFj12A!Da<J>Eet6v%}h~jDXhT^nrtsYrfD+YVsXh#F1f|wS&~|m
zn3R)xi^V6ixI~lj7I$T4YEDXgPG(+eaWY6PGG>C=?!myokjfCnn8Fanl)@OroWhjC
z+`<sWlERY0+QJaUn!=XC-og;Ymco(3*}@RTp2C&F-NF#Xk;0S0+rkjVnZlRC-@*{Z
zl_C(#pecBZ2jm#v)RM%M#FE4+J5LxhpeVmAGbOc1p(G=*M4>1(F{M}`7phDlEi)&z
zSRt(_KUX19Atf`pBr`uRv8Yln8RSZst3hlKb_RtRC}?XKYZ&4gQW%06Rx<jnWW2>0
z4>M4c=@v_IYEIfM4w%SFh9VvY28Lg)&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCw
zo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^
znMpClnI);Z1&PVoiRr1uF$I|g`tg~0C8<Sui8=bEC7C(J`UTnP@kOb{`K3k4sl|E)
zmA5$J<1_OzOXA}>L7oBmih-$06glYhU@8cQK^8+9Loh=TI|Bnl5eEYU!%C(iQ1IMh
z$xF;l1$!Gp@G>wk+~UbdEQW^@NTe8QyCjP3$f{6W07|tW)4{P2#K6E%B~ZhV#Zbd2
z$*_QNAwxJrFarxi2~(vHBSS3{BSV!+4HFAP7IO+?4dZNv6sEb%<_t^>@ytyO;S7-s
zDGaqtbxe6&5ZZvj034f|%zjlY3YmEdRjlBYp~+GN3Z`3ZDXGc%DXF)FLh~{~3>Prh
zwWuh+=oVX1YGQGIo+dNc>qP<}uQFnKK0UPr?s-8_(1X0fz{JETz{tlW##n_K2*|2Y
z0s$0cEDQ_`;6UJGU|=X=s9{*ZSi`uGv6&GX6`D*%te_YX0}=cn0+axeVnPVnct|dl
z0yzm}I0I9aJW70Es>N^+Bg{b{m!&WUGiWmTxk2p1W<4J)Ys6<3r(_n%Az3YrVl}Ed
z{MM$!6C&8N*z6U6o0pSWT#}Mmq=aO%EOwirDw9Ep4^|w2*r;Acu^XBaZgCeU7iAWd
z#Dns}Elv<wT#%TIkutc7O7r3&O4X3uBaY%8gc?6hZcrWu85bXaiz_}pH$SB`CpA9)
z7EgS9VQFFxRE9l1J|#anKE4Q)NQyuyt_YkS#6jsn0z^oH2pJFo4lx7)%9}-O3=9k)
zTntLk9E>bX94s6x9Gqa11uW~Q$$pEiq_QA0FTDtqa*9CVQUpo@w<HTP3-sd4Qu9*s
ii}X;6AV|st84O7usJ7nXuz`5T4ivt{AhSf6c$fiFAdSKR

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/setuptools_build.cpython-39.pyc
deleted file mode 100644
index 365c4f76fac72090814c87536d41df6dc9fed473..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/subprocess.cpython-39.pyc
deleted file mode 100644
index 2c6dc2f6699ca24d2cdb0ee868bed92452d0451a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/temp_dir.cpython-39.pyc
deleted file mode 100644
index 16fa511a9a099511408c14826654b5c322810b34..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/unpacking.cpython-39.pyc
deleted file mode 100644
index ca9359c8b90c0d2c0a3c74be2ba1572204c44d52..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6484
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
X=HTGq<q+WD;o#)p;L_&^W%vsKr`W+g

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/urls.cpython-39.pyc
deleted file mode 100644
index d14a48542989483ea7bfef2df4d02bf1cfb60b95..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1375
zcmYe~<>g{vU|^UdaWM4-3j@Pr5C<7EF)%PVFfcF_doVCCq%fo~<}gG-XvQc;FrO)k
z8BDW)X{H?3T(&4SMursT6qXi-DE1WA6t)(ID2^2N6pj{#D9#kdU<OUjmmoX*G#PJk
z_!pF9=I15mBr}49pcuqvVPIfz2HC6tvYD}lp^UMJCxs!Hp@v}rLkeRG(?X^cW=Vzx
zj0+ip88lh^elc3T1nDaR5t>Z5Sc?mCGD~i;=H!>B7HKlxVlFMpS;<hu!N9=qtH#+X
zCbT%Us5mAyCnd8e#y>CBr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6*EKlA
zHAulMCLq8kCecJUCqF&2xFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_#SGp{7I
zC@(QbzqBMXr&zzVD5qGjpz;=9dTL30X;DsmadJj#ZYsz{#cUv-GjTAoFcyI#1SK>;
zaR8DBhlU;l149Wz7UKdYFv(oQu#j;fV=Y4oOBU+_wiLz^mMr!K9AHtVTE-esXfsu1
za49G#C^+Zmm8BMyC?qNrB$i|-l;kTUDx_uRq*^J22KneID1>CBLS)J_b8-}tQWbI&
zQ&JTYlZx|mN=s4|67y0NG7`&D!Dbbf=9i?VK$I6G7L^q1frWpuf(_K<yv3AXe2WES
z&n=F;{Gwbii#;)^7|dWREy~HsOuEHdkXTfldW*fZC?_jFGw&9AQEFjnYH`Ue9+0xU
z#N1S)(xMzqrXpSj28JSb5CIA;a3mISGB7aQ;sz;<FUbdmCqF2)fC7qvO@vX5u}GAG
zfdM5TK}m`gmaHlm7@$dMA!D(W7efkD4a01v6y~|i&5TWqC5%~23&4RJ!&=K&%T&u;
z%UH`;!&GEb!<533%~a%+!dlCervwW26t--pqOcV98YXduTBba{61Ef$kXdt?peBJL
zgsFyEoM9njEprVsC<9b!fWr$BCE#!aMFb>XK;D7`X%ROA14ETzWPYhaa$=rBeqK(c
zLP=>+9yIDeiAo_euOuJL2L)NNf<|6`iNY^N&0Cx~`N@en8TrK}w-|1*mS^S}8&xsI
z#8g@2<>%>w<-ocWLW4Yu6%vb56+jw`OA89}i$JlPpQligky)%zkds)FmS2=>rJ%`q
zi>tT<6yN2UB^gBmpcoMZ#RCV(9pDVdTwGavivy<R7FSqePHC!ZQBi(TkuXRlPiaw(
z5y*QWw`#J0WAzqe{4KV;)RLV1WJpw_$1*6ll;p>Qv`K+tSq_w4SXmgE{<AT0{bOMf
zW8z_AW8`AuVq#+C_|L*3z*wZjz`&r%Rm1~wq72O9oXjLWaGC=<{T3f29qPf79a~9d
yL1tch5h%xj^C375fsKNsIW%{1*yQG?l;)(`fy$g>J_ZH`4n_#%Vdh}x;06G@A7nKE

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/virtualenv.cpython-39.pyc
deleted file mode 100644
index ece4546e838972f31df095ab232dbdca09b6d9e2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/utils/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index 1eeb051528b73b8f799f6df72632f70577d7db4b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5993
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
SfGCFqhcJf{2N#D3hadn%(m}xh

diff --git a/env/Lib/site-packages/pip/_internal/utils/appdirs.py b/env/Lib/site-packages/pip/_internal/utils/appdirs.py
index db974dad..16933bf8 100644
--- a/env/Lib/site-packages/pip/_internal/utils/appdirs.py
+++ b/env/Lib/site-packages/pip/_internal/utils/appdirs.py
@@ -7,32 +7,46 @@ and eventually drop this after all usages are changed.
 """
 
 import os
+import sys
 from typing import List
 
-from pip._vendor import appdirs as _appdirs
+from pip._vendor import platformdirs as _appdirs
 
 
-def user_cache_dir(appname):
-    # type: (str) -> str
+def user_cache_dir(appname: str) -> str:
     return _appdirs.user_cache_dir(appname, appauthor=False)
 
 
-def user_config_dir(appname, roaming=True):
-    # type: (str, bool) -> str
-    path = _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming)
-    if _appdirs.system == "darwin" and not os.path.isdir(path):
-        path = os.path.expanduser("~/.config/")
-        if appname:
-            path = os.path.join(path, appname)
-    return path
+def _macos_user_config_dir(appname: str, roaming: bool = True) -> str:
+    # Use ~/Application Support/pip, if the directory exists.
+    path = _appdirs.user_data_dir(appname, appauthor=False, roaming=roaming)
+    if os.path.isdir(path):
+        return path
+
+    # Use a Linux-like ~/.config/pip, by default.
+    linux_like_path = "~/.config/"
+    if appname:
+        linux_like_path = os.path.join(linux_like_path, appname)
+
+    return os.path.expanduser(linux_like_path)
+
+
+def user_config_dir(appname: str, roaming: bool = True) -> str:
+    if sys.platform == "darwin":
+        return _macos_user_config_dir(appname, roaming)
+
+    return _appdirs.user_config_dir(appname, appauthor=False, roaming=roaming)
 
 
 # for the discussion regarding site_config_dir locations
 # see <https://github.com/pypa/pip/issues/1733>
-def site_config_dirs(appname):
-    # type: (str) -> List[str]
+def site_config_dirs(appname: str) -> List[str]:
+    if sys.platform == "darwin":
+        return [_appdirs.site_data_dir(appname, appauthor=False, multipath=True)]
+
     dirval = _appdirs.site_config_dir(appname, appauthor=False, multipath=True)
-    if _appdirs.system not in ["win32", "darwin"]:
-        # always look in /etc directly as well
-        return dirval.split(os.pathsep) + ["/etc"]
-    return [dirval]
+    if sys.platform == "win32":
+        return [dirval]
+
+    # Unix-y system. Look in /etc as well.
+    return dirval.split(os.pathsep) + ["/etc"]
diff --git a/env/Lib/site-packages/pip/_internal/utils/compat.py b/env/Lib/site-packages/pip/_internal/utils/compat.py
index 1fb2dc72..3f4d300c 100644
--- a/env/Lib/site-packages/pip/_internal/utils/compat.py
+++ b/env/Lib/site-packages/pip/_internal/utils/compat.py
@@ -11,8 +11,7 @@ __all__ = ["get_path_uid", "stdlib_pkgs", "WINDOWS"]
 logger = logging.getLogger(__name__)
 
 
-def has_tls():
-    # type: () -> bool
+def has_tls() -> bool:
     try:
         import _ssl  # noqa: F401  # ignore unused
 
@@ -25,8 +24,7 @@ def has_tls():
     return IS_PYOPENSSL
 
 
-def get_path_uid(path):
-    # type: (str) -> int
+def get_path_uid(path: str) -> int:
     """
     Return path's uid.
 
diff --git a/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py b/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py
index 14fe51c1..b6ed9a78 100644
--- a/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py
+++ b/env/Lib/site-packages/pip/_internal/utils/compatibility_tags.py
@@ -2,9 +2,10 @@
 """
 
 import re
-from typing import TYPE_CHECKING, List, Optional, Tuple
+from typing import List, Optional, Tuple
 
 from pip._vendor.packaging.tags import (
+    PythonVersion,
     Tag,
     compatible_tags,
     cpython_tags,
@@ -14,21 +15,15 @@ from pip._vendor.packaging.tags import (
     mac_platforms,
 )
 
-if TYPE_CHECKING:
-    from pip._vendor.packaging.tags import PythonVersion
-
-
 _osx_arch_pat = re.compile(r"(.+)_(\d+)_(\d+)_(.+)")
 
 
-def version_info_to_nodot(version_info):
-    # type: (Tuple[int, ...]) -> str
+def version_info_to_nodot(version_info: Tuple[int, ...]) -> str:
     # Only use up to the first two numbers.
     return "".join(map(str, version_info[:2]))
 
 
-def _mac_platforms(arch):
-    # type: (str) -> List[str]
+def _mac_platforms(arch: str) -> List[str]:
     match = _osx_arch_pat.match(arch)
     if match:
         name, major, minor, actual_arch = match.groups()
@@ -48,8 +43,7 @@ def _mac_platforms(arch):
     return arches
 
 
-def _custom_manylinux_platforms(arch):
-    # type: (str) -> List[str]
+def _custom_manylinux_platforms(arch: str) -> List[str]:
     arches = [arch]
     arch_prefix, arch_sep, arch_suffix = arch.partition("_")
     if arch_prefix == "manylinux2014":
@@ -70,8 +64,7 @@ def _custom_manylinux_platforms(arch):
     return arches
 
 
-def _get_custom_platforms(arch):
-    # type: (str) -> List[str]
+def _get_custom_platforms(arch: str) -> List[str]:
     arch_prefix, arch_sep, arch_suffix = arch.partition("_")
     if arch.startswith("macosx"):
         arches = _mac_platforms(arch)
@@ -82,8 +75,7 @@ def _get_custom_platforms(arch):
     return arches
 
 
-def _expand_allowed_platforms(platforms):
-    # type: (Optional[List[str]]) -> Optional[List[str]]
+def _expand_allowed_platforms(platforms: Optional[List[str]]) -> Optional[List[str]]:
     if not platforms:
         return None
 
@@ -100,16 +92,16 @@ def _expand_allowed_platforms(platforms):
     return result
 
 
-def _get_python_version(version):
-    # type: (str) -> PythonVersion
+def _get_python_version(version: str) -> PythonVersion:
     if len(version) > 1:
         return int(version[0]), int(version[1:])
     else:
         return (int(version[0]),)
 
 
-def _get_custom_interpreter(implementation=None, version=None):
-    # type: (Optional[str], Optional[str]) -> str
+def _get_custom_interpreter(
+    implementation: Optional[str] = None, version: Optional[str] = None
+) -> str:
     if implementation is None:
         implementation = interpreter_name()
     if version is None:
@@ -118,12 +110,11 @@ def _get_custom_interpreter(implementation=None, version=None):
 
 
 def get_supported(
-    version=None,  # type: Optional[str]
-    platforms=None,  # type: Optional[List[str]]
-    impl=None,  # type: Optional[str]
-    abis=None,  # type: Optional[List[str]]
-):
-    # type: (...) -> List[Tag]
+    version: Optional[str] = None,
+    platforms: Optional[List[str]] = None,
+    impl: Optional[str] = None,
+    abis: Optional[List[str]] = None,
+) -> List[Tag]:
     """Return a list of supported tags for each version specified in
     `versions`.
 
@@ -136,9 +127,9 @@ def get_supported(
     :param abis: specify a list of abis you want valid
         tags for, or None. If None, use the local interpreter abi.
     """
-    supported = []  # type: List[Tag]
+    supported: List[Tag] = []
 
-    python_version = None  # type: Optional[PythonVersion]
+    python_version: Optional[PythonVersion] = None
     if version is not None:
         python_version = _get_python_version(version)
 
diff --git a/env/Lib/site-packages/pip/_internal/utils/datetime.py b/env/Lib/site-packages/pip/_internal/utils/datetime.py
index b638646c..8668b3b0 100644
--- a/env/Lib/site-packages/pip/_internal/utils/datetime.py
+++ b/env/Lib/site-packages/pip/_internal/utils/datetime.py
@@ -4,8 +4,7 @@
 import datetime
 
 
-def today_is_later_than(year, month, day):
-    # type: (int, int, int) -> bool
+def today_is_later_than(year: int, month: int, day: int) -> bool:
     today = datetime.date.today()
     given = datetime.date(year, month, day)
 
diff --git a/env/Lib/site-packages/pip/_internal/utils/deprecation.py b/env/Lib/site-packages/pip/_internal/utils/deprecation.py
index b62b3fb6..72bd6f25 100644
--- a/env/Lib/site-packages/pip/_internal/utils/deprecation.py
+++ b/env/Lib/site-packages/pip/_internal/utils/deprecation.py
@@ -8,7 +8,7 @@ from typing import Any, Optional, TextIO, Type, Union
 
 from pip._vendor.packaging.version import parse
 
-from pip import __version__ as current_version
+from pip import __version__ as current_version  # NOTE: tests patch this name.
 
 DEPRECATION_MSG_PREFIX = "DEPRECATION: "
 
@@ -17,19 +17,18 @@ class PipDeprecationWarning(Warning):
     pass
 
 
-_original_showwarning = None  # type: Any
+_original_showwarning: Any = None
 
 
 # Warnings <-> Logging Integration
 def _showwarning(
-    message,  # type: Union[Warning, str]
-    category,  # type: Type[Warning]
-    filename,  # type: str
-    lineno,  # type: int
-    file=None,  # type: Optional[TextIO]
-    line=None,  # type: Optional[str]
-):
-    # type: (...) -> None
+    message: Union[Warning, str],
+    category: Type[Warning],
+    filename: str,
+    lineno: int,
+    file: Optional[TextIO] = None,
+    line: Optional[str] = None,
+) -> None:
     if file is not None:
         if _original_showwarning is not None:
             _original_showwarning(message, category, filename, lineno, file, line)
@@ -42,8 +41,7 @@ def _showwarning(
         _original_showwarning(message, category, filename, lineno, file, line)
 
 
-def install_warning_logger():
-    # type: () -> None
+def install_warning_logger() -> None:
     # Enable our Deprecation Warnings
     warnings.simplefilter("default", PipDeprecationWarning, append=True)
 
@@ -54,49 +52,69 @@ def install_warning_logger():
         warnings.showwarning = _showwarning
 
 
-def deprecated(reason, replacement, gone_in, issue=None):
-    # type: (str, Optional[str], Optional[str], Optional[int]) -> None
+def deprecated(
+    *,
+    reason: str,
+    replacement: Optional[str],
+    gone_in: Optional[str],
+    feature_flag: Optional[str] = None,
+    issue: Optional[int] = None,
+) -> None:
     """Helper to deprecate existing functionality.
 
     reason:
         Textual reason shown to the user about why this functionality has
-        been deprecated.
+        been deprecated. Should be a complete sentence.
     replacement:
         Textual suggestion shown to the user about what alternative
         functionality they can use.
     gone_in:
         The version of pip does this functionality should get removed in.
-        Raises errors if pip's current version is greater than or equal to
+        Raises an error if pip's current version is greater than or equal to
         this.
+    feature_flag:
+        Command-line flag of the form --use-feature={feature_flag} for testing
+        upcoming functionality.
     issue:
         Issue number on the tracker that would serve as a useful place for
         users to find related discussion and provide feedback.
-
-    Always pass replacement, gone_in and issue as keyword arguments for clarity
-    at the call site.
     """
 
-    # Construct a nice message.
-    #   This is eagerly formatted as we want it to get logged as if someone
-    #   typed this entire message out.
-    sentences = [
-        (reason, DEPRECATION_MSG_PREFIX + "{}"),
-        (gone_in, "pip {} will remove support for this functionality."),
-        (replacement, "A possible replacement is {}."),
+    # Determine whether or not the feature is already gone in this version.
+    is_gone = gone_in is not None and parse(current_version) >= parse(gone_in)
+
+    message_parts = [
+        (reason, f"{DEPRECATION_MSG_PREFIX}{{}}"),
+        (
+            gone_in,
+            "pip {} will enforce this behaviour change."
+            if not is_gone
+            else "Since pip {}, this is no longer supported.",
+        ),
+        (
+            replacement,
+            "A possible replacement is {}.",
+        ),
+        (
+            feature_flag,
+            "You can use the flag --use-feature={} to test the upcoming behaviour."
+            if not is_gone
+            else None,
+        ),
         (
             issue,
-            (
-                "You can find discussion regarding this at "
-                "https://github.com/pypa/pip/issues/{}."
-            ),
+            "Discussion can be found at https://github.com/pypa/pip/issues/{}",
         ),
     ]
+
     message = " ".join(
-        template.format(val) for val, template in sentences if val is not None
+        format_str.format(value)
+        for value, format_str in message_parts
+        if format_str is not None and value is not None
     )
 
-    # Raise as an error if it has to be removed.
-    if gone_in is not None and parse(current_version) >= parse(gone_in):
+    # Raise as an error if this behaviour is deprecated.
+    if is_gone:
         raise PipDeprecationWarning(message)
 
     warnings.warn(message, category=PipDeprecationWarning, stacklevel=2)
diff --git a/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py b/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py
index eb50ac42..0e8e5e16 100644
--- a/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py
+++ b/env/Lib/site-packages/pip/_internal/utils/direct_url_helpers.py
@@ -1,25 +1,12 @@
-import json
-import logging
 from typing import Optional
 
-from pip._vendor.pkg_resources import Distribution
-
-from pip._internal.models.direct_url import (
-    DIRECT_URL_METADATA_NAME,
-    ArchiveInfo,
-    DirectUrl,
-    DirectUrlValidationError,
-    DirInfo,
-    VcsInfo,
-)
+from pip._internal.models.direct_url import ArchiveInfo, DirectUrl, DirInfo, VcsInfo
 from pip._internal.models.link import Link
+from pip._internal.utils.urls import path_to_url
 from pip._internal.vcs import vcs
 
-logger = logging.getLogger(__name__)
-
 
-def direct_url_as_pep440_direct_reference(direct_url, name):
-    # type: (DirectUrl, str) -> str
+def direct_url_as_pep440_direct_reference(direct_url: DirectUrl, name: str) -> str:
     """Convert a DirectUrl to a pip requirement string."""
     direct_url.validate()  # if invalid, this is a pip bug
     requirement = name + " @ "
@@ -42,8 +29,16 @@ def direct_url_as_pep440_direct_reference(direct_url, name):
     return requirement
 
 
-def direct_url_from_link(link, source_dir=None, link_is_in_wheel_cache=False):
-    # type: (Link, Optional[str], bool) -> DirectUrl
+def direct_url_for_editable(source_dir: str) -> DirectUrl:
+    return DirectUrl(
+        url=path_to_url(source_dir),
+        info=DirInfo(editable=True),
+    )
+
+
+def direct_url_from_link(
+    link: Link, source_dir: Optional[str] = None, link_is_in_wheel_cache: bool = False
+) -> DirectUrl:
     if link.is_vcs:
         vcs_backend = vcs.get_backend_for_scheme(link.scheme)
         assert vcs_backend
@@ -90,28 +85,3 @@ def direct_url_from_link(link, source_dir=None, link_is_in_wheel_cache=False):
             info=ArchiveInfo(hash=hash),
             subdirectory=link.subdirectory_fragment,
         )
-
-
-def dist_get_direct_url(dist):
-    # type: (Distribution) -> Optional[DirectUrl]
-    """Obtain a DirectUrl from a pkg_resource.Distribution.
-
-    Returns None if the distribution has no `direct_url.json` metadata,
-    or if `direct_url.json` is invalid.
-    """
-    if not dist.has_metadata(DIRECT_URL_METADATA_NAME):
-        return None
-    try:
-        return DirectUrl.from_json(dist.get_metadata(DIRECT_URL_METADATA_NAME))
-    except (
-        DirectUrlValidationError,
-        json.JSONDecodeError,
-        UnicodeDecodeError,
-    ) as e:
-        logger.warning(
-            "Error parsing %s for %s: %s",
-            DIRECT_URL_METADATA_NAME,
-            dist.project_name,
-            e,
-        )
-        return None
diff --git a/env/Lib/site-packages/pip/_internal/utils/distutils_args.py b/env/Lib/site-packages/pip/_internal/utils/distutils_args.py
deleted file mode 100644
index e886c888..00000000
--- a/env/Lib/site-packages/pip/_internal/utils/distutils_args.py
+++ /dev/null
@@ -1,43 +0,0 @@
-from distutils.errors import DistutilsArgError
-from distutils.fancy_getopt import FancyGetopt
-from typing import Dict, List
-
-_options = [
-    ("exec-prefix=", None, ""),
-    ("home=", None, ""),
-    ("install-base=", None, ""),
-    ("install-data=", None, ""),
-    ("install-headers=", None, ""),
-    ("install-lib=", None, ""),
-    ("install-platlib=", None, ""),
-    ("install-purelib=", None, ""),
-    ("install-scripts=", None, ""),
-    ("prefix=", None, ""),
-    ("root=", None, ""),
-    ("user", None, ""),
-]
-
-
-# typeshed doesn't permit Tuple[str, None, str], see python/typeshed#3469.
-_distutils_getopt = FancyGetopt(_options)  # type: ignore
-
-
-def parse_distutils_args(args):
-    # type: (List[str]) -> Dict[str, str]
-    """Parse provided arguments, returning an object that has the
-    matched arguments.
-
-    Any unknown arguments are ignored.
-    """
-    result = {}
-    for arg in args:
-        try:
-            _, match = _distutils_getopt.getopt(args=[arg])
-        except DistutilsArgError:
-            # We don't care about any other options, which here may be
-            # considered unrecognized since our option list is not
-            # exhaustive.
-            pass
-        else:
-            result.update(match.__dict__)
-    return result
diff --git a/env/Lib/site-packages/pip/_internal/utils/encoding.py b/env/Lib/site-packages/pip/_internal/utils/encoding.py
index 7c8893d5..008f06a7 100644
--- a/env/Lib/site-packages/pip/_internal/utils/encoding.py
+++ b/env/Lib/site-packages/pip/_internal/utils/encoding.py
@@ -4,7 +4,7 @@ import re
 import sys
 from typing import List, Tuple
 
-BOMS = [
+BOMS: List[Tuple[bytes, str]] = [
     (codecs.BOM_UTF8, "utf-8"),
     (codecs.BOM_UTF16, "utf-16"),
     (codecs.BOM_UTF16_BE, "utf-16-be"),
@@ -12,13 +12,12 @@ BOMS = [
     (codecs.BOM_UTF32, "utf-32"),
     (codecs.BOM_UTF32_BE, "utf-32-be"),
     (codecs.BOM_UTF32_LE, "utf-32-le"),
-]  # type: List[Tuple[bytes, str]]
+]
 
-ENCODING_RE = re.compile(br"coding[:=]\s*([-\w.]+)")
+ENCODING_RE = re.compile(rb"coding[:=]\s*([-\w.]+)")
 
 
-def auto_decode(data):
-    # type: (bytes) -> str
+def auto_decode(data: bytes) -> str:
     """Check a bytes string for a BOM to correctly detect the encoding
 
     Fallback to locale.getpreferredencoding(False) like open() on Python3"""
diff --git a/env/Lib/site-packages/pip/_internal/utils/entrypoints.py b/env/Lib/site-packages/pip/_internal/utils/entrypoints.py
index 879bf21a..15013693 100644
--- a/env/Lib/site-packages/pip/_internal/utils/entrypoints.py
+++ b/env/Lib/site-packages/pip/_internal/utils/entrypoints.py
@@ -1,11 +1,26 @@
+import itertools
+import os
+import shutil
 import sys
 from typing import List, Optional
 
 from pip._internal.cli.main import main
+from pip._internal.utils.compat import WINDOWS
 
+_EXECUTABLE_NAMES = [
+    "pip",
+    f"pip{sys.version_info.major}",
+    f"pip{sys.version_info.major}.{sys.version_info.minor}",
+]
+if WINDOWS:
+    _allowed_extensions = {"", ".exe"}
+    _EXECUTABLE_NAMES = [
+        "".join(parts)
+        for parts in itertools.product(_EXECUTABLE_NAMES, _allowed_extensions)
+    ]
 
-def _wrapper(args=None):
-    # type: (Optional[List[str]]) -> int
+
+def _wrapper(args: Optional[List[str]] = None) -> int:
     """Central wrapper for all old entrypoints.
 
     Historically pip has had several entrypoints defined. Because of issues
@@ -26,3 +41,44 @@ def _wrapper(args=None):
         "running pip directly.\n"
     )
     return main(args)
+
+
+def get_best_invocation_for_this_pip() -> str:
+    """Try to figure out the best way to invoke pip in the current environment."""
+    binary_directory = "Scripts" if WINDOWS else "bin"
+    binary_prefix = os.path.join(sys.prefix, binary_directory)
+
+    # Try to use pip[X[.Y]] names, if those executables for this environment are
+    # the first on PATH with that name.
+    path_parts = os.path.normcase(os.environ.get("PATH", "")).split(os.pathsep)
+    exe_are_in_PATH = os.path.normcase(binary_prefix) in path_parts
+    if exe_are_in_PATH:
+        for exe_name in _EXECUTABLE_NAMES:
+            found_executable = shutil.which(exe_name)
+            binary_executable = os.path.join(binary_prefix, exe_name)
+            if (
+                found_executable
+                and os.path.exists(binary_executable)
+                and os.path.samefile(
+                    found_executable,
+                    binary_executable,
+                )
+            ):
+                return exe_name
+
+    # Use the `-m` invocation, if there's no "nice" invocation.
+    return f"{get_best_invocation_for_this_python()} -m pip"
+
+
+def get_best_invocation_for_this_python() -> str:
+    """Try to figure out the best way to invoke the current Python."""
+    exe = sys.executable
+    exe_name = os.path.basename(exe)
+
+    # Try to use the basename, if it's the first executable.
+    found_executable = shutil.which(exe_name)
+    if found_executable and os.path.samefile(found_executable, exe):
+        return exe_name
+
+    # Use the full executable name, because we couldn't find something simpler.
+    return exe
diff --git a/env/Lib/site-packages/pip/_internal/utils/filesystem.py b/env/Lib/site-packages/pip/_internal/utils/filesystem.py
index 3db97dc4..83c2df75 100644
--- a/env/Lib/site-packages/pip/_internal/utils/filesystem.py
+++ b/env/Lib/site-packages/pip/_internal/utils/filesystem.py
@@ -2,12 +2,10 @@ import fnmatch
 import os
 import os.path
 import random
-import shutil
-import stat
 import sys
 from contextlib import contextmanager
 from tempfile import NamedTemporaryFile
-from typing import Any, BinaryIO, Iterator, List, Union, cast
+from typing import Any, BinaryIO, Generator, List, Union, cast
 
 from pip._vendor.tenacity import retry, stop_after_delay, wait_fixed
 
@@ -15,8 +13,7 @@ from pip._internal.utils.compat import get_path_uid
 from pip._internal.utils.misc import format_size
 
 
-def check_path_owner(path):
-    # type: (str) -> bool
+def check_path_owner(path: str) -> bool:
     # If we don't have a way to check the effective uid of this process, then
     # we'll just assume that we own the directory.
     if sys.platform == "win32" or not hasattr(os, "geteuid"):
@@ -43,38 +40,8 @@ def check_path_owner(path):
     return False  # assume we don't own the path
 
 
-def copy2_fixed(src, dest):
-    # type: (str, str) -> None
-    """Wrap shutil.copy2() but map errors copying socket files to
-    SpecialFileError as expected.
-
-    See also https://bugs.python.org/issue37700.
-    """
-    try:
-        shutil.copy2(src, dest)
-    except OSError:
-        for f in [src, dest]:
-            try:
-                is_socket_file = is_socket(f)
-            except OSError:
-                # An error has already occurred. Another error here is not
-                # a problem and we can ignore it.
-                pass
-            else:
-                if is_socket_file:
-                    raise shutil.SpecialFileError(f"`{f}` is a socket")
-
-        raise
-
-
-def is_socket(path):
-    # type: (str) -> bool
-    return stat.S_ISSOCK(os.lstat(path).st_mode)
-
-
 @contextmanager
-def adjacent_tmp_file(path, **kwargs):
-    # type: (str, **Any) -> Iterator[BinaryIO]
+def adjacent_tmp_file(path: str, **kwargs: Any) -> Generator[BinaryIO, None, None]:
     """Return a file-like object pointing to a tmp file next to path.
 
     The file is created securely and is ensured to be written to disk
@@ -98,7 +65,7 @@ def adjacent_tmp_file(path, **kwargs):
             os.fsync(result.fileno())
 
 
-# Tenacity raises RetryError by default, explictly raise the original exception
+# Tenacity raises RetryError by default, explicitly raise the original exception
 _replace_retry = retry(reraise=True, stop=stop_after_delay(1), wait=wait_fixed(0.25))
 
 replace = _replace_retry(os.replace)
@@ -106,8 +73,7 @@ replace = _replace_retry(os.replace)
 
 # test_writable_dir and _test_writable_dir_win are copied from Flit,
 # with the author's agreement to also place them under pip's license.
-def test_writable_dir(path):
-    # type: (str) -> bool
+def test_writable_dir(path: str) -> bool:
     """Check if a directory is writable.
 
     Uses os.access() on POSIX, tries creating files on Windows.
@@ -125,8 +91,7 @@ def test_writable_dir(path):
     return _test_writable_dir_win(path)
 
 
-def _test_writable_dir_win(path):
-    # type: (str) -> bool
+def _test_writable_dir_win(path: str) -> bool:
     # os.access doesn't work on Windows: http://bugs.python.org/issue2528
     # and we can't use tempfile: http://bugs.python.org/issue22107
     basename = "accesstest_deleteme_fishfingers_custard_"
@@ -154,32 +119,28 @@ def _test_writable_dir_win(path):
     raise OSError("Unexpected condition testing for writable directory")
 
 
-def find_files(path, pattern):
-    # type: (str, str) -> List[str]
+def find_files(path: str, pattern: str) -> List[str]:
     """Returns a list of absolute paths of files beneath path, recursively,
     with filenames which match the UNIX-style shell glob pattern."""
-    result = []  # type: List[str]
+    result: List[str] = []
     for root, _, files in os.walk(path):
         matches = fnmatch.filter(files, pattern)
         result.extend(os.path.join(root, f) for f in matches)
     return result
 
 
-def file_size(path):
-    # type: (str) -> Union[int, float]
+def file_size(path: str) -> Union[int, float]:
     # If it's a symlink, return 0.
     if os.path.islink(path):
         return 0
     return os.path.getsize(path)
 
 
-def format_file_size(path):
-    # type: (str) -> str
+def format_file_size(path: str) -> str:
     return format_size(file_size(path))
 
 
-def directory_size(path):
-    # type: (str) -> Union[int, float]
+def directory_size(path: str) -> Union[int, float]:
     size = 0.0
     for root, _dirs, files in os.walk(path):
         for filename in files:
@@ -188,6 +149,5 @@ def directory_size(path):
     return size
 
 
-def format_directory_size(path):
-    # type: (str) -> str
+def format_directory_size(path: str) -> str:
     return format_size(directory_size(path))
diff --git a/env/Lib/site-packages/pip/_internal/utils/filetypes.py b/env/Lib/site-packages/pip/_internal/utils/filetypes.py
index da935846..59485701 100644
--- a/env/Lib/site-packages/pip/_internal/utils/filetypes.py
+++ b/env/Lib/site-packages/pip/_internal/utils/filetypes.py
@@ -6,21 +6,20 @@ from typing import Tuple
 from pip._internal.utils.misc import splitext
 
 WHEEL_EXTENSION = ".whl"
-BZ2_EXTENSIONS = (".tar.bz2", ".tbz")  # type: Tuple[str, ...]
-XZ_EXTENSIONS = (
+BZ2_EXTENSIONS: Tuple[str, ...] = (".tar.bz2", ".tbz")
+XZ_EXTENSIONS: Tuple[str, ...] = (
     ".tar.xz",
     ".txz",
     ".tlz",
     ".tar.lz",
     ".tar.lzma",
-)  # type: Tuple[str, ...]
-ZIP_EXTENSIONS = (".zip", WHEEL_EXTENSION)  # type: Tuple[str, ...]
-TAR_EXTENSIONS = (".tar.gz", ".tgz", ".tar")  # type: Tuple[str, ...]
+)
+ZIP_EXTENSIONS: Tuple[str, ...] = (".zip", WHEEL_EXTENSION)
+TAR_EXTENSIONS: Tuple[str, ...] = (".tar.gz", ".tgz", ".tar")
 ARCHIVE_EXTENSIONS = ZIP_EXTENSIONS + BZ2_EXTENSIONS + TAR_EXTENSIONS + XZ_EXTENSIONS
 
 
-def is_archive_file(name):
-    # type: (str) -> bool
+def is_archive_file(name: str) -> bool:
     """Return True if `name` is a considered as an archive file."""
     ext = splitext(name)[1].lower()
     if ext in ARCHIVE_EXTENSIONS:
diff --git a/env/Lib/site-packages/pip/_internal/utils/glibc.py b/env/Lib/site-packages/pip/_internal/utils/glibc.py
index 1c9ff354..81342afa 100644
--- a/env/Lib/site-packages/pip/_internal/utils/glibc.py
+++ b/env/Lib/site-packages/pip/_internal/utils/glibc.py
@@ -1,19 +1,14 @@
-# The following comment should be removed at some point in the future.
-# mypy: strict-optional=False
-
 import os
 import sys
 from typing import Optional, Tuple
 
 
-def glibc_version_string():
-    # type: () -> Optional[str]
+def glibc_version_string() -> Optional[str]:
     "Returns glibc version string, or None if not using glibc."
     return glibc_version_string_confstr() or glibc_version_string_ctypes()
 
 
-def glibc_version_string_confstr():
-    # type: () -> Optional[str]
+def glibc_version_string_confstr() -> Optional[str]:
     "Primary implementation of glibc_version_string using os.confstr."
     # os.confstr is quite a bit faster than ctypes.DLL. It's also less likely
     # to be broken or missing. This strategy is used in the standard library
@@ -22,16 +17,18 @@ def glibc_version_string_confstr():
     if sys.platform == "win32":
         return None
     try:
+        gnu_libc_version = os.confstr("CS_GNU_LIBC_VERSION")
+        if gnu_libc_version is None:
+            return None
         # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17":
-        _, version = os.confstr("CS_GNU_LIBC_VERSION").split()
+        _, version = gnu_libc_version.split()
     except (AttributeError, OSError, ValueError):
         # os.confstr() or CS_GNU_LIBC_VERSION not available (or a bad value)...
         return None
     return version
 
 
-def glibc_version_string_ctypes():
-    # type: () -> Optional[str]
+def glibc_version_string_ctypes() -> Optional[str]:
     "Fallback implementation of glibc_version_string using ctypes."
 
     try:
@@ -78,8 +75,7 @@ def glibc_version_string_ctypes():
 # versions that was generated by pip 8.1.2 and earlier is useless and
 # misleading. Solution: instead of using platform, use our code that actually
 # works.
-def libc_ver():
-    # type: () -> Tuple[str, str]
+def libc_ver() -> Tuple[str, str]:
     """Try to determine the glibc version
 
     Returns a tuple of strings (lib, version) which default to empty strings
diff --git a/env/Lib/site-packages/pip/_internal/utils/hashes.py b/env/Lib/site-packages/pip/_internal/utils/hashes.py
index 3d20b8d0..843cffc6 100644
--- a/env/Lib/site-packages/pip/_internal/utils/hashes.py
+++ b/env/Lib/site-packages/pip/_internal/utils/hashes.py
@@ -1,5 +1,5 @@
 import hashlib
-from typing import TYPE_CHECKING, BinaryIO, Dict, Iterator, List
+from typing import TYPE_CHECKING, BinaryIO, Dict, Iterable, List, Optional
 
 from pip._internal.exceptions import HashMismatch, HashMissing, InstallationError
 from pip._internal.utils.misc import read_chunks
@@ -28,8 +28,7 @@ class Hashes:
 
     """
 
-    def __init__(self, hashes=None):
-        # type: (Dict[str, List[str]]) -> None
+    def __init__(self, hashes: Optional[Dict[str, List[str]]] = None) -> None:
         """
         :param hashes: A dict of algorithm names pointing to lists of allowed
             hex digests
@@ -41,8 +40,7 @@ class Hashes:
                 allowed[alg] = sorted(keys)
         self._allowed = allowed
 
-    def __and__(self, other):
-        # type: (Hashes) -> Hashes
+    def __and__(self, other: "Hashes") -> "Hashes":
         if not isinstance(other, Hashes):
             return NotImplemented
 
@@ -62,21 +60,14 @@ class Hashes:
         return Hashes(new)
 
     @property
-    def digest_count(self):
-        # type: () -> int
+    def digest_count(self) -> int:
         return sum(len(digests) for digests in self._allowed.values())
 
-    def is_hash_allowed(
-        self,
-        hash_name,  # type: str
-        hex_digest,  # type: str
-    ):
-        # type: (...) -> bool
+    def is_hash_allowed(self, hash_name: str, hex_digest: str) -> bool:
         """Return whether the given hex digest is allowed."""
         return hex_digest in self._allowed.get(hash_name, [])
 
-    def check_against_chunks(self, chunks):
-        # type: (Iterator[bytes]) -> None
+    def check_against_chunks(self, chunks: Iterable[bytes]) -> None:
         """Check good hashes against ones built from iterable of chunks of
         data.
 
@@ -99,12 +90,10 @@ class Hashes:
                 return
         self._raise(gots)
 
-    def _raise(self, gots):
-        # type: (Dict[str, _Hash]) -> NoReturn
+    def _raise(self, gots: Dict[str, "_Hash"]) -> "NoReturn":
         raise HashMismatch(self._allowed, gots)
 
-    def check_against_file(self, file):
-        # type: (BinaryIO) -> None
+    def check_against_file(self, file: BinaryIO) -> None:
         """Check good hashes against a file-like object
 
         Raise HashMismatch if none match.
@@ -112,28 +101,27 @@ class Hashes:
         """
         return self.check_against_chunks(read_chunks(file))
 
-    def check_against_path(self, path):
-        # type: (str) -> None
+    def check_against_path(self, path: str) -> None:
         with open(path, "rb") as file:
             return self.check_against_file(file)
 
-    def __nonzero__(self):
-        # type: () -> bool
+    def has_one_of(self, hashes: Dict[str, str]) -> bool:
+        """Return whether any of the given hashes are allowed."""
+        for hash_name, hex_digest in hashes.items():
+            if self.is_hash_allowed(hash_name, hex_digest):
+                return True
+        return False
+
+    def __bool__(self) -> bool:
         """Return whether I know any known-good hashes."""
         return bool(self._allowed)
 
-    def __bool__(self):
-        # type: () -> bool
-        return self.__nonzero__()
-
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         if not isinstance(other, Hashes):
             return NotImplemented
         return self._allowed == other._allowed
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(
             ",".join(
                 sorted(
@@ -153,13 +141,11 @@ class MissingHashes(Hashes):
 
     """
 
-    def __init__(self):
-        # type: () -> None
+    def __init__(self) -> None:
         """Don't offer the ``hashes`` kwarg."""
         # Pass our favorite hash in to generate a "gotten hash". With the
         # empty list, it will never match, so an error will always raise.
         super().__init__(hashes={FAVORITE_HASH: []})
 
-    def _raise(self, gots):
-        # type: (Dict[str, _Hash]) -> NoReturn
+    def _raise(self, gots: Dict[str, "_Hash"]) -> "NoReturn":
         raise HashMissing(gots[FAVORITE_HASH].hexdigest())
diff --git a/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py b/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py
index b6863d93..276aa79b 100644
--- a/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py
+++ b/env/Lib/site-packages/pip/_internal/utils/inject_securetransport.py
@@ -10,8 +10,7 @@ old to handle TLSv1.2.
 import sys
 
 
-def inject_securetransport():
-    # type: () -> None
+def inject_securetransport() -> None:
     # Only relevant on macOS
     if sys.platform != "darwin":
         return
diff --git a/env/Lib/site-packages/pip/_internal/utils/logging.py b/env/Lib/site-packages/pip/_internal/utils/logging.py
index 45798d54..c10e1f4c 100644
--- a/env/Lib/site-packages/pip/_internal/utils/logging.py
+++ b/env/Lib/site-packages/pip/_internal/utils/logging.py
@@ -4,27 +4,30 @@ import logging
 import logging.handlers
 import os
 import sys
-from logging import Filter, getLogger
-from typing import IO, Any, Callable, Iterator, Optional, TextIO, Type, cast
-
+import threading
+from dataclasses import dataclass
+from io import TextIOWrapper
+from logging import Filter
+from typing import Any, ClassVar, Generator, List, Optional, TextIO, Type
+
+from pip._vendor.rich.console import (
+    Console,
+    ConsoleOptions,
+    ConsoleRenderable,
+    RenderableType,
+    RenderResult,
+    RichCast,
+)
+from pip._vendor.rich.highlighter import NullHighlighter
+from pip._vendor.rich.logging import RichHandler
+from pip._vendor.rich.segment import Segment
+from pip._vendor.rich.style import Style
+
+from pip._internal.utils._log import VERBOSE, getLogger
 from pip._internal.utils.compat import WINDOWS
 from pip._internal.utils.deprecation import DEPRECATION_MSG_PREFIX
 from pip._internal.utils.misc import ensure_dir
 
-try:
-    import threading
-except ImportError:
-    import dummy_threading as threading  # type: ignore
-
-
-try:
-    from pip._vendor import colorama
-# Lots of different errors can come from this, including SystemError and
-# ImportError.
-except Exception:
-    colorama = None
-
-
 _log_state = threading.local()
 subprocess_logger = getLogger("pip.subprocessor")
 
@@ -34,39 +37,22 @@ class BrokenStdoutLoggingError(Exception):
     Raised if BrokenPipeError occurs for the stdout stream while logging.
     """
 
-    pass
 
+def _is_broken_pipe_error(exc_class: Type[BaseException], exc: BaseException) -> bool:
+    if exc_class is BrokenPipeError:
+        return True
 
-# BrokenPipeError manifests differently in Windows and non-Windows.
-if WINDOWS:
-    # In Windows, a broken pipe can show up as EINVAL rather than EPIPE:
+    # On Windows, a broken pipe can show up as EINVAL rather than EPIPE:
     # https://bugs.python.org/issue19612
     # https://bugs.python.org/issue30418
-    def _is_broken_pipe_error(exc_class, exc):
-        # type: (Type[BaseException], BaseException) -> bool
-        """See the docstring for non-Windows below."""
-        return (exc_class is BrokenPipeError) or (
-            isinstance(exc, OSError) and exc.errno in (errno.EINVAL, errno.EPIPE)
-        )
-
-
-else:
-    # Then we are in the non-Windows case.
-    def _is_broken_pipe_error(exc_class, exc):
-        # type: (Type[BaseException], BaseException) -> bool
-        """
-        Return whether an exception is a broken pipe error.
+    if not WINDOWS:
+        return False
 
-        Args:
-          exc_class: an exception class.
-          exc: an exception instance.
-        """
-        return exc_class is BrokenPipeError
+    return isinstance(exc, OSError) and exc.errno in (errno.EINVAL, errno.EPIPE)
 
 
 @contextlib.contextmanager
-def indent_log(num=2):
-    # type: (int) -> Iterator[None]
+def indent_log(num: int = 2) -> Generator[None, None, None]:
     """
     A context manager which will cause the log output to be indented for any
     log messages emitted inside it.
@@ -80,8 +66,7 @@ def indent_log(num=2):
         _log_state.indentation -= num
 
 
-def get_indentation():
-    # type: () -> int
+def get_indentation() -> int:
     return getattr(_log_state, "indentation", 0)
 
 
@@ -90,11 +75,10 @@ class IndentingFormatter(logging.Formatter):
 
     def __init__(
         self,
-        *args,  # type: Any
-        add_timestamp=False,  # type: bool
-        **kwargs,  # type: Any
-    ):
-        # type: (...) -> None
+        *args: Any,
+        add_timestamp: bool = False,
+        **kwargs: Any,
+    ) -> None:
         """
         A logging.Formatter that obeys the indent_log() context manager.
 
@@ -104,8 +88,7 @@ class IndentingFormatter(logging.Formatter):
         self.add_timestamp = add_timestamp
         super().__init__(*args, **kwargs)
 
-    def get_message_start(self, formatted, levelno):
-        # type: (str, int) -> str
+    def get_message_start(self, formatted: str, levelno: int) -> str:
         """
         Return the start of the formatted log message (not counting the
         prefix to add to each line).
@@ -121,8 +104,7 @@ class IndentingFormatter(logging.Formatter):
 
         return "ERROR: "
 
-    def format(self, record):
-        # type: (logging.LogRecord) -> str
+    def format(self, record: logging.LogRecord) -> str:
         """
         Calls the standard formatter, but will indent all of the log message
         lines by our current indentation level.
@@ -139,85 +121,66 @@ class IndentingFormatter(logging.Formatter):
         return formatted
 
 
-def _color_wrap(*colors):
-    # type: (*str) -> Callable[[str], str]
-    def wrapped(inp):
-        # type: (str) -> str
-        return "".join(list(colors) + [inp, colorama.Style.RESET_ALL])
-
-    return wrapped
-
-
-class ColorizedStreamHandler(logging.StreamHandler):
-
-    # Don't build up a list of colors if we don't have colorama
-    if colorama:
-        COLORS = [
-            # This needs to be in order from highest logging level to lowest.
-            (logging.ERROR, _color_wrap(colorama.Fore.RED)),
-            (logging.WARNING, _color_wrap(colorama.Fore.YELLOW)),
-        ]
-    else:
-        COLORS = []
-
-    def __init__(self, stream=None, no_color=None):
-        # type: (Optional[TextIO], bool) -> None
-        super().__init__(stream)
-        self._no_color = no_color
-
-        if WINDOWS and colorama:
-            self.stream = colorama.AnsiToWin32(self.stream)
-
-    def _using_stdout(self):
-        # type: () -> bool
-        """
-        Return whether the handler is using sys.stdout.
-        """
-        if WINDOWS and colorama:
-            # Then self.stream is an AnsiToWin32 object.
-            stream = cast(colorama.AnsiToWin32, self.stream)
-            return stream.wrapped is sys.stdout
-
-        return self.stream is sys.stdout
-
-    def should_color(self):
-        # type: () -> bool
-        # Don't colorize things if we do not have colorama or if told not to
-        if not colorama or self._no_color:
-            return False
-
-        real_stream = (
-            self.stream
-            if not isinstance(self.stream, colorama.AnsiToWin32)
-            else self.stream.wrapped
+@dataclass
+class IndentedRenderable:
+    renderable: RenderableType
+    indent: int
+
+    def __rich_console__(
+        self, console: Console, options: ConsoleOptions
+    ) -> RenderResult:
+        segments = console.render(self.renderable, options)
+        lines = Segment.split_lines(segments)
+        for line in lines:
+            yield Segment(" " * self.indent)
+            yield from line
+            yield Segment("\n")
+
+
+class RichPipStreamHandler(RichHandler):
+    KEYWORDS: ClassVar[Optional[List[str]]] = []
+
+    def __init__(self, stream: Optional[TextIO], no_color: bool) -> None:
+        super().__init__(
+            console=Console(file=stream, no_color=no_color, soft_wrap=True),
+            show_time=False,
+            show_level=False,
+            show_path=False,
+            highlighter=NullHighlighter(),
         )
 
-        # If the stream is a tty we should color it
-        if hasattr(real_stream, "isatty") and real_stream.isatty():
-            return True
-
-        # If we have an ANSI term we should color it
-        if os.environ.get("TERM") == "ANSI":
-            return True
+    # Our custom override on Rich's logger, to make things work as we need them to.
+    def emit(self, record: logging.LogRecord) -> None:
+        style: Optional[Style] = None
+
+        # If we are given a diagnostic error to present, present it with indentation.
+        assert isinstance(record.args, tuple)
+        if record.msg == "[present-rich] %s" and len(record.args) == 1:
+            rich_renderable = record.args[0]
+            assert isinstance(
+                rich_renderable, (ConsoleRenderable, RichCast, str)
+            ), f"{rich_renderable} is not rich-console-renderable"
+
+            renderable: RenderableType = IndentedRenderable(
+                rich_renderable, indent=get_indentation()
+            )
+        else:
+            message = self.format(record)
+            renderable = self.render_message(record, message)
+            if record.levelno is not None:
+                if record.levelno >= logging.ERROR:
+                    style = Style(color="red")
+                elif record.levelno >= logging.WARNING:
+                    style = Style(color="yellow")
+
+        try:
+            self.console.print(renderable, overflow="ignore", crop=False, style=style)
+        except Exception:
+            self.handleError(record)
+
+    def handleError(self, record: logging.LogRecord) -> None:
+        """Called when logging is unable to log some output."""
 
-        # If anything else we should not color it
-        return False
-
-    def format(self, record):
-        # type: (logging.LogRecord) -> str
-        msg = super().format(record)
-
-        if self.should_color():
-            for level, color in self.COLORS:
-                if record.levelno >= level:
-                    msg = color(msg)
-                    break
-
-        return msg
-
-    # The logging module says handleError() can be customized.
-    def handleError(self, record):
-        # type: (logging.LogRecord) -> None
         exc_class, exc = sys.exc_info()[:2]
         # If a broken pipe occurred while calling write() or flush() on the
         # stdout stream in logging's Handler.emit(), then raise our special
@@ -226,7 +189,7 @@ class ColorizedStreamHandler(logging.StreamHandler):
         if (
             exc_class
             and exc
-            and self._using_stdout()
+            and self.console.file is sys.stdout
             and _is_broken_pipe_error(exc_class, exc)
         ):
             raise BrokenStdoutLoggingError()
@@ -235,19 +198,16 @@ class ColorizedStreamHandler(logging.StreamHandler):
 
 
 class BetterRotatingFileHandler(logging.handlers.RotatingFileHandler):
-    def _open(self):
-        # type: () -> IO[Any]
+    def _open(self) -> TextIOWrapper:
         ensure_dir(os.path.dirname(self.baseFilename))
         return super()._open()
 
 
 class MaxLevelFilter(Filter):
-    def __init__(self, level):
-        # type: (int) -> None
+    def __init__(self, level: int) -> None:
         self.level = level
 
-    def filter(self, record):
-        # type: (logging.LogRecord) -> bool
+    def filter(self, record: logging.LogRecord) -> bool:
         return record.levelno < self.level
 
 
@@ -257,33 +217,33 @@ class ExcludeLoggerFilter(Filter):
     A logging Filter that excludes records from a logger (or its children).
     """
 
-    def filter(self, record):
-        # type: (logging.LogRecord) -> bool
+    def filter(self, record: logging.LogRecord) -> bool:
         # The base Filter class allows only records from a logger (or its
         # children).
         return not super().filter(record)
 
 
-def setup_logging(verbosity, no_color, user_log_file):
-    # type: (int, bool, Optional[str]) -> int
+def setup_logging(verbosity: int, no_color: bool, user_log_file: Optional[str]) -> int:
     """Configures and sets up all of the logging
 
     Returns the requested logging level, as its integer value.
     """
 
     # Determine the level to be logging at.
-    if verbosity >= 1:
-        level = "DEBUG"
+    if verbosity >= 2:
+        level_number = logging.DEBUG
+    elif verbosity == 1:
+        level_number = VERBOSE
     elif verbosity == -1:
-        level = "WARNING"
+        level_number = logging.WARNING
     elif verbosity == -2:
-        level = "ERROR"
+        level_number = logging.ERROR
     elif verbosity <= -3:
-        level = "CRITICAL"
+        level_number = logging.CRITICAL
     else:
-        level = "INFO"
+        level_number = logging.INFO
 
-    level_number = getattr(logging, level)
+    level = logging.getLevelName(level_number)
 
     # The "root" logger should match the "console" level *unless* we also need
     # to log to a user log file.
@@ -305,7 +265,7 @@ def setup_logging(verbosity, no_color, user_log_file):
         "stderr": "ext://sys.stderr",
     }
     handler_classes = {
-        "stream": "pip._internal.utils.logging.ColorizedStreamHandler",
+        "stream": "pip._internal.utils.logging.RichPipStreamHandler",
         "file": "pip._internal.utils.logging.BetterRotatingFileHandler",
     }
     handlers = ["console", "console_errors", "console_subprocess"] + (
@@ -363,8 +323,8 @@ def setup_logging(verbosity, no_color, user_log_file):
                 "console_subprocess": {
                     "level": level,
                     "class": handler_classes["stream"],
-                    "no_color": no_color,
                     "stream": log_streams["stderr"],
+                    "no_color": no_color,
                     "filters": ["restrict_to_subprocess"],
                     "formatter": "indent",
                 },
@@ -372,6 +332,7 @@ def setup_logging(verbosity, no_color, user_log_file):
                     "level": "DEBUG",
                     "class": handler_classes["file"],
                     "filename": additional_log_file,
+                    "encoding": "utf-8",
                     "delay": True,
                     "formatter": "indent_with_timestamp",
                 },
diff --git a/env/Lib/site-packages/pip/_internal/utils/misc.py b/env/Lib/site-packages/pip/_internal/utils/misc.py
index a4ad35be..bd191c4e 100644
--- a/env/Lib/site-packages/pip/_internal/utils/misc.py
+++ b/env/Lib/site-packages/pip/_internal/utils/misc.py
@@ -1,6 +1,3 @@
-# The following comment should be removed at some point in the future.
-# mypy: strict-optional=False
-
 import contextlib
 import errno
 import getpass
@@ -12,17 +9,18 @@ import posixpath
 import shutil
 import stat
 import sys
+import sysconfig
 import urllib.parse
 from io import StringIO
 from itertools import filterfalse, tee, zip_longest
 from types import TracebackType
 from typing import (
     Any,
-    AnyStr,
     BinaryIO,
     Callable,
-    Container,
     ContextManager,
+    Dict,
+    Generator,
     Iterable,
     Iterator,
     List,
@@ -31,20 +29,18 @@ from typing import (
     Tuple,
     Type,
     TypeVar,
+    Union,
     cast,
 )
 
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.pyproject_hooks import BuildBackendHookCaller
 from pip._vendor.tenacity import retry, stop_after_delay, wait_fixed
 
 from pip import __version__
-from pip._internal.exceptions import CommandError
-from pip._internal.locations import get_major_minor_version, site_packages, user_site
-from pip._internal.utils.compat import WINDOWS, stdlib_pkgs
-from pip._internal.utils.virtualenv import (
-    running_under_virtualenv,
-    virtualenv_no_global,
-)
+from pip._internal.exceptions import CommandError, ExternallyManagedEnvironment
+from pip._internal.locations import get_major_minor_version
+from pip._internal.utils.compat import WINDOWS
+from pip._internal.utils.virtualenv import running_under_virtualenv
 
 __all__ = [
     "rmtree",
@@ -60,9 +56,10 @@ __all__ = [
     "captured_stdout",
     "ensure_dir",
     "remove_auth_from_url",
+    "check_externally_managed",
+    "ConfiguredBuildBackendHookCaller",
 ]
 
-
 logger = logging.getLogger(__name__)
 
 T = TypeVar("T")
@@ -71,8 +68,7 @@ VersionInfo = Tuple[int, int, int]
 NetlocTuple = Tuple[str, Tuple[Optional[str], Optional[str]]]
 
 
-def get_pip_version():
-    # type: () -> str
+def get_pip_version() -> str:
     pip_pkg_dir = os.path.join(os.path.dirname(__file__), "..", "..")
     pip_pkg_dir = os.path.abspath(pip_pkg_dir)
 
@@ -83,8 +79,7 @@ def get_pip_version():
     )
 
 
-def normalize_version_info(py_version_info):
-    # type: (Tuple[int, ...]) -> Tuple[int, int, int]
+def normalize_version_info(py_version_info: Tuple[int, ...]) -> Tuple[int, int, int]:
     """
     Convert a tuple of ints representing a Python version to one of length
     three.
@@ -103,8 +98,7 @@ def normalize_version_info(py_version_info):
     return cast("VersionInfo", py_version_info)
 
 
-def ensure_dir(path):
-    # type: (AnyStr) -> None
+def ensure_dir(path: str) -> None:
     """os.path.makedirs without EEXIST."""
     try:
         os.makedirs(path)
@@ -114,8 +108,7 @@ def ensure_dir(path):
             raise
 
 
-def get_prog():
-    # type: () -> str
+def get_prog() -> str:
     try:
         prog = os.path.basename(sys.argv[0])
         if prog in ("__main__.py", "-c"):
@@ -128,15 +121,18 @@ def get_prog():
 
 
 # Retry every half second for up to 3 seconds
-# Tenacity raises RetryError by default, explictly raise the original exception
+# Tenacity raises RetryError by default, explicitly raise the original exception
 @retry(reraise=True, stop=stop_after_delay(3), wait=wait_fixed(0.5))
-def rmtree(dir, ignore_errors=False):
-    # type: (AnyStr, bool) -> None
-    shutil.rmtree(dir, ignore_errors=ignore_errors, onerror=rmtree_errorhandler)
+def rmtree(dir: str, ignore_errors: bool = False) -> None:
+    if sys.version_info >= (3, 12):
+        shutil.rmtree(dir, ignore_errors=ignore_errors, onexc=rmtree_errorhandler)
+    else:
+        shutil.rmtree(dir, ignore_errors=ignore_errors, onerror=rmtree_errorhandler)
 
 
-def rmtree_errorhandler(func, path, exc_info):
-    # type: (Callable[..., Any], str, ExcInfo) -> None
+def rmtree_errorhandler(
+    func: Callable[..., Any], path: str, exc_info: Union[ExcInfo, BaseException]
+) -> None:
     """On Windows, the files in .svn are read-only, so when rmtree() tries to
     remove them, an exception is thrown.  We catch that here, remove the
     read-only attribute, and hopefully continue without problems."""
@@ -156,8 +152,7 @@ def rmtree_errorhandler(func, path, exc_info):
         raise
 
 
-def display_path(path):
-    # type: (str) -> str
+def display_path(path: str) -> str:
     """Gives the display value for a given path, making it relative to cwd
     if possible."""
     path = os.path.normcase(os.path.abspath(path))
@@ -166,8 +161,7 @@ def display_path(path):
     return path
 
 
-def backup_dir(dir, ext=".bak"):
-    # type: (str, str) -> str
+def backup_dir(dir: str, ext: str = ".bak") -> str:
     """Figure out the name of a directory to back up the given dir to
     (adding .bak, .bak2, etc)"""
     n = 1
@@ -178,16 +172,14 @@ def backup_dir(dir, ext=".bak"):
     return dir + extension
 
 
-def ask_path_exists(message, options):
-    # type: (str, Iterable[str]) -> str
+def ask_path_exists(message: str, options: Iterable[str]) -> str:
     for action in os.environ.get("PIP_EXISTS_ACTION", "").split():
         if action in options:
             return action
     return ask(message, options)
 
 
-def _check_no_input(message):
-    # type: (str) -> None
+def _check_no_input(message: str) -> None:
     """Raise an error if no input is allowed."""
     if os.environ.get("PIP_NO_INPUT"):
         raise Exception(
@@ -195,8 +187,7 @@ def _check_no_input(message):
         )
 
 
-def ask(message, options):
-    # type: (str, Iterable[str]) -> str
+def ask(message: str, options: Iterable[str]) -> str:
     """Ask the message interactively, with the given possible responses"""
     while 1:
         _check_no_input(message)
@@ -211,22 +202,19 @@ def ask(message, options):
             return response
 
 
-def ask_input(message):
-    # type: (str) -> str
+def ask_input(message: str) -> str:
     """Ask for input interactively."""
     _check_no_input(message)
     return input(message)
 
 
-def ask_password(message):
-    # type: (str) -> str
+def ask_password(message: str) -> str:
     """Ask for a password interactively."""
     _check_no_input(message)
     return getpass.getpass(message)
 
 
-def strtobool(val):
-    # type: (str) -> int
+def strtobool(val: str) -> int:
     """Convert a string representation of truth to true (1) or false (0).
 
     True values are 'y', 'yes', 't', 'true', 'on', and '1'; false values
@@ -242,8 +230,7 @@ def strtobool(val):
         raise ValueError(f"invalid truth value {val!r}")
 
 
-def format_size(bytes):
-    # type: (float) -> str
+def format_size(bytes: float) -> str:
     if bytes > 1000 * 1000:
         return "{:.1f} MB".format(bytes / 1000.0 / 1000)
     elif bytes > 10 * 1000:
@@ -254,8 +241,7 @@ def format_size(bytes):
         return "{} bytes".format(int(bytes))
 
 
-def tabulate(rows):
-    # type: (Iterable[Iterable[Any]]) -> Tuple[List[str], List[int]]
+def tabulate(rows: Iterable[Iterable[Any]]) -> Tuple[List[str], List[int]]:
     """Return a list of formatted rows and a list of column sizes.
 
     For example::
@@ -270,17 +256,25 @@ def tabulate(rows):
 
 
 def is_installable_dir(path: str) -> bool:
-    """Is path is a directory containing pyproject.toml, setup.cfg or setup.py?"""
+    """Is path is a directory containing pyproject.toml or setup.py?
+
+    If pyproject.toml exists, this is a PEP 517 project. Otherwise we look for
+    a legacy setuptools layout by identifying setup.py. We don't check for the
+    setup.cfg because using it without setup.py is only available for PEP 517
+    projects, which are already covered by the pyproject.toml check.
+    """
     if not os.path.isdir(path):
         return False
-    return any(
-        os.path.isfile(os.path.join(path, signifier))
-        for signifier in ("pyproject.toml", "setup.cfg", "setup.py")
-    )
+    if os.path.isfile(os.path.join(path, "pyproject.toml")):
+        return True
+    if os.path.isfile(os.path.join(path, "setup.py")):
+        return True
+    return False
 
 
-def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE):
-    # type: (BinaryIO, int) -> Iterator[bytes]
+def read_chunks(
+    file: BinaryIO, size: int = io.DEFAULT_BUFFER_SIZE
+) -> Generator[bytes, None, None]:
     """Yield pieces of data from a file-like object until EOF."""
     while True:
         chunk = file.read(size)
@@ -289,8 +283,7 @@ def read_chunks(file, size=io.DEFAULT_BUFFER_SIZE):
         yield chunk
 
 
-def normalize_path(path, resolve_symlinks=True):
-    # type: (str, bool) -> str
+def normalize_path(path: str, resolve_symlinks: bool = True) -> str:
     """
     Convert a path to its canonical, case-normalized, absolute version.
 
@@ -303,8 +296,7 @@ def normalize_path(path, resolve_symlinks=True):
     return os.path.normcase(path)
 
 
-def splitext(path):
-    # type: (str) -> Tuple[str, str]
+def splitext(path: str) -> Tuple[str, str]:
     """Like os.path.splitext, but take off .tar too"""
     base, ext = posixpath.splitext(path)
     if base.lower().endswith(".tar"):
@@ -313,8 +305,7 @@ def splitext(path):
     return base, ext
 
 
-def renames(old, new):
-    # type: (str, str) -> None
+def renames(old: str, new: str) -> None:
     """Like os.renames(), but handles renaming across devices."""
     # Implementation borrowed from os.renames().
     head, tail = os.path.split(new)
@@ -331,8 +322,7 @@ def renames(old, new):
             pass
 
 
-def is_local(path):
-    # type: (str) -> bool
+def is_local(path: str) -> bool:
     """
     Return True if path is within sys.prefix, if we're running in a virtualenv.
 
@@ -346,171 +336,28 @@ def is_local(path):
     return path.startswith(normalize_path(sys.prefix))
 
 
-def dist_is_local(dist):
-    # type: (Distribution) -> bool
-    """
-    Return True if given Distribution object is installed locally
-    (i.e. within current virtualenv).
-
-    Always True if we're not in a virtualenv.
-
-    """
-    return is_local(dist_location(dist))
-
-
-def dist_in_usersite(dist):
-    # type: (Distribution) -> bool
-    """
-    Return True if given Distribution is installed in user site.
-    """
-    return dist_location(dist).startswith(normalize_path(user_site))
-
-
-def dist_in_site_packages(dist):
-    # type: (Distribution) -> bool
-    """
-    Return True if given Distribution is installed in
-    sysconfig.get_python_lib().
-    """
-    return dist_location(dist).startswith(normalize_path(site_packages))
-
-
-def dist_is_editable(dist):
-    # type: (Distribution) -> bool
-    """
-    Return True if given Distribution is an editable install.
-    """
-    for path_item in sys.path:
-        egg_link = os.path.join(path_item, dist.project_name + ".egg-link")
-        if os.path.isfile(egg_link):
-            return True
-    return False
-
-
-def get_installed_distributions(
-    local_only=True,  # type: bool
-    skip=stdlib_pkgs,  # type: Container[str]
-    include_editables=True,  # type: bool
-    editables_only=False,  # type: bool
-    user_only=False,  # type: bool
-    paths=None,  # type: Optional[List[str]]
-):
-    # type: (...) -> List[Distribution]
-    """Return a list of installed Distribution objects.
-
-    Left for compatibility until direct pkg_resources uses are refactored out.
-    """
-    from pip._internal.metadata import get_default_environment, get_environment
-    from pip._internal.metadata.pkg_resources import Distribution as _Dist
-
-    if paths is None:
-        env = get_default_environment()
-    else:
-        env = get_environment(paths)
-    dists = env.iter_installed_distributions(
-        local_only=local_only,
-        skip=skip,
-        include_editables=include_editables,
-        editables_only=editables_only,
-        user_only=user_only,
-    )
-    return [cast(_Dist, dist)._dist for dist in dists]
-
-
-def get_distribution(req_name):
-    # type: (str) -> Optional[Distribution]
-    """Given a requirement name, return the installed Distribution object.
-
-    This searches from *all* distributions available in the environment, to
-    match the behavior of ``pkg_resources.get_distribution()``.
-
-    Left for compatibility until direct pkg_resources uses are refactored out.
-    """
-    from pip._internal.metadata import get_default_environment
-    from pip._internal.metadata.pkg_resources import Distribution as _Dist
-
-    dist = get_default_environment().get_distribution(req_name)
-    if dist is None:
-        return None
-    return cast(_Dist, dist)._dist
-
-
-def egg_link_path(dist):
-    # type: (Distribution) -> Optional[str]
-    """
-    Return the path for the .egg-link file if it exists, otherwise, None.
-
-    There's 3 scenarios:
-    1) not in a virtualenv
-       try to find in site.USER_SITE, then site_packages
-    2) in a no-global virtualenv
-       try to find in site_packages
-    3) in a yes-global virtualenv
-       try to find in site_packages, then site.USER_SITE
-       (don't look in global location)
-
-    For #1 and #3, there could be odd cases, where there's an egg-link in 2
-    locations.
-
-    This method will just return the first one found.
-    """
-    sites = []
-    if running_under_virtualenv():
-        sites.append(site_packages)
-        if not virtualenv_no_global() and user_site:
-            sites.append(user_site)
-    else:
-        if user_site:
-            sites.append(user_site)
-        sites.append(site_packages)
-
-    for site in sites:
-        egglink = os.path.join(site, dist.project_name) + ".egg-link"
-        if os.path.isfile(egglink):
-            return egglink
-    return None
-
-
-def dist_location(dist):
-    # type: (Distribution) -> str
-    """
-    Get the site-packages location of this distribution. Generally
-    this is dist.location, except in the case of develop-installed
-    packages, where dist.location is the source code location, and we
-    want to know where the egg-link file is.
-
-    The returned location is normalized (in particular, with symlinks removed).
-    """
-    egg_link = egg_link_path(dist)
-    if egg_link:
-        return normalize_path(egg_link)
-    return normalize_path(dist.location)
-
-
-def write_output(msg, *args):
-    # type: (Any, Any) -> None
+def write_output(msg: Any, *args: Any) -> None:
     logger.info(msg, *args)
 
 
 class StreamWrapper(StringIO):
-    orig_stream = None  # type: TextIO
+    orig_stream: TextIO
 
     @classmethod
-    def from_stream(cls, orig_stream):
-        # type: (TextIO) -> StreamWrapper
-        cls.orig_stream = orig_stream
-        return cls()
+    def from_stream(cls, orig_stream: TextIO) -> "StreamWrapper":
+        ret = cls()
+        ret.orig_stream = orig_stream
+        return ret
 
     # compileall.compile_dir() needs stdout.encoding to print to stdout
-    # https://github.com/python/mypy/issues/4125
+    # type ignore is because TextIOBase.encoding is writeable
     @property
-    def encoding(self):  # type: ignore
+    def encoding(self) -> str:  # type: ignore
         return self.orig_stream.encoding
 
 
 @contextlib.contextmanager
-def captured_output(stream_name):
-    # type: (str) -> Iterator[StreamWrapper]
+def captured_output(stream_name: str) -> Generator[StreamWrapper, None, None]:
     """Return a context manager used by captured_stdout/stdin/stderr
     that temporarily replaces the sys stream *stream_name* with a StringIO.
 
@@ -524,8 +371,7 @@ def captured_output(stream_name):
         setattr(sys, stream_name, orig_stdout)
 
 
-def captured_stdout():
-    # type: () -> ContextManager[StreamWrapper]
+def captured_stdout() -> ContextManager[StreamWrapper]:
     """Capture the output of sys.stdout:
 
        with captured_stdout() as stdout:
@@ -537,8 +383,7 @@ def captured_stdout():
     return captured_output("stdout")
 
 
-def captured_stderr():
-    # type: () -> ContextManager[StreamWrapper]
+def captured_stderr() -> ContextManager[StreamWrapper]:
     """
     See captured_stdout().
     """
@@ -546,16 +391,14 @@ def captured_stderr():
 
 
 # Simulates an enum
-def enum(*sequential, **named):
-    # type: (*Any, **Any) -> Type[Any]
+def enum(*sequential: Any, **named: Any) -> Type[Any]:
     enums = dict(zip(sequential, range(len(sequential))), **named)
     reverse = {value: key for key, value in enums.items()}
     enums["reverse_mapping"] = reverse
     return type("Enum", (), enums)
 
 
-def build_netloc(host, port):
-    # type: (str, Optional[int]) -> str
+def build_netloc(host: str, port: Optional[int]) -> str:
     """
     Build a netloc from a host-port pair
     """
@@ -567,8 +410,7 @@ def build_netloc(host, port):
     return f"{host}:{port}"
 
 
-def build_url_from_netloc(netloc, scheme="https"):
-    # type: (str, str) -> str
+def build_url_from_netloc(netloc: str, scheme: str = "https") -> str:
     """
     Build a full URL from a netloc.
     """
@@ -578,8 +420,7 @@ def build_url_from_netloc(netloc, scheme="https"):
     return f"{scheme}://{netloc}"
 
 
-def parse_netloc(netloc):
-    # type: (str) -> Tuple[str, Optional[int]]
+def parse_netloc(netloc: str) -> Tuple[Optional[str], Optional[int]]:
     """
     Return the host-port pair from a netloc.
     """
@@ -588,8 +429,7 @@ def parse_netloc(netloc):
     return parsed.hostname, parsed.port
 
 
-def split_auth_from_netloc(netloc):
-    # type: (str) -> NetlocTuple
+def split_auth_from_netloc(netloc: str) -> NetlocTuple:
     """
     Parse out and remove the auth information from a netloc.
 
@@ -602,7 +442,7 @@ def split_auth_from_netloc(netloc):
     # behaves if more than one @ is present (which can be checked using
     # the password attribute of urlsplit()'s return value).
     auth, netloc = netloc.rsplit("@", 1)
-    pw = None  # type: Optional[str]
+    pw: Optional[str] = None
     if ":" in auth:
         # Split from the left because that's how urllib.parse.urlsplit()
         # behaves if more than one : is present (which again can be checked
@@ -618,8 +458,7 @@ def split_auth_from_netloc(netloc):
     return netloc, (user, pw)
 
 
-def redact_netloc(netloc):
-    # type: (str) -> str
+def redact_netloc(netloc: str) -> str:
     """
     Replace the sensitive data in a netloc with "****", if it exists.
 
@@ -641,8 +480,9 @@ def redact_netloc(netloc):
     )
 
 
-def _transform_url(url, transform_netloc):
-    # type: (str, Callable[[str], Tuple[Any, ...]]) -> Tuple[str, NetlocTuple]
+def _transform_url(
+    url: str, transform_netloc: Callable[[str], Tuple[Any, ...]]
+) -> Tuple[str, NetlocTuple]:
     """Transform and replace netloc in a url.
 
     transform_netloc is a function taking the netloc and returning a
@@ -660,18 +500,17 @@ def _transform_url(url, transform_netloc):
     return surl, cast("NetlocTuple", netloc_tuple)
 
 
-def _get_netloc(netloc):
-    # type: (str) -> NetlocTuple
+def _get_netloc(netloc: str) -> NetlocTuple:
     return split_auth_from_netloc(netloc)
 
 
-def _redact_netloc(netloc):
-    # type: (str) -> Tuple[str,]
+def _redact_netloc(netloc: str) -> Tuple[str]:
     return (redact_netloc(netloc),)
 
 
-def split_auth_netloc_from_url(url):
-    # type: (str) -> Tuple[str, str, Tuple[str, str]]
+def split_auth_netloc_from_url(
+    url: str,
+) -> Tuple[str, str, Tuple[Optional[str], Optional[str]]]:
     """
     Parse a url into separate netloc, auth, and url with no auth.
 
@@ -681,41 +520,31 @@ def split_auth_netloc_from_url(url):
     return url_without_auth, netloc, auth
 
 
-def remove_auth_from_url(url):
-    # type: (str) -> str
+def remove_auth_from_url(url: str) -> str:
     """Return a copy of url with 'username:password@' removed."""
     # username/pass params are passed to subversion through flags
     # and are not recognized in the url.
     return _transform_url(url, _get_netloc)[0]
 
 
-def redact_auth_from_url(url):
-    # type: (str) -> str
+def redact_auth_from_url(url: str) -> str:
     """Replace the password in a given url with ****."""
     return _transform_url(url, _redact_netloc)[0]
 
 
 class HiddenText:
-    def __init__(
-        self,
-        secret,  # type: str
-        redacted,  # type: str
-    ):
-        # type: (...) -> None
+    def __init__(self, secret: str, redacted: str) -> None:
         self.secret = secret
         self.redacted = redacted
 
-    def __repr__(self):
-        # type: (...) -> str
+    def __repr__(self) -> str:
         return "<HiddenText {!r}>".format(str(self))
 
-    def __str__(self):
-        # type: (...) -> str
+    def __str__(self) -> str:
         return self.redacted
 
     # This is useful for testing.
-    def __eq__(self, other):
-        # type: (Any) -> bool
+    def __eq__(self, other: Any) -> bool:
         if type(self) != type(other):
             return False
 
@@ -724,28 +553,25 @@ class HiddenText:
         return self.secret == other.secret
 
 
-def hide_value(value):
-    # type: (str) -> HiddenText
+def hide_value(value: str) -> HiddenText:
     return HiddenText(value, redacted="****")
 
 
-def hide_url(url):
-    # type: (str) -> HiddenText
+def hide_url(url: str) -> HiddenText:
     redacted = redact_auth_from_url(url)
     return HiddenText(url, redacted=redacted)
 
 
-def protect_pip_from_modification_on_windows(modifying_pip):
-    # type: (bool) -> None
+def protect_pip_from_modification_on_windows(modifying_pip: bool) -> None:
     """Protection of pip.exe from modification on Windows
 
     On Windows, any operation modifying pip should be run as:
         python -m pip ...
     """
     pip_names = [
-        "pip.exe",
-        "pip{}.exe".format(sys.version_info[0]),
-        "pip{}.{}.exe".format(*sys.version_info[:2]),
+        "pip",
+        f"pip{sys.version_info.major}",
+        f"pip{sys.version_info.major}.{sys.version_info.minor}",
     ]
 
     # See https://github.com/pypa/pip/issues/1299 for more discussion
@@ -762,14 +588,27 @@ def protect_pip_from_modification_on_windows(modifying_pip):
         )
 
 
-def is_console_interactive():
-    # type: () -> bool
+def check_externally_managed() -> None:
+    """Check whether the current environment is externally managed.
+
+    If the ``EXTERNALLY-MANAGED`` config file is found, the current environment
+    is considered externally managed, and an ExternallyManagedEnvironment is
+    raised.
+    """
+    if running_under_virtualenv():
+        return
+    marker = os.path.join(sysconfig.get_path("stdlib"), "EXTERNALLY-MANAGED")
+    if not os.path.isfile(marker):
+        return
+    raise ExternallyManagedEnvironment.from_config(marker)
+
+
+def is_console_interactive() -> bool:
     """Is this console interactive?"""
     return sys.stdin is not None and sys.stdin.isatty()
 
 
-def hash_file(path, blocksize=1 << 20):
-    # type: (str, int) -> Tuple[Any, int]
+def hash_file(path: str, blocksize: int = 1 << 20) -> Tuple[Any, int]:
     """Return (hash, length) for path using hashlib.sha256()"""
 
     h = hashlib.sha256()
@@ -781,21 +620,7 @@ def hash_file(path, blocksize=1 << 20):
     return h, length
 
 
-def is_wheel_installed():
-    # type: () -> bool
-    """
-    Return whether the wheel package is installed.
-    """
-    try:
-        import wheel  # noqa: F401
-    except ImportError:
-        return False
-
-    return True
-
-
-def pairwise(iterable):
-    # type: (Iterable[Any]) -> Iterator[Tuple[Any, Any]]
+def pairwise(iterable: Iterable[Any]) -> Iterator[Tuple[Any, Any]]:
     """
     Return paired elements.
 
@@ -807,10 +632,9 @@ def pairwise(iterable):
 
 
 def partition(
-    pred,  # type: Callable[[T], bool]
-    iterable,  # type: Iterable[T]
-):
-    # type: (...) -> Tuple[Iterable[T], Iterable[T]]
+    pred: Callable[[T], bool],
+    iterable: Iterable[T],
+) -> Tuple[Iterable[T], Iterable[T]]:
     """
     Use a predicate to partition entries into false entries and true entries,
     like
@@ -819,3 +643,93 @@ def partition(
     """
     t1, t2 = tee(iterable)
     return filterfalse(pred, t1), filter(pred, t2)
+
+
+class ConfiguredBuildBackendHookCaller(BuildBackendHookCaller):
+    def __init__(
+        self,
+        config_holder: Any,
+        source_dir: str,
+        build_backend: str,
+        backend_path: Optional[str] = None,
+        runner: Optional[Callable[..., None]] = None,
+        python_executable: Optional[str] = None,
+    ):
+        super().__init__(
+            source_dir, build_backend, backend_path, runner, python_executable
+        )
+        self.config_holder = config_holder
+
+    def build_wheel(
+        self,
+        wheel_directory: str,
+        config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+        metadata_directory: Optional[str] = None,
+    ) -> str:
+        cs = self.config_holder.config_settings
+        return super().build_wheel(
+            wheel_directory, config_settings=cs, metadata_directory=metadata_directory
+        )
+
+    def build_sdist(
+        self,
+        sdist_directory: str,
+        config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+    ) -> str:
+        cs = self.config_holder.config_settings
+        return super().build_sdist(sdist_directory, config_settings=cs)
+
+    def build_editable(
+        self,
+        wheel_directory: str,
+        config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+        metadata_directory: Optional[str] = None,
+    ) -> str:
+        cs = self.config_holder.config_settings
+        return super().build_editable(
+            wheel_directory, config_settings=cs, metadata_directory=metadata_directory
+        )
+
+    def get_requires_for_build_wheel(
+        self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None
+    ) -> List[str]:
+        cs = self.config_holder.config_settings
+        return super().get_requires_for_build_wheel(config_settings=cs)
+
+    def get_requires_for_build_sdist(
+        self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None
+    ) -> List[str]:
+        cs = self.config_holder.config_settings
+        return super().get_requires_for_build_sdist(config_settings=cs)
+
+    def get_requires_for_build_editable(
+        self, config_settings: Optional[Dict[str, Union[str, List[str]]]] = None
+    ) -> List[str]:
+        cs = self.config_holder.config_settings
+        return super().get_requires_for_build_editable(config_settings=cs)
+
+    def prepare_metadata_for_build_wheel(
+        self,
+        metadata_directory: str,
+        config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+        _allow_fallback: bool = True,
+    ) -> str:
+        cs = self.config_holder.config_settings
+        return super().prepare_metadata_for_build_wheel(
+            metadata_directory=metadata_directory,
+            config_settings=cs,
+            _allow_fallback=_allow_fallback,
+        )
+
+    def prepare_metadata_for_build_editable(
+        self,
+        metadata_directory: str,
+        config_settings: Optional[Dict[str, Union[str, List[str]]]] = None,
+        _allow_fallback: bool = True,
+    ) -> str:
+        cs = self.config_holder.config_settings
+        return super().prepare_metadata_for_build_editable(
+            metadata_directory=metadata_directory,
+            config_settings=cs,
+            _allow_fallback=_allow_fallback,
+        )
diff --git a/env/Lib/site-packages/pip/_internal/utils/models.py b/env/Lib/site-packages/pip/_internal/utils/models.py
index 0e02bc7a..b6bb21a8 100644
--- a/env/Lib/site-packages/pip/_internal/utils/models.py
+++ b/env/Lib/site-packages/pip/_internal/utils/models.py
@@ -10,37 +10,29 @@ class KeyBasedCompareMixin:
 
     __slots__ = ["_compare_key", "_defining_class"]
 
-    def __init__(self, key, defining_class):
-        # type: (Any, Type[KeyBasedCompareMixin]) -> None
+    def __init__(self, key: Any, defining_class: Type["KeyBasedCompareMixin"]) -> None:
         self._compare_key = key
         self._defining_class = defining_class
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(self._compare_key)
 
-    def __lt__(self, other):
-        # type: (Any) -> bool
+    def __lt__(self, other: Any) -> bool:
         return self._compare(other, operator.__lt__)
 
-    def __le__(self, other):
-        # type: (Any) -> bool
+    def __le__(self, other: Any) -> bool:
         return self._compare(other, operator.__le__)
 
-    def __gt__(self, other):
-        # type: (Any) -> bool
+    def __gt__(self, other: Any) -> bool:
         return self._compare(other, operator.__gt__)
 
-    def __ge__(self, other):
-        # type: (Any) -> bool
+    def __ge__(self, other: Any) -> bool:
         return self._compare(other, operator.__ge__)
 
-    def __eq__(self, other):
-        # type: (Any) -> bool
+    def __eq__(self, other: Any) -> bool:
         return self._compare(other, operator.__eq__)
 
-    def _compare(self, other, method):
-        # type: (Any, Callable[[Any, Any], bool]) -> bool
+    def _compare(self, other: Any, method: Callable[[Any, Any], bool]) -> bool:
         if not isinstance(other, self._defining_class):
             return NotImplemented
 
diff --git a/env/Lib/site-packages/pip/_internal/utils/packaging.py b/env/Lib/site-packages/pip/_internal/utils/packaging.py
index 3f9dbd3b..b9f6af4d 100644
--- a/env/Lib/site-packages/pip/_internal/utils/packaging.py
+++ b/env/Lib/site-packages/pip/_internal/utils/packaging.py
@@ -1,20 +1,19 @@
+import functools
 import logging
-from email.message import Message
-from email.parser import FeedParser
-from typing import Optional, Tuple
+import re
+from typing import NewType, Optional, Tuple, cast
 
-from pip._vendor import pkg_resources
 from pip._vendor.packaging import specifiers, version
-from pip._vendor.pkg_resources import Distribution
+from pip._vendor.packaging.requirements import Requirement
 
-from pip._internal.exceptions import NoneMetadataError
-from pip._internal.utils.misc import display_path
+NormalizedExtra = NewType("NormalizedExtra", str)
 
 logger = logging.getLogger(__name__)
 
 
-def check_requires_python(requires_python, version_info):
-    # type: (Optional[str], Tuple[int, ...]) -> bool
+def check_requires_python(
+    requires_python: Optional[str], version_info: Tuple[int, ...]
+) -> bool:
     """
     Check if the given Python version matches a "Requires-Python" specifier.
 
@@ -35,55 +34,24 @@ def check_requires_python(requires_python, version_info):
     return python_version in requires_python_specifier
 
 
-def get_metadata(dist):
-    # type: (Distribution) -> Message
-    """
-    :raises NoneMetadataError: if the distribution reports `has_metadata()`
-        True but `get_metadata()` returns None.
-    """
-    metadata_name = "METADATA"
-    if isinstance(dist, pkg_resources.DistInfoDistribution) and dist.has_metadata(
-        metadata_name
-    ):
-        metadata = dist.get_metadata(metadata_name)
-    elif dist.has_metadata("PKG-INFO"):
-        metadata_name = "PKG-INFO"
-        metadata = dist.get_metadata(metadata_name)
-    else:
-        logger.warning("No metadata found in %s", display_path(dist.location))
-        metadata = ""
+@functools.lru_cache(maxsize=512)
+def get_requirement(req_string: str) -> Requirement:
+    """Construct a packaging.Requirement object with caching"""
+    # Parsing requirement strings is expensive, and is also expected to happen
+    # with a low diversity of different arguments (at least relative the number
+    # constructed). This method adds a cache to requirement object creation to
+    # minimize repeated parsing of the same string to construct equivalent
+    # Requirement objects.
+    return Requirement(req_string)
 
-    if metadata is None:
-        raise NoneMetadataError(dist, metadata_name)
 
-    feed_parser = FeedParser()
-    # The following line errors out if with a "NoneType" TypeError if
-    # passed metadata=None.
-    feed_parser.feed(metadata)
-    return feed_parser.close()
+def safe_extra(extra: str) -> NormalizedExtra:
+    """Convert an arbitrary string to a standard 'extra' name
 
+    Any runs of non-alphanumeric characters are replaced with a single '_',
+    and the result is always lowercased.
 
-def get_requires_python(dist):
-    # type: (pkg_resources.Distribution) -> Optional[str]
+    This function is duplicated from ``pkg_resources``. Note that this is not
+    the same to either ``canonicalize_name`` or ``_egg_link_name``.
     """
-    Return the "Requires-Python" metadata for a distribution, or None
-    if not present.
-    """
-    pkg_info_dict = get_metadata(dist)
-    requires_python = pkg_info_dict.get("Requires-Python")
-
-    if requires_python is not None:
-        # Convert to a str to satisfy the type checker, since requires_python
-        # can be a Header object.
-        requires_python = str(requires_python)
-
-    return requires_python
-
-
-def get_installer(dist):
-    # type: (Distribution) -> str
-    if dist.has_metadata("INSTALLER"):
-        for line in dist.get_metadata_lines("INSTALLER"):
-            if line.strip():
-                return line.strip()
-    return ""
+    return cast(NormalizedExtra, re.sub("[^A-Za-z0-9.-]+", "_", extra).lower())
diff --git a/env/Lib/site-packages/pip/_internal/utils/parallel.py b/env/Lib/site-packages/pip/_internal/utils/parallel.py
deleted file mode 100644
index de91dc8a..00000000
--- a/env/Lib/site-packages/pip/_internal/utils/parallel.py
+++ /dev/null
@@ -1,101 +0,0 @@
-"""Convenient parallelization of higher order functions.
-
-This module provides two helper functions, with appropriate fallbacks on
-Python 2 and on systems lacking support for synchronization mechanisms:
-
-- map_multiprocess
-- map_multithread
-
-These helpers work like Python 3's map, with two differences:
-
-- They don't guarantee the order of processing of
-  the elements of the iterable.
-- The underlying process/thread pools chop the iterable into
-  a number of chunks, so that for very long iterables using
-  a large value for chunksize can make the job complete much faster
-  than using the default value of 1.
-"""
-
-__all__ = ["map_multiprocess", "map_multithread"]
-
-from contextlib import contextmanager
-from multiprocessing import Pool as ProcessPool
-from multiprocessing import pool
-from multiprocessing.dummy import Pool as ThreadPool
-from typing import Callable, Iterable, Iterator, TypeVar, Union
-
-from pip._vendor.requests.adapters import DEFAULT_POOLSIZE
-
-Pool = Union[pool.Pool, pool.ThreadPool]
-S = TypeVar("S")
-T = TypeVar("T")
-
-# On platforms without sem_open, multiprocessing[.dummy] Pool
-# cannot be created.
-try:
-    import multiprocessing.synchronize  # noqa
-except ImportError:
-    LACK_SEM_OPEN = True
-else:
-    LACK_SEM_OPEN = False
-
-# Incredibly large timeout to work around bpo-8296 on Python 2.
-TIMEOUT = 2000000
-
-
-@contextmanager
-def closing(pool):
-    # type: (Pool) -> Iterator[Pool]
-    """Return a context manager making sure the pool closes properly."""
-    try:
-        yield pool
-    finally:
-        # For Pool.imap*, close and join are needed
-        # for the returned iterator to begin yielding.
-        pool.close()
-        pool.join()
-        pool.terminate()
-
-
-def _map_fallback(func, iterable, chunksize=1):
-    # type: (Callable[[S], T], Iterable[S], int) -> Iterator[T]
-    """Make an iterator applying func to each element in iterable.
-
-    This function is the sequential fallback either on Python 2
-    where Pool.imap* doesn't react to KeyboardInterrupt
-    or when sem_open is unavailable.
-    """
-    return map(func, iterable)
-
-
-def _map_multiprocess(func, iterable, chunksize=1):
-    # type: (Callable[[S], T], Iterable[S], int) -> Iterator[T]
-    """Chop iterable into chunks and submit them to a process pool.
-
-    For very long iterables using a large value for chunksize can make
-    the job complete much faster than using the default value of 1.
-
-    Return an unordered iterator of the results.
-    """
-    with closing(ProcessPool()) as pool:
-        return pool.imap_unordered(func, iterable, chunksize)
-
-
-def _map_multithread(func, iterable, chunksize=1):
-    # type: (Callable[[S], T], Iterable[S], int) -> Iterator[T]
-    """Chop iterable into chunks and submit them to a thread pool.
-
-    For very long iterables using a large value for chunksize can make
-    the job complete much faster than using the default value of 1.
-
-    Return an unordered iterator of the results.
-    """
-    with closing(ThreadPool(DEFAULT_POOLSIZE)) as pool:
-        return pool.imap_unordered(func, iterable, chunksize)
-
-
-if LACK_SEM_OPEN:
-    map_multiprocess = map_multithread = _map_fallback
-else:
-    map_multiprocess = _map_multiprocess
-    map_multithread = _map_multithread
diff --git a/env/Lib/site-packages/pip/_internal/utils/pkg_resources.py b/env/Lib/site-packages/pip/_internal/utils/pkg_resources.py
deleted file mode 100644
index ee1eca30..00000000
--- a/env/Lib/site-packages/pip/_internal/utils/pkg_resources.py
+++ /dev/null
@@ -1,40 +0,0 @@
-from typing import Dict, Iterable, List
-
-from pip._vendor.pkg_resources import yield_lines
-
-
-class DictMetadata:
-    """IMetadataProvider that reads metadata files from a dictionary."""
-
-    def __init__(self, metadata):
-        # type: (Dict[str, bytes]) -> None
-        self._metadata = metadata
-
-    def has_metadata(self, name):
-        # type: (str) -> bool
-        return name in self._metadata
-
-    def get_metadata(self, name):
-        # type: (str) -> str
-        try:
-            return self._metadata[name].decode()
-        except UnicodeDecodeError as e:
-            # Mirrors handling done in pkg_resources.NullProvider.
-            e.reason += f" in {name} file"
-            raise
-
-    def get_metadata_lines(self, name):
-        # type: (str) -> Iterable[str]
-        return yield_lines(self.get_metadata(name))
-
-    def metadata_isdir(self, name):
-        # type: (str) -> bool
-        return False
-
-    def metadata_listdir(self, name):
-        # type: (str) -> List[str]
-        return []
-
-    def run_script(self, script_name, namespace):
-        # type: (str, str) -> None
-        pass
diff --git a/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py b/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py
index 4b8e4b35..96d1b246 100644
--- a/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py
+++ b/env/Lib/site-packages/pip/_internal/utils/setuptools_build.py
@@ -1,30 +1,57 @@
 import sys
+import textwrap
 from typing import List, Optional, Sequence
 
 # Shim to wrap setup.py invocation with setuptools
-#
-# We set sys.argv[0] to the path to the underlying setup.py file so
-# setuptools / distutils don't take the path to the setup.py to be "-c" when
-# invoking via the shim.  This avoids e.g. the following manifest_maker
-# warning: "warning: manifest_maker: standard file '-c' not found".
-_SETUPTOOLS_SHIM = (
-    "import io, os, sys, setuptools, tokenize; sys.argv[0] = {0!r}; __file__={0!r};"
-    "f = getattr(tokenize, 'open', open)(__file__) "
-    "if os.path.exists(__file__) "
-    "else io.StringIO('from setuptools import setup; setup()');"
-    "code = f.read().replace('\\r\\n', '\\n');"
-    "f.close();"
-    "exec(compile(code, __file__, 'exec'))"
-)
+# Note that __file__ is handled via two {!r} *and* %r, to ensure that paths on
+# Windows are correctly handled (it should be "C:\\Users" not "C:\Users").
+_SETUPTOOLS_SHIM = textwrap.dedent(
+    """
+    exec(compile('''
+    # This is <pip-setuptools-caller> -- a caller that pip uses to run setup.py
+    #
+    # - It imports setuptools before invoking setup.py, to enable projects that directly
+    #   import from `distutils.core` to work with newer packaging standards.
+    # - It provides a clear error message when setuptools is not installed.
+    # - It sets `sys.argv[0]` to the underlying `setup.py`, when invoking `setup.py` so
+    #   setuptools doesn't think the script is `-c`. This avoids the following warning:
+    #     manifest_maker: standard file '-c' not found".
+    # - It generates a shim setup.py, for handling setup.cfg-only projects.
+    import os, sys, tokenize
+
+    try:
+        import setuptools
+    except ImportError as error:
+        print(
+            "ERROR: Can not execute `setup.py` since setuptools is not available in "
+            "the build environment.",
+            file=sys.stderr,
+        )
+        sys.exit(1)
+
+    __file__ = %r
+    sys.argv[0] = __file__
+
+    if os.path.exists(__file__):
+        filename = __file__
+        with tokenize.open(__file__) as f:
+            setup_py_code = f.read()
+    else:
+        filename = "<auto-generated setuptools caller>"
+        setup_py_code = "from setuptools import setup; setup()"
+
+    exec(compile(setup_py_code, filename, "exec"))
+    ''' % ({!r},), "<pip-setuptools-caller>", "exec"))
+    """
+).rstrip()
 
 
 def make_setuptools_shim_args(
-    setup_py_path,  # type: str
-    global_options=None,  # type: Sequence[str]
-    no_user_config=False,  # type: bool
-    unbuffered_output=False,  # type: bool
-):
-    # type: (...) -> List[str]
+    setup_py_path: str,
+    global_options: Optional[Sequence[str]] = None,
+    no_user_config: bool = False,
+    unbuffered_output: bool = False,
+) -> List[str]:
     """
     Get setuptools command arguments with shim wrapped setup file invocation.
 
@@ -46,12 +73,11 @@ def make_setuptools_shim_args(
 
 
 def make_setuptools_bdist_wheel_args(
-    setup_py_path,  # type: str
-    global_options,  # type: Sequence[str]
-    build_options,  # type: Sequence[str]
-    destination_dir,  # type: str
-):
-    # type: (...) -> List[str]
+    setup_py_path: str,
+    global_options: Sequence[str],
+    build_options: Sequence[str],
+    destination_dir: str,
+) -> List[str]:
     # NOTE: Eventually, we'd want to also -S to the flags here, when we're
     # isolating. Currently, it breaks Python in virtualenvs, because it
     # relies on site.py to find parts of the standard library outside the
@@ -65,10 +91,9 @@ def make_setuptools_bdist_wheel_args(
 
 
 def make_setuptools_clean_args(
-    setup_py_path,  # type: str
-    global_options,  # type: Sequence[str]
-):
-    # type: (...) -> List[str]
+    setup_py_path: str,
+    global_options: Sequence[str],
+) -> List[str]:
     args = make_setuptools_shim_args(
         setup_py_path, global_options=global_options, unbuffered_output=True
     )
@@ -77,15 +102,14 @@ def make_setuptools_clean_args(
 
 
 def make_setuptools_develop_args(
-    setup_py_path,  # type: str
-    global_options,  # type: Sequence[str]
-    install_options,  # type: Sequence[str]
-    no_user_config,  # type: bool
-    prefix,  # type: Optional[str]
-    home,  # type: Optional[str]
-    use_user_site,  # type: bool
-):
-    # type: (...) -> List[str]
+    setup_py_path: str,
+    *,
+    global_options: Sequence[str],
+    no_user_config: bool,
+    prefix: Optional[str],
+    home: Optional[str],
+    use_user_site: bool,
+) -> List[str]:
     assert not (use_user_site and prefix)
 
     args = make_setuptools_shim_args(
@@ -96,8 +120,6 @@ def make_setuptools_develop_args(
 
     args += ["develop", "--no-deps"]
 
-    args += install_options
-
     if prefix:
         args += ["--prefix", prefix]
     if home is not None:
@@ -110,11 +132,10 @@ def make_setuptools_develop_args(
 
 
 def make_setuptools_egg_info_args(
-    setup_py_path,  # type: str
-    egg_info_dir,  # type: Optional[str]
-    no_user_config,  # type: bool
-):
-    # type: (...) -> List[str]
+    setup_py_path: str,
+    egg_info_dir: Optional[str],
+    no_user_config: bool,
+) -> List[str]:
     args = make_setuptools_shim_args(setup_py_path, no_user_config=no_user_config)
 
     args += ["egg_info"]
@@ -123,51 +144,3 @@ def make_setuptools_egg_info_args(
         args += ["--egg-base", egg_info_dir]
 
     return args
-
-
-def make_setuptools_install_args(
-    setup_py_path,  # type: str
-    global_options,  # type: Sequence[str]
-    install_options,  # type: Sequence[str]
-    record_filename,  # type: str
-    root,  # type: Optional[str]
-    prefix,  # type: Optional[str]
-    header_dir,  # type: Optional[str]
-    home,  # type: Optional[str]
-    use_user_site,  # type: bool
-    no_user_config,  # type: bool
-    pycompile,  # type: bool
-):
-    # type: (...) -> List[str]
-    assert not (use_user_site and prefix)
-    assert not (use_user_site and root)
-
-    args = make_setuptools_shim_args(
-        setup_py_path,
-        global_options=global_options,
-        no_user_config=no_user_config,
-        unbuffered_output=True,
-    )
-    args += ["install", "--record", record_filename]
-    args += ["--single-version-externally-managed"]
-
-    if root is not None:
-        args += ["--root", root]
-    if prefix is not None:
-        args += ["--prefix", prefix]
-    if home is not None:
-        args += ["--home", home]
-    if use_user_site:
-        args += ["--user", "--prefix="]
-
-    if pycompile:
-        args += ["--compile"]
-    else:
-        args += ["--no-compile"]
-
-    if header_dir:
-        args += ["--install-headers", header_dir]
-
-    args += install_options
-
-    return args
diff --git a/env/Lib/site-packages/pip/_internal/utils/subprocess.py b/env/Lib/site-packages/pip/_internal/utils/subprocess.py
index 2c8cf212..1e8ff50e 100644
--- a/env/Lib/site-packages/pip/_internal/utils/subprocess.py
+++ b/env/Lib/site-packages/pip/_internal/utils/subprocess.py
@@ -2,25 +2,38 @@ import logging
 import os
 import shlex
 import subprocess
-from typing import Any, Callable, Iterable, List, Mapping, Optional, Union
+from typing import (
+    TYPE_CHECKING,
+    Any,
+    Callable,
+    Iterable,
+    List,
+    Mapping,
+    Optional,
+    Union,
+)
+
+from pip._vendor.rich.markup import escape
 
 from pip._internal.cli.spinners import SpinnerInterface, open_spinner
 from pip._internal.exceptions import InstallationSubprocessError
-from pip._internal.utils.logging import subprocess_logger
+from pip._internal.utils.logging import VERBOSE, subprocess_logger
 from pip._internal.utils.misc import HiddenText
 
-CommandArgs = List[Union[str, HiddenText]]
-
+if TYPE_CHECKING:
+    # Literal was introduced in Python 3.8.
+    #
+    # TODO: Remove `if TYPE_CHECKING` when dropping support for Python 3.7.
+    from typing import Literal
 
-LOG_DIVIDER = "----------------------------------------"
+CommandArgs = List[Union[str, HiddenText]]
 
 
-def make_command(*args):
-    # type: (Union[str, HiddenText, CommandArgs]) -> CommandArgs
+def make_command(*args: Union[str, HiddenText, CommandArgs]) -> CommandArgs:
     """
     Create a CommandArgs object.
     """
-    command_args = []  # type: CommandArgs
+    command_args: CommandArgs = []
     for arg in args:
         # Check for list instead of CommandArgs since CommandArgs is
         # only known during type-checking.
@@ -33,8 +46,7 @@ def make_command(*args):
     return command_args
 
 
-def format_command_args(args):
-    # type: (Union[List[str], CommandArgs]) -> str
+def format_command_args(args: Union[List[str], CommandArgs]) -> str:
     """
     Format command arguments for display.
     """
@@ -49,64 +61,27 @@ def format_command_args(args):
     )
 
 
-def reveal_command_args(args):
-    # type: (Union[List[str], CommandArgs]) -> List[str]
+def reveal_command_args(args: Union[List[str], CommandArgs]) -> List[str]:
     """
     Return the arguments in their raw, unredacted form.
     """
     return [arg.secret if isinstance(arg, HiddenText) else arg for arg in args]
 
 
-def make_subprocess_output_error(
-    cmd_args,  # type: Union[List[str], CommandArgs]
-    cwd,  # type: Optional[str]
-    lines,  # type: List[str]
-    exit_status,  # type: int
-):
-    # type: (...) -> str
-    """
-    Create and return the error message to use to log a subprocess error
-    with command output.
-
-    :param lines: A list of lines, each ending with a newline.
-    """
-    command = format_command_args(cmd_args)
-
-    # We know the joined output value ends in a newline.
-    output = "".join(lines)
-    msg = (
-        # Use a unicode string to avoid "UnicodeEncodeError: 'ascii'
-        # codec can't encode character ..." in Python 2 when a format
-        # argument (e.g. `output`) has a non-ascii character.
-        "Command errored out with exit status {exit_status}:\n"
-        " command: {command_display}\n"
-        "     cwd: {cwd_display}\n"
-        "Complete output ({line_count} lines):\n{output}{divider}"
-    ).format(
-        exit_status=exit_status,
-        command_display=command,
-        cwd_display=cwd,
-        line_count=len(lines),
-        output=output,
-        divider=LOG_DIVIDER,
-    )
-    return msg
-
-
 def call_subprocess(
-    cmd,  # type: Union[List[str], CommandArgs]
-    show_stdout=False,  # type: bool
-    cwd=None,  # type: Optional[str]
-    on_returncode="raise",  # type: str
-    extra_ok_returncodes=None,  # type: Optional[Iterable[int]]
-    command_desc=None,  # type: Optional[str]
-    extra_environ=None,  # type: Optional[Mapping[str, Any]]
-    unset_environ=None,  # type: Optional[Iterable[str]]
-    spinner=None,  # type: Optional[SpinnerInterface]
-    log_failed_cmd=True,  # type: Optional[bool]
-    stdout_only=False,  # type: Optional[bool]
-):
-    # type: (...) -> str
+    cmd: Union[List[str], CommandArgs],
+    show_stdout: bool = False,
+    cwd: Optional[str] = None,
+    on_returncode: 'Literal["raise", "warn", "ignore"]' = "raise",
+    extra_ok_returncodes: Optional[Iterable[int]] = None,
+    extra_environ: Optional[Mapping[str, Any]] = None,
+    unset_environ: Optional[Iterable[str]] = None,
+    spinner: Optional[SpinnerInterface] = None,
+    log_failed_cmd: Optional[bool] = True,
+    stdout_only: Optional[bool] = False,
+    *,
+    command_desc: str,
+) -> str:
     """
     Args:
       show_stdout: if true, use INFO to log the subprocess's stderr and
@@ -141,13 +116,13 @@ def call_subprocess(
     # replaced by INFO.
     if show_stdout:
         # Then log the subprocess output at INFO level.
-        log_subprocess = subprocess_logger.info
+        log_subprocess: Callable[..., None] = subprocess_logger.info
         used_level = logging.INFO
     else:
-        # Then log the subprocess output using DEBUG.  This also ensures
+        # Then log the subprocess output using VERBOSE.  This also ensures
         # it will be logged to the log file (aka user_log), if enabled.
-        log_subprocess = subprocess_logger.debug
-        used_level = logging.DEBUG
+        log_subprocess = subprocess_logger.verbose
+        used_level = VERBOSE
 
     # Whether the subprocess will be visible in the console.
     showing_subprocess = subprocess_logger.getEffectiveLevel() <= used_level
@@ -156,9 +131,6 @@ def call_subprocess(
     # and we have a spinner.
     use_spinner = not showing_subprocess and spinner is not None
 
-    if command_desc is None:
-        command_desc = format_command_args(cmd)
-
     log_subprocess("Running command %s", command_desc)
     env = os.environ.copy()
     if extra_environ:
@@ -191,7 +163,7 @@ def call_subprocess(
         proc.stdin.close()
         # In this mode, stdout and stderr are in the same pipe.
         while True:
-            line = proc.stdout.readline()  # type: str
+            line: str = proc.stdout.readline()
             if not line:
                 break
             line = line.rstrip()
@@ -231,17 +203,25 @@ def call_subprocess(
             spinner.finish("done")
     if proc_had_error:
         if on_returncode == "raise":
-            if not showing_subprocess and log_failed_cmd:
-                # Then the subprocess streams haven't been logged to the
-                # console yet.
-                msg = make_subprocess_output_error(
-                    cmd_args=cmd,
-                    cwd=cwd,
-                    lines=all_output,
-                    exit_status=proc.returncode,
+            error = InstallationSubprocessError(
+                command_description=command_desc,
+                exit_code=proc.returncode,
+                output_lines=all_output if not showing_subprocess else None,
+            )
+            if log_failed_cmd:
+                subprocess_logger.error("[present-rich] %s", error)
+                subprocess_logger.verbose(
+                    "[bold magenta]full command[/]: [blue]%s[/]",
+                    escape(format_command_args(cmd)),
+                    extra={"markup": True},
                 )
-                subprocess_logger.error(msg)
-            raise InstallationSubprocessError(proc.returncode, command_desc)
+                subprocess_logger.verbose(
+                    "[bold magenta]cwd[/]: %s",
+                    escape(cwd or "[inherit]"),
+                    extra={"markup": True},
+                )
+
+            raise error
         elif on_returncode == "warn":
             subprocess_logger.warning(
                 'Command "%s" had error code %s in %s',
@@ -256,23 +236,22 @@ def call_subprocess(
     return output
 
 
-def runner_with_spinner_message(message):
-    # type: (str) -> Callable[..., None]
+def runner_with_spinner_message(message: str) -> Callable[..., None]:
     """Provide a subprocess_runner that shows a spinner message.
 
-    Intended for use with for pep517's Pep517HookCaller. Thus, the runner has
-    an API that matches what's expected by Pep517HookCaller.subprocess_runner.
+    Intended for use with for BuildBackendHookCaller. Thus, the runner has
+    an API that matches what's expected by BuildBackendHookCaller.subprocess_runner.
     """
 
     def runner(
-        cmd,  # type: List[str]
-        cwd=None,  # type: Optional[str]
-        extra_environ=None,  # type: Optional[Mapping[str, Any]]
-    ):
-        # type: (...) -> None
+        cmd: List[str],
+        cwd: Optional[str] = None,
+        extra_environ: Optional[Mapping[str, Any]] = None,
+    ) -> None:
         with open_spinner(message) as spinner:
             call_subprocess(
                 cmd,
+                command_desc=message,
                 cwd=cwd,
                 extra_environ=extra_environ,
                 spinner=spinner,
diff --git a/env/Lib/site-packages/pip/_internal/utils/temp_dir.py b/env/Lib/site-packages/pip/_internal/utils/temp_dir.py
index 477cbe6b..8ee8a1cb 100644
--- a/env/Lib/site-packages/pip/_internal/utils/temp_dir.py
+++ b/env/Lib/site-packages/pip/_internal/utils/temp_dir.py
@@ -4,7 +4,7 @@ import logging
 import os.path
 import tempfile
 from contextlib import ExitStack, contextmanager
-from typing import Any, Dict, Iterator, Optional, TypeVar, Union
+from typing import Any, Dict, Generator, Optional, TypeVar, Union
 
 from pip._internal.utils.misc import enum, rmtree
 
@@ -22,12 +22,11 @@ tempdir_kinds = enum(
 )
 
 
-_tempdir_manager = None  # type: Optional[ExitStack]
+_tempdir_manager: Optional[ExitStack] = None
 
 
 @contextmanager
-def global_tempdir_manager():
-    # type: () -> Iterator[None]
+def global_tempdir_manager() -> Generator[None, None, None]:
     global _tempdir_manager
     with ExitStack() as stack:
         old_tempdir_manager, _tempdir_manager = _tempdir_manager, stack
@@ -40,31 +39,27 @@ def global_tempdir_manager():
 class TempDirectoryTypeRegistry:
     """Manages temp directory behavior"""
 
-    def __init__(self):
-        # type: () -> None
-        self._should_delete = {}  # type: Dict[str, bool]
+    def __init__(self) -> None:
+        self._should_delete: Dict[str, bool] = {}
 
-    def set_delete(self, kind, value):
-        # type: (str, bool) -> None
+    def set_delete(self, kind: str, value: bool) -> None:
         """Indicate whether a TempDirectory of the given kind should be
         auto-deleted.
         """
         self._should_delete[kind] = value
 
-    def get_delete(self, kind):
-        # type: (str) -> bool
+    def get_delete(self, kind: str) -> bool:
         """Get configured auto-delete flag for a given TempDirectory type,
         default True.
         """
         return self._should_delete.get(kind, True)
 
 
-_tempdir_registry = None  # type: Optional[TempDirectoryTypeRegistry]
+_tempdir_registry: Optional[TempDirectoryTypeRegistry] = None
 
 
 @contextmanager
-def tempdir_registry():
-    # type: () -> Iterator[TempDirectoryTypeRegistry]
+def tempdir_registry() -> Generator[TempDirectoryTypeRegistry, None, None]:
     """Provides a scoped global tempdir registry that can be used to dictate
     whether directories should be deleted.
     """
@@ -107,10 +102,10 @@ class TempDirectory:
 
     def __init__(
         self,
-        path=None,  # type: Optional[str]
-        delete=_default,  # type: Union[bool, None, _Default]
-        kind="temp",  # type: str
-        globally_managed=False,  # type: bool
+        path: Optional[str] = None,
+        delete: Union[bool, None, _Default] = _default,
+        kind: str = "temp",
+        globally_managed: bool = False,
     ):
         super().__init__()
 
@@ -139,21 +134,17 @@ class TempDirectory:
             _tempdir_manager.enter_context(self)
 
     @property
-    def path(self):
-        # type: () -> str
+    def path(self) -> str:
         assert not self._deleted, f"Attempted to access deleted path: {self._path}"
         return self._path
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         return f"<{self.__class__.__name__} {self.path!r}>"
 
-    def __enter__(self):
-        # type: (_T) -> _T
+    def __enter__(self: _T) -> _T:
         return self
 
-    def __exit__(self, exc, value, tb):
-        # type: (Any, Any, Any) -> None
+    def __exit__(self, exc: Any, value: Any, tb: Any) -> None:
         if self.delete is not None:
             delete = self.delete
         elif _tempdir_registry:
@@ -164,8 +155,7 @@ class TempDirectory:
         if delete:
             self.cleanup()
 
-    def _create(self, kind):
-        # type: (str) -> str
+    def _create(self, kind: str) -> str:
         """Create a temporary directory and store its path in self.path"""
         # We realpath here because some systems have their default tmpdir
         # symlinked to another directory.  This tends to confuse build
@@ -175,8 +165,7 @@ class TempDirectory:
         logger.debug("Created temporary directory: %s", path)
         return path
 
-    def cleanup(self):
-        # type: () -> None
+    def cleanup(self) -> None:
         """Remove the temporary directory created and reset state"""
         self._deleted = True
         if not os.path.exists(self._path):
@@ -206,14 +195,12 @@ class AdjacentTempDirectory(TempDirectory):
     # with leading '-' and invalid metadata
     LEADING_CHARS = "-~.=%0123456789"
 
-    def __init__(self, original, delete=None):
-        # type: (str, Optional[bool]) -> None
+    def __init__(self, original: str, delete: Optional[bool] = None) -> None:
         self.original = original.rstrip("/\\")
         super().__init__(delete=delete)
 
     @classmethod
-    def _generate_names(cls, name):
-        # type: (str) -> Iterator[str]
+    def _generate_names(cls, name: str) -> Generator[str, None, None]:
         """Generates a series of temporary names.
 
         The algorithm replaces the leading characters in the name
@@ -238,8 +225,7 @@ class AdjacentTempDirectory(TempDirectory):
                 if new_name != name:
                     yield new_name
 
-    def _create(self, kind):
-        # type: (str) -> str
+    def _create(self, kind: str) -> str:
         root, name = os.path.split(self.original)
         for candidate in self._generate_names(name):
             path = os.path.join(root, candidate)
diff --git a/env/Lib/site-packages/pip/_internal/utils/unpacking.py b/env/Lib/site-packages/pip/_internal/utils/unpacking.py
index 44ac4753..78b5c13c 100644
--- a/env/Lib/site-packages/pip/_internal/utils/unpacking.py
+++ b/env/Lib/site-packages/pip/_internal/utils/unpacking.py
@@ -40,16 +40,14 @@ except ImportError:
     logger.debug("lzma module is not available")
 
 
-def current_umask():
-    # type: () -> int
+def current_umask() -> int:
     """Get the current umask which involves having to set it temporarily."""
     mask = os.umask(0)
     os.umask(mask)
     return mask
 
 
-def split_leading_dir(path):
-    # type: (str) -> List[str]
+def split_leading_dir(path: str) -> List[str]:
     path = path.lstrip("/").lstrip("\\")
     if "/" in path and (
         ("\\" in path and path.find("/") < path.find("\\")) or "\\" not in path
@@ -61,8 +59,7 @@ def split_leading_dir(path):
         return [path, ""]
 
 
-def has_leading_dir(paths):
-    # type: (Iterable[str]) -> bool
+def has_leading_dir(paths: Iterable[str]) -> bool:
     """Returns true if all the paths have the same leading path name
     (i.e., everything is in one subdirectory in an archive)"""
     common_prefix = None
@@ -77,8 +74,7 @@ def has_leading_dir(paths):
     return True
 
 
-def is_within_directory(directory, target):
-    # type: (str, str) -> bool
+def is_within_directory(directory: str, target: str) -> bool:
     """
     Return true if the absolute path of target is within the directory
     """
@@ -89,8 +85,7 @@ def is_within_directory(directory, target):
     return prefix == abs_directory
 
 
-def set_extracted_file_to_default_mode_plus_executable(path):
-    # type: (str) -> None
+def set_extracted_file_to_default_mode_plus_executable(path: str) -> None:
     """
     Make file present at path have execute for user/group/world
     (chmod +x) is no-op on windows per python docs
@@ -98,16 +93,14 @@ def set_extracted_file_to_default_mode_plus_executable(path):
     os.chmod(path, (0o777 & ~current_umask() | 0o111))
 
 
-def zip_item_is_executable(info):
-    # type: (ZipInfo) -> bool
+def zip_item_is_executable(info: ZipInfo) -> bool:
     mode = info.external_attr >> 16
     # if mode and regular file and any execute permissions for
     # user/group/world?
     return bool(mode and stat.S_ISREG(mode) and mode & 0o111)
 
 
-def unzip_file(filename, location, flatten=True):
-    # type: (str, str, bool) -> None
+def unzip_file(filename: str, location: str, flatten: bool = True) -> None:
     """
     Unzip the file (with path `filename`) to the destination `location`.  All
     files are written based on system defaults and umask (i.e. permissions are
@@ -153,8 +146,7 @@ def unzip_file(filename, location, flatten=True):
         zipfp.close()
 
 
-def untar_file(filename, location):
-    # type: (str, str) -> None
+def untar_file(filename: str, location: str) -> None:
     """
     Untar the file (with path `filename`) to the destination `location`.
     All files are written based on system defaults and umask (i.e. permissions
@@ -178,7 +170,7 @@ def untar_file(filename, location):
             filename,
         )
         mode = "r:*"
-    tar = tarfile.open(filename, mode)
+    tar = tarfile.open(filename, mode, encoding="utf-8")
     try:
         leading = has_leading_dir([member.name for member in tar.getmembers()])
         for member in tar.getmembers():
@@ -196,8 +188,7 @@ def untar_file(filename, location):
                 ensure_dir(path)
             elif member.issym():
                 try:
-                    # https://github.com/python/typeshed/issues/2673
-                    tar._extract_member(member, path)  # type: ignore
+                    tar._extract_member(member, path)
                 except Exception as exc:
                     # Some corrupt tar files seem to produce this
                     # (specifically bad symlinks)
@@ -236,11 +227,10 @@ def untar_file(filename, location):
 
 
 def unpack_file(
-    filename,  # type: str
-    location,  # type: str
-    content_type=None,  # type: Optional[str]
-):
-    # type: (...) -> None
+    filename: str,
+    location: str,
+    content_type: Optional[str] = None,
+) -> None:
     filename = os.path.realpath(filename)
     if (
         content_type == "application/zip"
diff --git a/env/Lib/site-packages/pip/_internal/utils/urls.py b/env/Lib/site-packages/pip/_internal/utils/urls.py
index 50a04d86..6ba2e04f 100644
--- a/env/Lib/site-packages/pip/_internal/utils/urls.py
+++ b/env/Lib/site-packages/pip/_internal/utils/urls.py
@@ -1,19 +1,19 @@
 import os
-import sys
+import string
 import urllib.parse
 import urllib.request
 from typing import Optional
 
+from .compat import WINDOWS
 
-def get_url_scheme(url):
-    # type: (str) -> Optional[str]
+
+def get_url_scheme(url: str) -> Optional[str]:
     if ":" not in url:
         return None
     return url.split(":", 1)[0].lower()
 
 
-def path_to_url(path):
-    # type: (str) -> str
+def path_to_url(path: str) -> str:
     """
     Convert a path to a file: URL.  The path will be made absolute and have
     quoted path parts.
@@ -23,8 +23,7 @@ def path_to_url(path):
     return url
 
 
-def url_to_path(url):
-    # type: (str) -> str
+def url_to_path(url: str) -> str:
     """
     Convert a file: URL to a path.
     """
@@ -37,7 +36,7 @@ def url_to_path(url):
     if not netloc or netloc == "localhost":
         # According to RFC 8089, same as empty authority.
         netloc = ""
-    elif sys.platform == "win32":
+    elif WINDOWS:
         # If we have a UNC path, prepend UNC share notation.
         netloc = "\\\\" + netloc
     else:
@@ -46,4 +45,18 @@ def url_to_path(url):
         )
 
     path = urllib.request.url2pathname(netloc + path)
+
+    # On Windows, urlsplit parses the path as something like "/C:/Users/foo".
+    # This creates issues for path-related functions like io.open(), so we try
+    # to detect and strip the leading slash.
+    if (
+        WINDOWS
+        and not netloc  # Not UNC.
+        and len(path) >= 3
+        and path[0] == "/"  # Leading slash to strip.
+        and path[1] in string.ascii_letters  # Drive letter.
+        and path[2:4] in (":", ":/")  # Colon + end of string, or colon + absolute path.
+    ):
+        path = path[1:]
+
     return path
diff --git a/env/Lib/site-packages/pip/_internal/utils/virtualenv.py b/env/Lib/site-packages/pip/_internal/utils/virtualenv.py
index 51cacb55..882e36f5 100644
--- a/env/Lib/site-packages/pip/_internal/utils/virtualenv.py
+++ b/env/Lib/site-packages/pip/_internal/utils/virtualenv.py
@@ -11,8 +11,7 @@ _INCLUDE_SYSTEM_SITE_PACKAGES_REGEX = re.compile(
 )
 
 
-def _running_under_venv():
-    # type: () -> bool
+def _running_under_venv() -> bool:
     """Checks if sys.base_prefix and sys.prefix match.
 
     This handles PEP 405 compliant virtual environments.
@@ -20,8 +19,7 @@ def _running_under_venv():
     return sys.prefix != getattr(sys, "base_prefix", sys.prefix)
 
 
-def _running_under_regular_virtualenv():
-    # type: () -> bool
+def _running_under_legacy_virtualenv() -> bool:
     """Checks if sys.real_prefix is set.
 
     This handles virtual environments created with pypa's virtualenv.
@@ -30,14 +28,12 @@ def _running_under_regular_virtualenv():
     return hasattr(sys, "real_prefix")
 
 
-def running_under_virtualenv():
-    # type: () -> bool
-    """Return True if we're running inside a virtualenv, False otherwise."""
-    return _running_under_venv() or _running_under_regular_virtualenv()
+def running_under_virtualenv() -> bool:
+    """True if we're running inside a virtual environment, False otherwise."""
+    return _running_under_venv() or _running_under_legacy_virtualenv()
 
 
-def _get_pyvenv_cfg_lines():
-    # type: () -> Optional[List[str]]
+def _get_pyvenv_cfg_lines() -> Optional[List[str]]:
     """Reads {sys.prefix}/pyvenv.cfg and returns its contents as list of lines
 
     Returns None, if it could not read/access the file.
@@ -52,8 +48,7 @@ def _get_pyvenv_cfg_lines():
         return None
 
 
-def _no_global_under_venv():
-    # type: () -> bool
+def _no_global_under_venv() -> bool:
     """Check `{sys.prefix}/pyvenv.cfg` for system site-packages inclusion
 
     PEP 405 specifies that when system site-packages are not supposed to be
@@ -82,8 +77,7 @@ def _no_global_under_venv():
     return False
 
 
-def _no_global_under_regular_virtualenv():
-    # type: () -> bool
+def _no_global_under_legacy_virtualenv() -> bool:
     """Check if "no-global-site-packages.txt" exists beside site.py
 
     This mirrors logic in pypa/virtualenv for determining whether system
@@ -97,15 +91,14 @@ def _no_global_under_regular_virtualenv():
     return os.path.exists(no_global_site_packages_file)
 
 
-def virtualenv_no_global():
-    # type: () -> bool
+def virtualenv_no_global() -> bool:
     """Returns a boolean, whether running in venv with no system site-packages."""
     # PEP 405 compliance needs to be checked first since virtualenv >=20 would
     # return True for both checks, but is only able to use the PEP 405 config.
     if _running_under_venv():
         return _no_global_under_venv()
 
-    if _running_under_regular_virtualenv():
-        return _no_global_under_regular_virtualenv()
+    if _running_under_legacy_virtualenv():
+        return _no_global_under_legacy_virtualenv()
 
     return False
diff --git a/env/Lib/site-packages/pip/_internal/utils/wheel.py b/env/Lib/site-packages/pip/_internal/utils/wheel.py
index 42f08084..e5e3f34e 100644
--- a/env/Lib/site-packages/pip/_internal/utils/wheel.py
+++ b/env/Lib/site-packages/pip/_internal/utils/wheel.py
@@ -4,14 +4,12 @@
 import logging
 from email.message import Message
 from email.parser import Parser
-from typing import Dict, Tuple
+from typing import Tuple
 from zipfile import BadZipFile, ZipFile
 
 from pip._vendor.packaging.utils import canonicalize_name
-from pip._vendor.pkg_resources import DistInfoDistribution, Distribution
 
 from pip._internal.exceptions import UnsupportedWheel
-from pip._internal.utils.pkg_resources import DictMetadata
 
 VERSION_COMPATIBLE = (1, 0)
 
@@ -19,53 +17,7 @@ VERSION_COMPATIBLE = (1, 0)
 logger = logging.getLogger(__name__)
 
 
-class WheelMetadata(DictMetadata):
-    """Metadata provider that maps metadata decoding exceptions to our
-    internal exception type.
-    """
-
-    def __init__(self, metadata, wheel_name):
-        # type: (Dict[str, bytes], str) -> None
-        super().__init__(metadata)
-        self._wheel_name = wheel_name
-
-    def get_metadata(self, name):
-        # type: (str) -> str
-        try:
-            return super().get_metadata(name)
-        except UnicodeDecodeError as e:
-            # Augment the default error with the origin of the file.
-            raise UnsupportedWheel(
-                f"Error decoding metadata for {self._wheel_name}: {e}"
-            )
-
-
-def pkg_resources_distribution_for_wheel(wheel_zip, name, location):
-    # type: (ZipFile, str, str) -> Distribution
-    """Get a pkg_resources distribution given a wheel.
-
-    :raises UnsupportedWheel: on any errors
-    """
-    info_dir, _ = parse_wheel(wheel_zip, name)
-
-    metadata_files = [p for p in wheel_zip.namelist() if p.startswith(f"{info_dir}/")]
-
-    metadata_text = {}  # type: Dict[str, bytes]
-    for path in metadata_files:
-        _, metadata_name = path.split("/", 1)
-
-        try:
-            metadata_text[metadata_name] = read_wheel_metadata_file(wheel_zip, path)
-        except UnsupportedWheel as e:
-            raise UnsupportedWheel("{} has an invalid wheel, {}".format(name, str(e)))
-
-    metadata = WheelMetadata(metadata_text, location)
-
-    return DistInfoDistribution(location=location, metadata=metadata, project_name=name)
-
-
-def parse_wheel(wheel_zip, name):
-    # type: (ZipFile, str) -> Tuple[str, Message]
+def parse_wheel(wheel_zip: ZipFile, name: str) -> Tuple[str, Message]:
     """Extract information from the provided wheel, ensuring it meets basic
     standards.
 
@@ -83,8 +35,7 @@ def parse_wheel(wheel_zip, name):
     return info_dir, metadata
 
 
-def wheel_dist_info_dir(source, name):
-    # type: (ZipFile, str) -> str
+def wheel_dist_info_dir(source: ZipFile, name: str) -> str:
     """Returns the name of the contained .dist-info directory.
 
     Raises AssertionError or UnsupportedWheel if not found, >1 found, or
@@ -117,8 +68,7 @@ def wheel_dist_info_dir(source, name):
     return info_dir
 
 
-def read_wheel_metadata_file(source, path):
-    # type: (ZipFile, str) -> bytes
+def read_wheel_metadata_file(source: ZipFile, path: str) -> bytes:
     try:
         return source.read(path)
         # BadZipFile for general corruption, KeyError for missing entry,
@@ -127,8 +77,7 @@ def read_wheel_metadata_file(source, path):
         raise UnsupportedWheel(f"could not read {path!r} file: {e!r}")
 
 
-def wheel_metadata(source, dist_info_dir):
-    # type: (ZipFile, str) -> Message
+def wheel_metadata(source: ZipFile, dist_info_dir: str) -> Message:
     """Return the WHEEL metadata of an extracted wheel, if possible.
     Otherwise, raise UnsupportedWheel.
     """
@@ -147,8 +96,7 @@ def wheel_metadata(source, dist_info_dir):
     return Parser().parsestr(wheel_text)
 
 
-def wheel_version(wheel_data):
-    # type: (Message) -> Tuple[int, ...]
+def wheel_version(wheel_data: Message) -> Tuple[int, ...]:
     """Given WHEEL metadata, return the parsed Wheel-Version.
     Otherwise, raise UnsupportedWheel.
     """
@@ -164,8 +112,7 @@ def wheel_version(wheel_data):
         raise UnsupportedWheel(f"invalid Wheel-Version: {version!r}")
 
 
-def check_compatibility(version, name):
-    # type: (Tuple[int, ...], str) -> None
+def check_compatibility(version: Tuple[int, ...], name: str) -> None:
     """Raises errors or warns if called with an incompatible Wheel-Version.
 
     pip should refuse to install a Wheel-Version that's a major series
diff --git a/env/Lib/site-packages/pip/_internal/vcs/__init__.py b/env/Lib/site-packages/pip/_internal/vcs/__init__.py
index 30025d63..b6beddbe 100644
--- a/env/Lib/site-packages/pip/_internal/vcs/__init__.py
+++ b/env/Lib/site-packages/pip/_internal/vcs/__init__.py
@@ -8,6 +8,7 @@ import pip._internal.vcs.mercurial
 import pip._internal.vcs.subversion  # noqa: F401
 from pip._internal.vcs.versioncontrol import (  # noqa: F401
     RemoteNotFoundError,
+    RemoteNotValidError,
     is_url,
     make_vcs_requirement_url,
     vcs,
diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index e549a9ac9dbd8a2d84af83182525b1f79d174be6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 512
zcmYe~<>g{vU|^UdaWK`IiGkrUh=Yuo7#J8F7#J9eZ5S9BQW#Pga~Pr+!88+;W`@!%
zV45k1HJ2@lEtfrtJ(nYjBbPIZlaV2XF_=M<`6b9)KTVcf!a=FI`6a1-`6X`orFki?
zMMe2Vx7ad^<4cQjZb{@OW~auNB^SpRr52WE7NzE<=9PeDn9GujHMwp{6l50Y#b@S~
zq!#5R=IE6r7waV@RwX7D-C{1tEVw0#DV?5Ka!VRhI5)K@xwI%VG3S;HretwxQdw$I
zab|wrEd@+js8n)(UP)1YP7x@OikKM~7>Zax1S<mr!%BuC9uONu{Hk-diU}=FEh>&l
z%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwu
ziAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Slx@hlze!a<P7Vd}dx|
fNqoFsLFFwDo80`A(wtN~kjsiW7#J8h7$Fb<7p0rH

diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/bazaar.cpython-39.pyc
deleted file mode 100644
index 2c9e5c9251b7c6adc92c946de63f4868b712065d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3028
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
B`VasB

diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/git.cpython-39.pyc
deleted file mode 100644
index 031887dbba1a53e17922590fbc35ec535f7a1f8a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 10004
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
I1`w1702D0+z5oCK

diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/mercurial.cpython-39.pyc
deleted file mode 100644
index 1c526459dddd98473d542f480fa2345d22d255ec..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4649
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
IsAu2?0E(iwy8r+H

diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/subversion.cpython-39.pyc
deleted file mode 100644
index e3997e1e3aab0aacb1ea4cc6fca98f5ed0143ec0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc b/env/Lib/site-packages/pip/_internal/vcs/__pycache__/versioncontrol.cpython-39.pyc
deleted file mode 100644
index 9db88480547ac3442228bbab60c5bd78f619fc13..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 19128
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
P$RQ)Z!sp2s&BhD>=rpk0

diff --git a/env/Lib/site-packages/pip/_internal/vcs/bazaar.py b/env/Lib/site-packages/pip/_internal/vcs/bazaar.py
index 42b68773..20a17ed0 100644
--- a/env/Lib/site-packages/pip/_internal/vcs/bazaar.py
+++ b/env/Lib/site-packages/pip/_internal/vcs/bazaar.py
@@ -16,61 +16,76 @@ logger = logging.getLogger(__name__)
 
 
 class Bazaar(VersionControl):
-    name = 'bzr'
-    dirname = '.bzr'
-    repo_name = 'branch'
+    name = "bzr"
+    dirname = ".bzr"
+    repo_name = "branch"
     schemes = (
-        'bzr+http', 'bzr+https', 'bzr+ssh', 'bzr+sftp', 'bzr+ftp',
-        'bzr+lp', 'bzr+file'
+        "bzr+http",
+        "bzr+https",
+        "bzr+ssh",
+        "bzr+sftp",
+        "bzr+ftp",
+        "bzr+lp",
+        "bzr+file",
     )
 
     @staticmethod
-    def get_base_rev_args(rev):
-        # type: (str) -> List[str]
-        return ['-r', rev]
+    def get_base_rev_args(rev: str) -> List[str]:
+        return ["-r", rev]
 
-    def fetch_new(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def fetch_new(
+        self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int
+    ) -> None:
         rev_display = rev_options.to_display()
         logger.info(
-            'Checking out %s%s to %s',
+            "Checking out %s%s to %s",
             url,
             rev_display,
             display_path(dest),
         )
-        cmd_args = (
-            make_command('branch', '-q', rev_options.to_args(), url, dest)
+        if verbosity <= 0:
+            flag = "--quiet"
+        elif verbosity == 1:
+            flag = ""
+        else:
+            flag = f"-{'v'*verbosity}"
+        cmd_args = make_command(
+            "checkout", "--lightweight", flag, rev_options.to_args(), url, dest
         )
         self.run_command(cmd_args)
 
-    def switch(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
-        self.run_command(make_command('switch', url), cwd=dest)
+    def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
+        self.run_command(make_command("switch", url), cwd=dest)
 
-    def update(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
-        cmd_args = make_command('pull', '-q', rev_options.to_args())
+    def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
+        output = self.run_command(
+            make_command("info"), show_stdout=False, stdout_only=True, cwd=dest
+        )
+        if output.startswith("Standalone "):
+            # Older versions of pip used to create standalone branches.
+            # Convert the standalone branch to a checkout by calling "bzr bind".
+            cmd_args = make_command("bind", "-q", url)
+            self.run_command(cmd_args, cwd=dest)
+
+        cmd_args = make_command("update", "-q", rev_options.to_args())
         self.run_command(cmd_args, cwd=dest)
 
     @classmethod
-    def get_url_rev_and_auth(cls, url):
-        # type: (str) -> Tuple[str, Optional[str], AuthInfo]
-        # hotfix the URL scheme after removing bzr+ from bzr+ssh:// readd it
+    def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]:
+        # hotfix the URL scheme after removing bzr+ from bzr+ssh:// re-add it
         url, rev, user_pass = super().get_url_rev_and_auth(url)
-        if url.startswith('ssh://'):
-            url = 'bzr+' + url
+        if url.startswith("ssh://"):
+            url = "bzr+" + url
         return url, rev, user_pass
 
     @classmethod
-    def get_remote_url(cls, location):
-        # type: (str) -> str
+    def get_remote_url(cls, location: str) -> str:
         urls = cls.run_command(
-            ['info'], show_stdout=False, stdout_only=True, cwd=location
+            ["info"], show_stdout=False, stdout_only=True, cwd=location
         )
         for line in urls.splitlines():
             line = line.strip()
-            for x in ('checkout of branch: ',
-                      'parent branch: '):
+            for x in ("checkout of branch: ", "parent branch: "):
                 if line.startswith(x):
                     repo = line.split(x)[1]
                     if cls._is_local_repository(repo):
@@ -79,16 +94,17 @@ class Bazaar(VersionControl):
         raise RemoteNotFoundError
 
     @classmethod
-    def get_revision(cls, location):
-        # type: (str) -> str
+    def get_revision(cls, location: str) -> str:
         revision = cls.run_command(
-            ['revno'], show_stdout=False, stdout_only=True, cwd=location,
+            ["revno"],
+            show_stdout=False,
+            stdout_only=True,
+            cwd=location,
         )
         return revision.splitlines()[-1]
 
     @classmethod
-    def is_commit_id_equal(cls, dest, name):
-        # type: (str, Optional[str]) -> bool
+    def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool:
         """Always assume the versions don't match"""
         return False
 
diff --git a/env/Lib/site-packages/pip/_internal/vcs/git.py b/env/Lib/site-packages/pip/_internal/vcs/git.py
index b7c1b9fe..8d1d4993 100644
--- a/env/Lib/site-packages/pip/_internal/vcs/git.py
+++ b/env/Lib/site-packages/pip/_internal/vcs/git.py
@@ -1,22 +1,21 @@
 import logging
 import os.path
+import pathlib
 import re
 import urllib.parse
 import urllib.request
 from typing import List, Optional, Tuple
 
-from pip._vendor.packaging.version import _BaseVersion
-from pip._vendor.packaging.version import parse as parse_version
-
 from pip._internal.exceptions import BadCommand, InstallationError
 from pip._internal.utils.misc import HiddenText, display_path, hide_url
 from pip._internal.utils.subprocess import make_command
 from pip._internal.vcs.versioncontrol import (
     AuthInfo,
     RemoteNotFoundError,
+    RemoteNotValidError,
     RevOptions,
     VersionControl,
-    find_path_to_setup_from_repo_root,
+    find_path_to_project_root_from_repo_root,
     vcs,
 )
 
@@ -27,33 +26,57 @@ urlunsplit = urllib.parse.urlunsplit
 logger = logging.getLogger(__name__)
 
 
-HASH_REGEX = re.compile('^[a-fA-F0-9]{40}$')
+GIT_VERSION_REGEX = re.compile(
+    r"^git version "  # Prefix.
+    r"(\d+)"  # Major.
+    r"\.(\d+)"  # Dot, minor.
+    r"(?:\.(\d+))?"  # Optional dot, patch.
+    r".*$"  # Suffix, including any pre- and post-release segments we don't care about.
+)
+
+HASH_REGEX = re.compile("^[a-fA-F0-9]{40}$")
+
+# SCP (Secure copy protocol) shorthand. e.g. 'git@example.com:foo/bar.git'
+SCP_REGEX = re.compile(
+    r"""^
+    # Optional user, e.g. 'git@'
+    (\w+@)?
+    # Server, e.g. 'github.com'.
+    ([^/:]+):
+    # The server-side path. e.g. 'user/project.git'. Must start with an
+    # alphanumeric character so as not to be confusable with a Windows paths
+    # like 'C:/foo/bar' or 'C:\foo\bar'.
+    (\w[^:]*)
+    $""",
+    re.VERBOSE,
+)
 
 
-def looks_like_hash(sha):
-    # type: (str) -> bool
+def looks_like_hash(sha: str) -> bool:
     return bool(HASH_REGEX.match(sha))
 
 
 class Git(VersionControl):
-    name = 'git'
-    dirname = '.git'
-    repo_name = 'clone'
+    name = "git"
+    dirname = ".git"
+    repo_name = "clone"
     schemes = (
-        'git+http', 'git+https', 'git+ssh', 'git+git', 'git+file',
+        "git+http",
+        "git+https",
+        "git+ssh",
+        "git+git",
+        "git+file",
     )
     # Prevent the user's environment variables from interfering with pip:
     # https://github.com/pypa/pip/issues/1130
-    unset_environ = ('GIT_DIR', 'GIT_WORK_TREE')
-    default_arg_rev = 'HEAD'
+    unset_environ = ("GIT_DIR", "GIT_WORK_TREE")
+    default_arg_rev = "HEAD"
 
     @staticmethod
-    def get_base_rev_args(rev):
-        # type: (str) -> List[str]
+    def get_base_rev_args(rev: str) -> List[str]:
         return [rev]
 
-    def is_immutable_rev_checkout(self, url, dest):
-        # type: (str, str) -> bool
+    def is_immutable_rev_checkout(self, url: str, dest: str) -> bool:
         _, rev_options = self.get_url_rev_options(hide_url(url))
         if not rev_options.rev:
             return False
@@ -64,30 +87,24 @@ class Git(VersionControl):
         # return False in the rare case rev is both a commit hash
         # and a tag or a branch; we don't want to cache in that case
         # because that branch/tag could point to something else in the future
-        is_tag_or_branch = bool(
-            self.get_revision_sha(dest, rev_options.rev)[0]
-        )
+        is_tag_or_branch = bool(self.get_revision_sha(dest, rev_options.rev)[0])
         return not is_tag_or_branch
 
-    def get_git_version(self):
-        # type: () -> _BaseVersion
-        VERSION_PFX = 'git version '
+    def get_git_version(self) -> Tuple[int, ...]:
         version = self.run_command(
-            ['version'], show_stdout=False, stdout_only=True
+            ["version"],
+            command_desc="git version",
+            show_stdout=False,
+            stdout_only=True,
         )
-        if version.startswith(VERSION_PFX):
-            version = version[len(VERSION_PFX):].split()[0]
-        else:
-            version = ''
-        # get first 3 positions of the git version because
-        # on windows it is x.y.z.windows.t, and this parses as
-        # LegacyVersion which always smaller than a Version.
-        version = '.'.join(version.split('.')[:3])
-        return parse_version(version)
+        match = GIT_VERSION_REGEX.match(version)
+        if not match:
+            logger.warning("Can't parse git version: %s", version)
+            return ()
+        return tuple(int(c) for c in match.groups())
 
     @classmethod
-    def get_current_branch(cls, location):
-        # type: (str) -> Optional[str]
+    def get_current_branch(cls, location: str) -> Optional[str]:
         """
         Return the current branch, or None if HEAD isn't at a branch
         (e.g. detached HEAD).
@@ -96,24 +113,23 @@ class Git(VersionControl):
         # HEAD rather than a symbolic ref.  In addition, the -q causes the
         # command to exit with status code 1 instead of 128 in this case
         # and to suppress the message to stderr.
-        args = ['symbolic-ref', '-q', 'HEAD']
+        args = ["symbolic-ref", "-q", "HEAD"]
         output = cls.run_command(
             args,
-            extra_ok_returncodes=(1, ),
+            extra_ok_returncodes=(1,),
             show_stdout=False,
             stdout_only=True,
             cwd=location,
         )
         ref = output.strip()
 
-        if ref.startswith('refs/heads/'):
-            return ref[len('refs/heads/'):]
+        if ref.startswith("refs/heads/"):
+            return ref[len("refs/heads/") :]
 
         return None
 
     @classmethod
-    def get_revision_sha(cls, dest, rev):
-        # type: (str, str) -> Tuple[Optional[str], bool]
+    def get_revision_sha(cls, dest: str, rev: str) -> Tuple[Optional[str], bool]:
         """
         Return (sha_or_none, is_branch), where sha_or_none is a commit hash
         if the revision names a remote branch or tag, otherwise None.
@@ -124,11 +140,11 @@ class Git(VersionControl):
         """
         # Pass rev to pre-filter the list.
         output = cls.run_command(
-            ['show-ref', rev],
+            ["show-ref", rev],
             cwd=dest,
             show_stdout=False,
             stdout_only=True,
-            on_returncode='ignore',
+            on_returncode="ignore",
         )
         refs = {}
         # NOTE: We do not use splitlines here since that would split on other
@@ -143,12 +159,12 @@ class Git(VersionControl):
             except ValueError:
                 # Include the offending line to simplify troubleshooting if
                 # this error ever occurs.
-                raise ValueError(f'unexpected show-ref line: {line!r}')
+                raise ValueError(f"unexpected show-ref line: {line!r}")
 
             refs[ref_name] = ref_sha
 
-        branch_ref = f'refs/remotes/origin/{rev}'
-        tag_ref = f'refs/tags/{rev}'
+        branch_ref = f"refs/remotes/origin/{rev}"
+        tag_ref = f"refs/tags/{rev}"
 
         sha = refs.get(branch_ref)
         if sha is not None:
@@ -159,8 +175,7 @@ class Git(VersionControl):
         return (sha, False)
 
     @classmethod
-    def _should_fetch(cls, dest, rev):
-        # type: (str, str) -> bool
+    def _should_fetch(cls, dest: str, rev: str) -> bool:
         """
         Return true if rev is a ref or is a commit that we don't have locally.
 
@@ -183,8 +198,9 @@ class Git(VersionControl):
         return True
 
     @classmethod
-    def resolve_revision(cls, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> RevOptions
+    def resolve_revision(
+        cls, dest: str, url: HiddenText, rev_options: RevOptions
+    ) -> RevOptions:
         """
         Resolve a revision to a new RevOptions object with the SHA1 of the
         branch, tag, or ref if found.
@@ -218,18 +234,17 @@ class Git(VersionControl):
 
         # fetch the requested revision
         cls.run_command(
-            make_command('fetch', '-q', url, rev_options.to_args()),
+            make_command("fetch", "-q", url, rev_options.to_args()),
             cwd=dest,
         )
         # Change the revision to the SHA of the ref we fetched
-        sha = cls.get_revision(dest, rev='FETCH_HEAD')
+        sha = cls.get_revision(dest, rev="FETCH_HEAD")
         rev_options = rev_options.make_new(sha)
 
         return rev_options
 
     @classmethod
-    def is_commit_id_equal(cls, dest, name):
-        # type: (str, Optional[str]) -> bool
+    def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool:
         """
         Return whether the current commit hash equals the given name.
 
@@ -243,65 +258,95 @@ class Git(VersionControl):
 
         return cls.get_revision(dest) == name
 
-    def fetch_new(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def fetch_new(
+        self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int
+    ) -> None:
         rev_display = rev_options.to_display()
-        logger.info('Cloning %s%s to %s', url, rev_display, display_path(dest))
-        self.run_command(make_command('clone', '-q', url, dest))
+        logger.info("Cloning %s%s to %s", url, rev_display, display_path(dest))
+        if verbosity <= 0:
+            flags: Tuple[str, ...] = ("--quiet",)
+        elif verbosity == 1:
+            flags = ()
+        else:
+            flags = ("--verbose", "--progress")
+        if self.get_git_version() >= (2, 17):
+            # Git added support for partial clone in 2.17
+            # https://git-scm.com/docs/partial-clone
+            # Speeds up cloning by functioning without a complete copy of repository
+            self.run_command(
+                make_command(
+                    "clone",
+                    "--filter=blob:none",
+                    *flags,
+                    url,
+                    dest,
+                )
+            )
+        else:
+            self.run_command(make_command("clone", *flags, url, dest))
 
         if rev_options.rev:
             # Then a specific revision was requested.
             rev_options = self.resolve_revision(dest, url, rev_options)
-            branch_name = getattr(rev_options, 'branch_name', None)
+            branch_name = getattr(rev_options, "branch_name", None)
+            logger.debug("Rev options %s, branch_name %s", rev_options, branch_name)
             if branch_name is None:
                 # Only do a checkout if the current commit id doesn't match
                 # the requested revision.
                 if not self.is_commit_id_equal(dest, rev_options.rev):
                     cmd_args = make_command(
-                        'checkout', '-q', rev_options.to_args(),
+                        "checkout",
+                        "-q",
+                        rev_options.to_args(),
                     )
                     self.run_command(cmd_args, cwd=dest)
             elif self.get_current_branch(dest) != branch_name:
                 # Then a specific branch was requested, and that branch
                 # is not yet checked out.
-                track_branch = f'origin/{branch_name}'
+                track_branch = f"origin/{branch_name}"
                 cmd_args = [
-                    'checkout', '-b', branch_name, '--track', track_branch,
+                    "checkout",
+                    "-b",
+                    branch_name,
+                    "--track",
+                    track_branch,
                 ]
                 self.run_command(cmd_args, cwd=dest)
+        else:
+            sha = self.get_revision(dest)
+            rev_options = rev_options.make_new(sha)
+
+        logger.info("Resolved %s to commit %s", url, rev_options.rev)
 
         #: repo may contain submodules
         self.update_submodules(dest)
 
-    def switch(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
         self.run_command(
-            make_command('config', 'remote.origin.url', url),
+            make_command("config", "remote.origin.url", url),
             cwd=dest,
         )
-        cmd_args = make_command('checkout', '-q', rev_options.to_args())
+        cmd_args = make_command("checkout", "-q", rev_options.to_args())
         self.run_command(cmd_args, cwd=dest)
 
         self.update_submodules(dest)
 
-    def update(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
         # First fetch changes from the default remote
-        if self.get_git_version() >= parse_version('1.9.0'):
+        if self.get_git_version() >= (1, 9):
             # fetch tags in addition to everything else
-            self.run_command(['fetch', '-q', '--tags'], cwd=dest)
+            self.run_command(["fetch", "-q", "--tags"], cwd=dest)
         else:
-            self.run_command(['fetch', '-q'], cwd=dest)
+            self.run_command(["fetch", "-q"], cwd=dest)
         # Then reset to wanted revision (maybe even origin/master)
         rev_options = self.resolve_revision(dest, url, rev_options)
-        cmd_args = make_command('reset', '--hard', '-q', rev_options.to_args())
+        cmd_args = make_command("reset", "--hard", "-q", rev_options.to_args())
         self.run_command(cmd_args, cwd=dest)
         #: update submodules
         self.update_submodules(dest)
 
     @classmethod
-    def get_remote_url(cls, location):
-        # type: (str) -> str
+    def get_remote_url(cls, location: str) -> str:
         """
         Return URL of the first remote encountered.
 
@@ -311,8 +356,8 @@ class Git(VersionControl):
         # We need to pass 1 for extra_ok_returncodes since the command
         # exits with return code 1 if there are no matching lines.
         stdout = cls.run_command(
-            ['config', '--get-regexp', r'remote\..*\.url'],
-            extra_ok_returncodes=(1, ),
+            ["config", "--get-regexp", r"remote\..*\.url"],
+            extra_ok_returncodes=(1,),
             show_stdout=False,
             stdout_only=True,
             cwd=location,
@@ -324,21 +369,51 @@ class Git(VersionControl):
             raise RemoteNotFoundError
 
         for remote in remotes:
-            if remote.startswith('remote.origin.url '):
+            if remote.startswith("remote.origin.url "):
                 found_remote = remote
                 break
-        url = found_remote.split(' ')[1]
-        return url.strip()
+        url = found_remote.split(" ")[1]
+        return cls._git_remote_to_pip_url(url.strip())
+
+    @staticmethod
+    def _git_remote_to_pip_url(url: str) -> str:
+        """
+        Convert a remote url from what git uses to what pip accepts.
+
+        There are 3 legal forms **url** may take:
+
+            1. A fully qualified url: ssh://git@example.com/foo/bar.git
+            2. A local project.git folder: /path/to/bare/repository.git
+            3. SCP shorthand for form 1: git@example.com:foo/bar.git
+
+        Form 1 is output as-is. Form 2 must be converted to URI and form 3 must
+        be converted to form 1.
+
+        See the corresponding test test_git_remote_url_to_pip() for examples of
+        sample inputs/outputs.
+        """
+        if re.match(r"\w+://", url):
+            # This is already valid. Pass it though as-is.
+            return url
+        if os.path.exists(url):
+            # A local bare remote (git clone --mirror).
+            # Needs a file:// prefix.
+            return pathlib.PurePath(url).as_uri()
+        scp_match = SCP_REGEX.match(url)
+        if scp_match:
+            # Add an ssh:// prefix and replace the ':' with a '/'.
+            return scp_match.expand(r"ssh://\1\2/\3")
+        # Otherwise, bail out.
+        raise RemoteNotValidError(url)
 
     @classmethod
-    def has_commit(cls, location, rev):
-        # type: (str, str) -> bool
+    def has_commit(cls, location: str, rev: str) -> bool:
         """
         Check if rev is a commit that is available in the local repository.
         """
         try:
             cls.run_command(
-                ['rev-parse', '-q', '--verify', "sha^" + rev],
+                ["rev-parse", "-q", "--verify", "sha^" + rev],
                 cwd=location,
                 log_failed_cmd=False,
             )
@@ -348,12 +423,11 @@ class Git(VersionControl):
             return True
 
     @classmethod
-    def get_revision(cls, location, rev=None):
-        # type: (str, Optional[str]) -> str
+    def get_revision(cls, location: str, rev: Optional[str] = None) -> str:
         if rev is None:
-            rev = 'HEAD'
+            rev = "HEAD"
         current_rev = cls.run_command(
-            ['rev-parse', rev],
+            ["rev-parse", rev],
             show_stdout=False,
             stdout_only=True,
             cwd=location,
@@ -361,27 +435,25 @@ class Git(VersionControl):
         return current_rev.strip()
 
     @classmethod
-    def get_subdirectory(cls, location):
-        # type: (str) -> Optional[str]
+    def get_subdirectory(cls, location: str) -> Optional[str]:
         """
-        Return the path to setup.py, relative to the repo root.
-        Return None if setup.py is in the repo root.
+        Return the path to Python project root, relative to the repo root.
+        Return None if the project root is in the repo root.
         """
         # find the repo root
         git_dir = cls.run_command(
-            ['rev-parse', '--git-dir'],
+            ["rev-parse", "--git-dir"],
             show_stdout=False,
             stdout_only=True,
             cwd=location,
         ).strip()
         if not os.path.isabs(git_dir):
             git_dir = os.path.join(location, git_dir)
-        repo_root = os.path.abspath(os.path.join(git_dir, '..'))
-        return find_path_to_setup_from_repo_root(location, repo_root)
+        repo_root = os.path.abspath(os.path.join(git_dir, ".."))
+        return find_path_to_project_root_from_repo_root(location, repo_root)
 
     @classmethod
-    def get_url_rev_and_auth(cls, url):
-        # type: (str) -> Tuple[str, Optional[str], AuthInfo]
+    def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]:
         """
         Prefixes stub URLs like 'user@hostname:user/repo.git' with 'ssh://'.
         That's required because although they use SSH they sometimes don't
@@ -391,60 +463,64 @@ class Git(VersionControl):
         # Works around an apparent Git bug
         # (see https://article.gmane.org/gmane.comp.version-control.git/146500)
         scheme, netloc, path, query, fragment = urlsplit(url)
-        if scheme.endswith('file'):
-            initial_slashes = path[:-len(path.lstrip('/'))]
-            newpath = (
-                initial_slashes +
-                urllib.request.url2pathname(path)
-                .replace('\\', '/').lstrip('/')
-            )
-            after_plus = scheme.find('+') + 1
+        if scheme.endswith("file"):
+            initial_slashes = path[: -len(path.lstrip("/"))]
+            newpath = initial_slashes + urllib.request.url2pathname(path).replace(
+                "\\", "/"
+            ).lstrip("/")
+            after_plus = scheme.find("+") + 1
             url = scheme[:after_plus] + urlunsplit(
                 (scheme[after_plus:], netloc, newpath, query, fragment),
             )
 
-        if '://' not in url:
-            assert 'file:' not in url
-            url = url.replace('git+', 'git+ssh://')
+        if "://" not in url:
+            assert "file:" not in url
+            url = url.replace("git+", "git+ssh://")
             url, rev, user_pass = super().get_url_rev_and_auth(url)
-            url = url.replace('ssh://', '')
+            url = url.replace("ssh://", "")
         else:
             url, rev, user_pass = super().get_url_rev_and_auth(url)
 
         return url, rev, user_pass
 
     @classmethod
-    def update_submodules(cls, location):
-        # type: (str) -> None
-        if not os.path.exists(os.path.join(location, '.gitmodules')):
+    def update_submodules(cls, location: str) -> None:
+        if not os.path.exists(os.path.join(location, ".gitmodules")):
             return
         cls.run_command(
-            ['submodule', 'update', '--init', '--recursive', '-q'],
+            ["submodule", "update", "--init", "--recursive", "-q"],
             cwd=location,
         )
 
     @classmethod
-    def get_repository_root(cls, location):
-        # type: (str) -> Optional[str]
+    def get_repository_root(cls, location: str) -> Optional[str]:
         loc = super().get_repository_root(location)
         if loc:
             return loc
         try:
             r = cls.run_command(
-                ['rev-parse', '--show-toplevel'],
+                ["rev-parse", "--show-toplevel"],
                 cwd=location,
                 show_stdout=False,
                 stdout_only=True,
-                on_returncode='raise',
+                on_returncode="raise",
                 log_failed_cmd=False,
             )
         except BadCommand:
-            logger.debug("could not determine if %s is under git control "
-                         "because git is not available", location)
+            logger.debug(
+                "could not determine if %s is under git control "
+                "because git is not available",
+                location,
+            )
             return None
         except InstallationError:
             return None
-        return os.path.normpath(r.rstrip('\r\n'))
+        return os.path.normpath(r.rstrip("\r\n"))
+
+    @staticmethod
+    def should_add_vcs_url_prefix(repo_url: str) -> bool:
+        """In either https or ssh form, requirements must be prefixed with git+."""
+        return True
 
 
 vcs.register(Git)
diff --git a/env/Lib/site-packages/pip/_internal/vcs/mercurial.py b/env/Lib/site-packages/pip/_internal/vcs/mercurial.py
index b4f887d3..4595960b 100644
--- a/env/Lib/site-packages/pip/_internal/vcs/mercurial.py
+++ b/env/Lib/site-packages/pip/_internal/vcs/mercurial.py
@@ -1,7 +1,7 @@
 import configparser
 import logging
 import os
-from typing import List, Optional
+from typing import List, Optional, Tuple
 
 from pip._internal.exceptions import BadCommand, InstallationError
 from pip._internal.utils.misc import HiddenText, display_path
@@ -10,7 +10,7 @@ from pip._internal.utils.urls import path_to_url
 from pip._internal.vcs.versioncontrol import (
     RevOptions,
     VersionControl,
-    find_path_to_setup_from_repo_root,
+    find_path_to_project_root_from_repo_root,
     vcs,
 )
 
@@ -18,61 +18,68 @@ logger = logging.getLogger(__name__)
 
 
 class Mercurial(VersionControl):
-    name = 'hg'
-    dirname = '.hg'
-    repo_name = 'clone'
+    name = "hg"
+    dirname = ".hg"
+    repo_name = "clone"
     schemes = (
-        'hg+file', 'hg+http', 'hg+https', 'hg+ssh', 'hg+static-http',
+        "hg+file",
+        "hg+http",
+        "hg+https",
+        "hg+ssh",
+        "hg+static-http",
     )
 
     @staticmethod
-    def get_base_rev_args(rev):
-        # type: (str) -> List[str]
-        return [rev]
+    def get_base_rev_args(rev: str) -> List[str]:
+        return ["-r", rev]
 
-    def fetch_new(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def fetch_new(
+        self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int
+    ) -> None:
         rev_display = rev_options.to_display()
         logger.info(
-            'Cloning hg %s%s to %s',
+            "Cloning hg %s%s to %s",
             url,
             rev_display,
             display_path(dest),
         )
-        self.run_command(make_command('clone', '--noupdate', '-q', url, dest))
+        if verbosity <= 0:
+            flags: Tuple[str, ...] = ("--quiet",)
+        elif verbosity == 1:
+            flags = ()
+        elif verbosity == 2:
+            flags = ("--verbose",)
+        else:
+            flags = ("--verbose", "--debug")
+        self.run_command(make_command("clone", "--noupdate", *flags, url, dest))
         self.run_command(
-            make_command('update', '-q', rev_options.to_args()),
+            make_command("update", *flags, rev_options.to_args()),
             cwd=dest,
         )
 
-    def switch(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
-        repo_config = os.path.join(dest, self.dirname, 'hgrc')
+    def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
+        repo_config = os.path.join(dest, self.dirname, "hgrc")
         config = configparser.RawConfigParser()
         try:
             config.read(repo_config)
-            config.set('paths', 'default', url.secret)
-            with open(repo_config, 'w') as config_file:
+            config.set("paths", "default", url.secret)
+            with open(repo_config, "w") as config_file:
                 config.write(config_file)
         except (OSError, configparser.NoSectionError) as exc:
-            logger.warning(
-                'Could not switch Mercurial repository to %s: %s', url, exc,
-            )
+            logger.warning("Could not switch Mercurial repository to %s: %s", url, exc)
         else:
-            cmd_args = make_command('update', '-q', rev_options.to_args())
+            cmd_args = make_command("update", "-q", rev_options.to_args())
             self.run_command(cmd_args, cwd=dest)
 
-    def update(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
-        self.run_command(['pull', '-q'], cwd=dest)
-        cmd_args = make_command('update', '-q', rev_options.to_args())
+    def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
+        self.run_command(["pull", "-q"], cwd=dest)
+        cmd_args = make_command("update", "-q", rev_options.to_args())
         self.run_command(cmd_args, cwd=dest)
 
     @classmethod
-    def get_remote_url(cls, location):
-        # type: (str) -> str
+    def get_remote_url(cls, location: str) -> str:
         url = cls.run_command(
-            ['showconfig', 'paths.default'],
+            ["showconfig", "paths.default"],
             show_stdout=False,
             stdout_only=True,
             cwd=location,
@@ -82,13 +89,12 @@ class Mercurial(VersionControl):
         return url.strip()
 
     @classmethod
-    def get_revision(cls, location):
-        # type: (str) -> str
+    def get_revision(cls, location: str) -> str:
         """
         Return the repository-local changeset revision number, as an integer.
         """
         current_revision = cls.run_command(
-            ['parents', '--template={rev}'],
+            ["parents", "--template={rev}"],
             show_stdout=False,
             stdout_only=True,
             cwd=location,
@@ -96,14 +102,13 @@ class Mercurial(VersionControl):
         return current_revision
 
     @classmethod
-    def get_requirement_revision(cls, location):
-        # type: (str) -> str
+    def get_requirement_revision(cls, location: str) -> str:
         """
         Return the changeset identification hash, as a 40-character
         hexadecimal string
         """
         current_rev_hash = cls.run_command(
-            ['parents', '--template={node}'],
+            ["parents", "--template={node}"],
             show_stdout=False,
             stdout_only=True,
             cwd=location,
@@ -111,48 +116,48 @@ class Mercurial(VersionControl):
         return current_rev_hash
 
     @classmethod
-    def is_commit_id_equal(cls, dest, name):
-        # type: (str, Optional[str]) -> bool
+    def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool:
         """Always assume the versions don't match"""
         return False
 
     @classmethod
-    def get_subdirectory(cls, location):
-        # type: (str) -> Optional[str]
+    def get_subdirectory(cls, location: str) -> Optional[str]:
         """
-        Return the path to setup.py, relative to the repo root.
-        Return None if setup.py is in the repo root.
+        Return the path to Python project root, relative to the repo root.
+        Return None if the project root is in the repo root.
         """
         # find the repo root
         repo_root = cls.run_command(
-            ['root'], show_stdout=False, stdout_only=True, cwd=location
+            ["root"], show_stdout=False, stdout_only=True, cwd=location
         ).strip()
         if not os.path.isabs(repo_root):
             repo_root = os.path.abspath(os.path.join(location, repo_root))
-        return find_path_to_setup_from_repo_root(location, repo_root)
+        return find_path_to_project_root_from_repo_root(location, repo_root)
 
     @classmethod
-    def get_repository_root(cls, location):
-        # type: (str) -> Optional[str]
+    def get_repository_root(cls, location: str) -> Optional[str]:
         loc = super().get_repository_root(location)
         if loc:
             return loc
         try:
             r = cls.run_command(
-                ['root'],
+                ["root"],
                 cwd=location,
                 show_stdout=False,
                 stdout_only=True,
-                on_returncode='raise',
+                on_returncode="raise",
                 log_failed_cmd=False,
             )
         except BadCommand:
-            logger.debug("could not determine if %s is under hg control "
-                         "because hg is not available", location)
+            logger.debug(
+                "could not determine if %s is under hg control "
+                "because hg is not available",
+                location,
+            )
             return None
         except InstallationError:
             return None
-        return os.path.normpath(r.rstrip('\r\n'))
+        return os.path.normpath(r.rstrip("\r\n"))
 
 
 vcs.register(Mercurial)
diff --git a/env/Lib/site-packages/pip/_internal/vcs/subversion.py b/env/Lib/site-packages/pip/_internal/vcs/subversion.py
index 4d1237ca..16d93a67 100644
--- a/env/Lib/site-packages/pip/_internal/vcs/subversion.py
+++ b/env/Lib/site-packages/pip/_internal/vcs/subversion.py
@@ -7,6 +7,7 @@ from pip._internal.utils.misc import (
     HiddenText,
     display_path,
     is_console_interactive,
+    is_installable_dir,
     split_auth_from_netloc,
 )
 from pip._internal.utils.subprocess import CommandArgs, make_command
@@ -23,30 +24,25 @@ logger = logging.getLogger(__name__)
 _svn_xml_url_re = re.compile('url="([^"]+)"')
 _svn_rev_re = re.compile(r'committed-rev="(\d+)"')
 _svn_info_xml_rev_re = re.compile(r'\s*revision="(\d+)"')
-_svn_info_xml_url_re = re.compile(r'<url>(.*)</url>')
+_svn_info_xml_url_re = re.compile(r"<url>(.*)</url>")
 
 
 class Subversion(VersionControl):
-    name = 'svn'
-    dirname = '.svn'
-    repo_name = 'checkout'
-    schemes = (
-        'svn+ssh', 'svn+http', 'svn+https', 'svn+svn', 'svn+file'
-    )
+    name = "svn"
+    dirname = ".svn"
+    repo_name = "checkout"
+    schemes = ("svn+ssh", "svn+http", "svn+https", "svn+svn", "svn+file")
 
     @classmethod
-    def should_add_vcs_url_prefix(cls, remote_url):
-        # type: (str) -> bool
+    def should_add_vcs_url_prefix(cls, remote_url: str) -> bool:
         return True
 
     @staticmethod
-    def get_base_rev_args(rev):
-        # type: (str) -> List[str]
-        return ['-r', rev]
+    def get_base_rev_args(rev: str) -> List[str]:
+        return ["-r", rev]
 
     @classmethod
-    def get_revision(cls, location):
-        # type: (str) -> str
+    def get_revision(cls, location: str) -> str:
         """
         Return the maximum revision for all files under a given location
         """
@@ -56,9 +52,9 @@ class Subversion(VersionControl):
         for base, dirs, _ in os.walk(location):
             if cls.dirname not in dirs:
                 dirs[:] = []
-                continue    # no sense walking uncontrolled subdirs
+                continue  # no sense walking uncontrolled subdirs
             dirs.remove(cls.dirname)
-            entries_fn = os.path.join(base, cls.dirname, 'entries')
+            entries_fn = os.path.join(base, cls.dirname, "entries")
             if not os.path.exists(entries_fn):
                 # FIXME: should we warn?
                 continue
@@ -67,21 +63,22 @@ class Subversion(VersionControl):
 
             if base == location:
                 assert dirurl is not None
-                base = dirurl + '/'   # save the root url
+                base = dirurl + "/"  # save the root url
             elif not dirurl or not dirurl.startswith(base):
                 dirs[:] = []
-                continue    # not part of the same svn tree, skip it
+                continue  # not part of the same svn tree, skip it
             revision = max(revision, localrev)
         return str(revision)
 
     @classmethod
-    def get_netloc_and_auth(cls, netloc, scheme):
-        # type: (str, str) -> Tuple[str, Tuple[Optional[str], Optional[str]]]
+    def get_netloc_and_auth(
+        cls, netloc: str, scheme: str
+    ) -> Tuple[str, Tuple[Optional[str], Optional[str]]]:
         """
         This override allows the auth information to be passed to svn via the
         --username and --password options instead of via the URL.
         """
-        if scheme == 'ssh':
+        if scheme == "ssh":
             # The --username and --password options can't be used for
             # svn+ssh URLs, so keep the auth information in the URL.
             return super().get_netloc_and_auth(netloc, scheme)
@@ -89,40 +86,38 @@ class Subversion(VersionControl):
         return split_auth_from_netloc(netloc)
 
     @classmethod
-    def get_url_rev_and_auth(cls, url):
-        # type: (str) -> Tuple[str, Optional[str], AuthInfo]
-        # hotfix the URL scheme after removing svn+ from svn+ssh:// readd it
+    def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]:
+        # hotfix the URL scheme after removing svn+ from svn+ssh:// re-add it
         url, rev, user_pass = super().get_url_rev_and_auth(url)
-        if url.startswith('ssh://'):
-            url = 'svn+' + url
+        if url.startswith("ssh://"):
+            url = "svn+" + url
         return url, rev, user_pass
 
     @staticmethod
-    def make_rev_args(username, password):
-        # type: (Optional[str], Optional[HiddenText]) -> CommandArgs
-        extra_args = []  # type: CommandArgs
+    def make_rev_args(
+        username: Optional[str], password: Optional[HiddenText]
+    ) -> CommandArgs:
+        extra_args: CommandArgs = []
         if username:
-            extra_args += ['--username', username]
+            extra_args += ["--username", username]
         if password:
-            extra_args += ['--password', password]
+            extra_args += ["--password", password]
 
         return extra_args
 
     @classmethod
-    def get_remote_url(cls, location):
-        # type: (str) -> str
-        # In cases where the source is in a subdirectory, not alongside
-        # setup.py we have to look up in the location until we find a real
-        # setup.py
+    def get_remote_url(cls, location: str) -> str:
+        # In cases where the source is in a subdirectory, we have to look up in
+        # the location until we find a valid project root.
         orig_location = location
-        while not os.path.exists(os.path.join(location, 'setup.py')):
+        while not is_installable_dir(location):
             last_location = location
             location = os.path.dirname(location)
             if location == last_location:
                 # We've traversed up to the root of the filesystem without
-                # finding setup.py
+                # finding a Python project.
                 logger.warning(
-                    "Could not find setup.py for directory %s (tried all "
+                    "Could not find Python project for directory %s (tried all "
                     "parent directories)",
                     orig_location,
                 )
@@ -135,30 +130,27 @@ class Subversion(VersionControl):
         return url
 
     @classmethod
-    def _get_svn_url_rev(cls, location):
-        # type: (str) -> Tuple[Optional[str], int]
+    def _get_svn_url_rev(cls, location: str) -> Tuple[Optional[str], int]:
         from pip._internal.exceptions import InstallationError
 
-        entries_path = os.path.join(location, cls.dirname, 'entries')
+        entries_path = os.path.join(location, cls.dirname, "entries")
         if os.path.exists(entries_path):
             with open(entries_path) as f:
                 data = f.read()
         else:  # subversion >= 1.7 does not have the 'entries' file
-            data = ''
+            data = ""
 
         url = None
-        if (data.startswith('8') or
-                data.startswith('9') or
-                data.startswith('10')):
-            entries = list(map(str.splitlines, data.split('\n\x0c\n')))
+        if data.startswith("8") or data.startswith("9") or data.startswith("10"):
+            entries = list(map(str.splitlines, data.split("\n\x0c\n")))
             del entries[0][0]  # get rid of the '8'
             url = entries[0][3]
             revs = [int(d[9]) for d in entries if len(d) > 9 and d[9]] + [0]
-        elif data.startswith('<?xml'):
+        elif data.startswith("<?xml"):
             match = _svn_xml_url_re.search(data)
             if not match:
-                raise ValueError(f'Badly formatted data: {data!r}')
-            url = match.group(1)    # get repository URL
+                raise ValueError(f"Badly formatted data: {data!r}")
+            url = match.group(1)  # get repository URL
             revs = [int(m.group(1)) for m in _svn_rev_re.finditer(data)] + [0]
         else:
             try:
@@ -169,16 +161,14 @@ class Subversion(VersionControl):
                 # is being used to prompt for passwords, because passwords
                 # are only potentially needed for remote server requests.
                 xml = cls.run_command(
-                    ['info', '--xml', location],
+                    ["info", "--xml", location],
                     show_stdout=False,
                     stdout_only=True,
                 )
                 match = _svn_info_xml_url_re.search(xml)
                 assert match is not None
                 url = match.group(1)
-                revs = [
-                    int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml)
-                ]
+                revs = [int(m.group(1)) for m in _svn_info_xml_rev_re.finditer(xml)]
             except InstallationError:
                 url, revs = None, []
 
@@ -190,13 +180,11 @@ class Subversion(VersionControl):
         return url, rev
 
     @classmethod
-    def is_commit_id_equal(cls, dest, name):
-        # type: (str, Optional[str]) -> bool
+    def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool:
         """Always assume the versions don't match"""
         return False
 
-    def __init__(self, use_interactive=None):
-        # type: (bool) -> None
+    def __init__(self, use_interactive: Optional[bool] = None) -> None:
         if use_interactive is None:
             use_interactive = is_console_interactive()
         self.use_interactive = use_interactive
@@ -206,12 +194,11 @@ class Subversion(VersionControl):
         # Special value definitions:
         #   None: Not evaluated yet.
         #   Empty tuple: Could not parse version.
-        self._vcs_version = None  # type: Optional[Tuple[int, ...]]
+        self._vcs_version: Optional[Tuple[int, ...]] = None
 
         super().__init__()
 
-    def call_vcs_version(self):
-        # type: () -> Tuple[int, ...]
+    def call_vcs_version(self) -> Tuple[int, ...]:
         """Query the version of the currently installed Subversion client.
 
         :return: A tuple containing the parts of the version information or
@@ -225,15 +212,13 @@ class Subversion(VersionControl):
         #      compiled Mar 28 2018, 08:49:13 on x86_64-pc-linux-gnu
         #   svn, version 1.12.0-SlikSvn (SlikSvn/1.12.0)
         #      compiled May 28 2019, 13:44:56 on x86_64-microsoft-windows6.2
-        version_prefix = 'svn, version '
-        version = self.run_command(
-            ['--version'], show_stdout=False, stdout_only=True
-        )
+        version_prefix = "svn, version "
+        version = self.run_command(["--version"], show_stdout=False, stdout_only=True)
         if not version.startswith(version_prefix):
             return ()
 
-        version = version[len(version_prefix):].split()[0]
-        version_list = version.partition('-')[0].split('.')
+        version = version[len(version_prefix) :].split()[0]
+        version_list = version.partition("-")[0].split(".")
         try:
             parsed_version = tuple(map(int, version_list))
         except ValueError:
@@ -241,8 +226,7 @@ class Subversion(VersionControl):
 
         return parsed_version
 
-    def get_vcs_version(self):
-        # type: () -> Tuple[int, ...]
+    def get_vcs_version(self) -> Tuple[int, ...]:
         """Return the version of the currently installed Subversion client.
 
         If the version of the Subversion client has already been queried,
@@ -262,8 +246,7 @@ class Subversion(VersionControl):
         self._vcs_version = vcs_version
         return vcs_version
 
-    def get_remote_call_options(self):
-        # type: () -> CommandArgs
+    def get_remote_call_options(self) -> CommandArgs:
         """Return options to be used on calls to Subversion that contact the server.
 
         These options are applicable for the following ``svn`` subcommands used
@@ -278,7 +261,7 @@ class Subversion(VersionControl):
         if not self.use_interactive:
             # --non-interactive switch is available since Subversion 0.14.4.
             # Subversion < 1.8 runs in interactive mode by default.
-            return ['--non-interactive']
+            return ["--non-interactive"]
 
         svn_version = self.get_vcs_version()
         # By default, Subversion >= 1.8 runs in non-interactive mode if
@@ -290,37 +273,49 @@ class Subversion(VersionControl):
         # SVN 1.7, pip should continue to support SVN 1.7. Therefore, pip
         # can't safely add the option if the SVN version is < 1.8 (or unknown).
         if svn_version >= (1, 8):
-            return ['--force-interactive']
+            return ["--force-interactive"]
 
         return []
 
-    def fetch_new(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def fetch_new(
+        self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int
+    ) -> None:
         rev_display = rev_options.to_display()
         logger.info(
-            'Checking out %s%s to %s',
+            "Checking out %s%s to %s",
             url,
             rev_display,
             display_path(dest),
         )
+        if verbosity <= 0:
+            flag = "--quiet"
+        else:
+            flag = ""
         cmd_args = make_command(
-            'checkout', '-q', self.get_remote_call_options(),
-            rev_options.to_args(), url, dest,
+            "checkout",
+            flag,
+            self.get_remote_call_options(),
+            rev_options.to_args(),
+            url,
+            dest,
         )
         self.run_command(cmd_args)
 
-    def switch(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
         cmd_args = make_command(
-            'switch', self.get_remote_call_options(), rev_options.to_args(),
-            url, dest,
+            "switch",
+            self.get_remote_call_options(),
+            rev_options.to_args(),
+            url,
+            dest,
         )
         self.run_command(cmd_args)
 
-    def update(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
         cmd_args = make_command(
-            'update', self.get_remote_call_options(), rev_options.to_args(),
+            "update",
+            self.get_remote_call_options(),
+            rev_options.to_args(),
             dest,
         )
         self.run_command(cmd_args)
diff --git a/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py b/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py
index 97977b57..02bbf68e 100644
--- a/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py
+++ b/env/Lib/site-packages/pip/_internal/vcs/versioncontrol.py
@@ -6,6 +6,7 @@ import shutil
 import sys
 import urllib.parse
 from typing import (
+    TYPE_CHECKING,
     Any,
     Dict,
     Iterable,
@@ -27,12 +28,25 @@ from pip._internal.utils.misc import (
     display_path,
     hide_url,
     hide_value,
+    is_installable_dir,
     rmtree,
 )
-from pip._internal.utils.subprocess import CommandArgs, call_subprocess, make_command
+from pip._internal.utils.subprocess import (
+    CommandArgs,
+    call_subprocess,
+    format_command_args,
+    make_command,
+)
 from pip._internal.utils.urls import get_url_scheme
 
-__all__ = ['vcs']
+if TYPE_CHECKING:
+    # Literal was introduced in Python 3.8.
+    #
+    # TODO: Remove `if TYPE_CHECKING` when dropping support for Python 3.7.
+    from typing import Literal
+
+
+__all__ = ["vcs"]
 
 
 logger = logging.getLogger(__name__)
@@ -40,19 +54,19 @@ logger = logging.getLogger(__name__)
 AuthInfo = Tuple[Optional[str], Optional[str]]
 
 
-def is_url(name):
-    # type: (str) -> bool
+def is_url(name: str) -> bool:
     """
     Return true if the name looks like a URL.
     """
     scheme = get_url_scheme(name)
     if scheme is None:
         return False
-    return scheme in ['http', 'https', 'file', 'ftp'] + vcs.all_schemes
+    return scheme in ["http", "https", "file", "ftp"] + vcs.all_schemes
 
 
-def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None):
-    # type: (str, str, str, Optional[str]) -> str
+def make_vcs_requirement_url(
+    repo_url: str, rev: str, project_name: str, subdir: Optional[str] = None
+) -> str:
     """
     Return the URL for a VCS requirement.
 
@@ -61,30 +75,31 @@ def make_vcs_requirement_url(repo_url, rev, project_name, subdir=None):
       project_name: the (unescaped) project name.
     """
     egg_project_name = project_name.replace("-", "_")
-    req = f'{repo_url}@{rev}#egg={egg_project_name}'
+    req = f"{repo_url}@{rev}#egg={egg_project_name}"
     if subdir:
-        req += f'&subdirectory={subdir}'
+        req += f"&subdirectory={subdir}"
 
     return req
 
 
-def find_path_to_setup_from_repo_root(location, repo_root):
-    # type: (str, str) -> Optional[str]
+def find_path_to_project_root_from_repo_root(
+    location: str, repo_root: str
+) -> Optional[str]:
     """
-    Find the path to `setup.py` by searching up the filesystem from `location`.
-    Return the path to `setup.py` relative to `repo_root`.
-    Return None if `setup.py` is in `repo_root` or cannot be found.
+    Find the the Python project's root by searching up the filesystem from
+    `location`. Return the path to project root relative to `repo_root`.
+    Return None if the project root is `repo_root`, or cannot be found.
     """
-    # find setup.py
+    # find project root.
     orig_location = location
-    while not os.path.exists(os.path.join(location, 'setup.py')):
+    while not is_installable_dir(location):
         last_location = location
         location = os.path.dirname(location)
         if location == last_location:
             # We've traversed up to the root of the filesystem without
-            # finding setup.py
+            # finding a Python project.
             logger.warning(
-                "Could not find setup.py for directory %s (tried all "
+                "Could not find a Python project for directory %s (tried all "
                 "parent directories)",
                 orig_location,
             )
@@ -100,6 +115,12 @@ class RemoteNotFoundError(Exception):
     pass
 
 
+class RemoteNotValidError(Exception):
+    def __init__(self, url: str):
+        super().__init__(url)
+        self.url = url
+
+
 class RevOptions:
 
     """
@@ -111,11 +132,10 @@ class RevOptions:
 
     def __init__(
         self,
-        vc_class,  # type: Type[VersionControl]
-        rev=None,  # type: Optional[str]
-        extra_args=None,  # type: Optional[CommandArgs]
-    ):
-        # type: (...) -> None
+        vc_class: Type["VersionControl"],
+        rev: Optional[str] = None,
+        extra_args: Optional[CommandArgs] = None,
+    ) -> None:
         """
         Args:
           vc_class: a VersionControl subclass.
@@ -128,26 +148,23 @@ class RevOptions:
         self.extra_args = extra_args
         self.rev = rev
         self.vc_class = vc_class
-        self.branch_name = None  # type: Optional[str]
+        self.branch_name: Optional[str] = None
 
-    def __repr__(self):
-        # type: () -> str
-        return f'<RevOptions {self.vc_class.name}: rev={self.rev!r}>'
+    def __repr__(self) -> str:
+        return f"<RevOptions {self.vc_class.name}: rev={self.rev!r}>"
 
     @property
-    def arg_rev(self):
-        # type: () -> Optional[str]
+    def arg_rev(self) -> Optional[str]:
         if self.rev is None:
             return self.vc_class.default_arg_rev
 
         return self.rev
 
-    def to_args(self):
-        # type: () -> CommandArgs
+    def to_args(self) -> CommandArgs:
         """
         Return the VCS-specific command arguments.
         """
-        args = []  # type: CommandArgs
+        args: CommandArgs = []
         rev = self.arg_rev
         if rev is not None:
             args += self.vc_class.get_base_rev_args(rev)
@@ -155,15 +172,13 @@ class RevOptions:
 
         return args
 
-    def to_display(self):
-        # type: () -> str
+    def to_display(self) -> str:
         if not self.rev:
-            return ''
+            return ""
 
-        return f' (to revision {self.rev})'
+        return f" (to revision {self.rev})"
 
-    def make_new(self, rev):
-        # type: (str) -> RevOptions
+    def make_new(self, rev: str) -> "RevOptions":
         """
         Make a copy of the current instance, but with a new rev.
 
@@ -174,54 +189,46 @@ class RevOptions:
 
 
 class VcsSupport:
-    _registry = {}  # type: Dict[str, VersionControl]
-    schemes = ['ssh', 'git', 'hg', 'bzr', 'sftp', 'svn']
+    _registry: Dict[str, "VersionControl"] = {}
+    schemes = ["ssh", "git", "hg", "bzr", "sftp", "svn"]
 
-    def __init__(self):
-        # type: () -> None
+    def __init__(self) -> None:
         # Register more schemes with urlparse for various version control
         # systems
         urllib.parse.uses_netloc.extend(self.schemes)
         super().__init__()
 
-    def __iter__(self):
-        # type: () -> Iterator[str]
+    def __iter__(self) -> Iterator[str]:
         return self._registry.__iter__()
 
     @property
-    def backends(self):
-        # type: () -> List[VersionControl]
+    def backends(self) -> List["VersionControl"]:
         return list(self._registry.values())
 
     @property
-    def dirnames(self):
-        # type: () -> List[str]
+    def dirnames(self) -> List[str]:
         return [backend.dirname for backend in self.backends]
 
     @property
-    def all_schemes(self):
-        # type: () -> List[str]
-        schemes = []  # type: List[str]
+    def all_schemes(self) -> List[str]:
+        schemes: List[str] = []
         for backend in self.backends:
             schemes.extend(backend.schemes)
         return schemes
 
-    def register(self, cls):
-        # type: (Type[VersionControl]) -> None
-        if not hasattr(cls, 'name'):
-            logger.warning('Cannot register VCS %s', cls.__name__)
+    def register(self, cls: Type["VersionControl"]) -> None:
+        if not hasattr(cls, "name"):
+            logger.warning("Cannot register VCS %s", cls.__name__)
             return
         if cls.name not in self._registry:
             self._registry[cls.name] = cls()
-            logger.debug('Registered VCS backend: %s', cls.name)
+            logger.debug("Registered VCS backend: %s", cls.name)
 
-    def unregister(self, name):
-        # type: (str) -> None
+    def unregister(self, name: str) -> None:
         if name in self._registry:
             del self._registry[name]
 
-    def get_backend_for_dir(self, location):
-        # type: (str) -> Optional[VersionControl]
+    def get_backend_for_dir(self, location: str) -> Optional["VersionControl"]:
         """
         Return a VersionControl object if a repository of that type is found
         at the given directory.
@@ -231,8 +238,7 @@ class VcsSupport:
             repo_path = vcs_backend.get_repository_root(location)
             if not repo_path:
                 continue
-            logger.debug('Determine that %s uses VCS: %s',
-                         location, vcs_backend.name)
+            logger.debug("Determine that %s uses VCS: %s", location, vcs_backend.name)
             vcs_backends[repo_path] = vcs_backend
 
         if not vcs_backends:
@@ -245,8 +251,7 @@ class VcsSupport:
         inner_most_repo_path = max(vcs_backends, key=len)
         return vcs_backends[inner_most_repo_path]
 
-    def get_backend_for_scheme(self, scheme):
-        # type: (str) -> Optional[VersionControl]
+    def get_backend_for_scheme(self, scheme: str) -> Optional["VersionControl"]:
         """
         Return a VersionControl object or None.
         """
@@ -255,8 +260,7 @@ class VcsSupport:
                 return vcs_backend
         return None
 
-    def get_backend(self, name):
-        # type: (str) -> Optional[VersionControl]
+    def get_backend(self, name: str) -> Optional["VersionControl"]:
         """
         Return a VersionControl object or None.
         """
@@ -268,44 +272,40 @@ vcs = VcsSupport()
 
 
 class VersionControl:
-    name = ''
-    dirname = ''
-    repo_name = ''
+    name = ""
+    dirname = ""
+    repo_name = ""
     # List of supported schemes for this Version Control
-    schemes = ()  # type: Tuple[str, ...]
+    schemes: Tuple[str, ...] = ()
     # Iterable of environment variable names to pass to call_subprocess().
-    unset_environ = ()  # type: Tuple[str, ...]
-    default_arg_rev = None  # type: Optional[str]
+    unset_environ: Tuple[str, ...] = ()
+    default_arg_rev: Optional[str] = None
 
     @classmethod
-    def should_add_vcs_url_prefix(cls, remote_url):
-        # type: (str) -> bool
+    def should_add_vcs_url_prefix(cls, remote_url: str) -> bool:
         """
         Return whether the vcs prefix (e.g. "git+") should be added to a
         repository's remote url when used in a requirement.
         """
-        return not remote_url.lower().startswith(f'{cls.name}:')
+        return not remote_url.lower().startswith(f"{cls.name}:")
 
     @classmethod
-    def get_subdirectory(cls, location):
-        # type: (str) -> Optional[str]
+    def get_subdirectory(cls, location: str) -> Optional[str]:
         """
-        Return the path to setup.py, relative to the repo root.
-        Return None if setup.py is in the repo root.
+        Return the path to Python project root, relative to the repo root.
+        Return None if the project root is in the repo root.
         """
         return None
 
     @classmethod
-    def get_requirement_revision(cls, repo_dir):
-        # type: (str) -> str
+    def get_requirement_revision(cls, repo_dir: str) -> str:
         """
         Return the revision string that should be used in a requirement.
         """
         return cls.get_revision(repo_dir)
 
     @classmethod
-    def get_src_requirement(cls, repo_dir, project_name):
-        # type: (str, str) -> str
+    def get_src_requirement(cls, repo_dir: str, project_name: str) -> str:
         """
         Return the requirement string to use to redownload the files
         currently at the given repository directory.
@@ -320,18 +320,16 @@ class VersionControl:
         repo_url = cls.get_remote_url(repo_dir)
 
         if cls.should_add_vcs_url_prefix(repo_url):
-            repo_url = f'{cls.name}+{repo_url}'
+            repo_url = f"{cls.name}+{repo_url}"
 
         revision = cls.get_requirement_revision(repo_dir)
         subdir = cls.get_subdirectory(repo_dir)
-        req = make_vcs_requirement_url(repo_url, revision, project_name,
-                                       subdir=subdir)
+        req = make_vcs_requirement_url(repo_url, revision, project_name, subdir=subdir)
 
         return req
 
     @staticmethod
-    def get_base_rev_args(rev):
-        # type: (str) -> List[str]
+    def get_base_rev_args(rev: str) -> List[str]:
         """
         Return the base revision arguments for a vcs command.
 
@@ -340,8 +338,7 @@ class VersionControl:
         """
         raise NotImplementedError
 
-    def is_immutable_rev_checkout(self, url, dest):
-        # type: (str, str) -> bool
+    def is_immutable_rev_checkout(self, url: str, dest: str) -> bool:
         """
         Return true if the commit hash checked out at dest matches
         the revision in url.
@@ -355,8 +352,9 @@ class VersionControl:
         return False
 
     @classmethod
-    def make_rev_options(cls, rev=None, extra_args=None):
-        # type: (Optional[str], Optional[CommandArgs]) -> RevOptions
+    def make_rev_options(
+        cls, rev: Optional[str] = None, extra_args: Optional[CommandArgs] = None
+    ) -> RevOptions:
         """
         Return a RevOptions object.
 
@@ -367,18 +365,18 @@ class VersionControl:
         return RevOptions(cls, rev, extra_args=extra_args)
 
     @classmethod
-    def _is_local_repository(cls, repo):
-        # type: (str) -> bool
+    def _is_local_repository(cls, repo: str) -> bool:
         """
-           posix absolute paths start with os.path.sep,
-           win32 ones start with drive (like c:\\folder)
+        posix absolute paths start with os.path.sep,
+        win32 ones start with drive (like c:\\folder)
         """
         drive, tail = os.path.splitdrive(repo)
         return repo.startswith(os.path.sep) or bool(drive)
 
     @classmethod
-    def get_netloc_and_auth(cls, netloc, scheme):
-        # type: (str, str) -> Tuple[str, Tuple[Optional[str], Optional[str]]]
+    def get_netloc_and_auth(
+        cls, netloc: str, scheme: str
+    ) -> Tuple[str, Tuple[Optional[str], Optional[str]]]:
         """
         Parse the repository URL's netloc, and return the new netloc to use
         along with auth information.
@@ -397,8 +395,7 @@ class VersionControl:
         return netloc, (None, None)
 
     @classmethod
-    def get_url_rev_and_auth(cls, url):
-        # type: (str) -> Tuple[str, Optional[str], AuthInfo]
+    def get_url_rev_and_auth(cls, url: str) -> Tuple[str, Optional[str], AuthInfo]:
         """
         Parse the repository URL to use, and return the URL, revision,
         and auth info to use.
@@ -406,44 +403,44 @@ class VersionControl:
         Returns: (url, rev, (username, password)).
         """
         scheme, netloc, path, query, frag = urllib.parse.urlsplit(url)
-        if '+' not in scheme:
+        if "+" not in scheme:
             raise ValueError(
                 "Sorry, {!r} is a malformed VCS url. "
                 "The format is <vcs>+<protocol>://<url>, "
                 "e.g. svn+http://myrepo/svn/MyApp#egg=MyApp".format(url)
             )
         # Remove the vcs prefix.
-        scheme = scheme.split('+', 1)[1]
+        scheme = scheme.split("+", 1)[1]
         netloc, user_pass = cls.get_netloc_and_auth(netloc, scheme)
         rev = None
-        if '@' in path:
-            path, rev = path.rsplit('@', 1)
+        if "@" in path:
+            path, rev = path.rsplit("@", 1)
             if not rev:
                 raise InstallationError(
                     "The URL {!r} has an empty revision (after @) "
                     "which is not supported. Include a revision after @ "
                     "or remove @ from the URL.".format(url)
                 )
-        url = urllib.parse.urlunsplit((scheme, netloc, path, query, ''))
+        url = urllib.parse.urlunsplit((scheme, netloc, path, query, ""))
         return url, rev, user_pass
 
     @staticmethod
-    def make_rev_args(username, password):
-        # type: (Optional[str], Optional[HiddenText]) -> CommandArgs
+    def make_rev_args(
+        username: Optional[str], password: Optional[HiddenText]
+    ) -> CommandArgs:
         """
         Return the RevOptions "extra arguments" to use in obtain().
         """
         return []
 
-    def get_url_rev_options(self, url):
-        # type: (HiddenText) -> Tuple[HiddenText, RevOptions]
+    def get_url_rev_options(self, url: HiddenText) -> Tuple[HiddenText, RevOptions]:
         """
         Return the URL and RevOptions object to use in obtain(),
         as a tuple (url, rev_options).
         """
         secret_url, rev, user_pass = self.get_url_rev_and_auth(url.secret)
         username, secret_password = user_pass
-        password = None  # type: Optional[HiddenText]
+        password: Optional[HiddenText] = None
         if secret_password is not None:
             password = hide_value(secret_password)
         extra_args = self.make_rev_args(username, password)
@@ -452,24 +449,23 @@ class VersionControl:
         return hide_url(secret_url), rev_options
 
     @staticmethod
-    def normalize_url(url):
-        # type: (str) -> str
+    def normalize_url(url: str) -> str:
         """
         Normalize a URL for comparison by unquoting it and removing any
         trailing slash.
         """
-        return urllib.parse.unquote(url).rstrip('/')
+        return urllib.parse.unquote(url).rstrip("/")
 
     @classmethod
-    def compare_urls(cls, url1, url2):
-        # type: (str, str) -> bool
+    def compare_urls(cls, url1: str, url2: str) -> bool:
         """
         Compare two repo URLs for identity, ignoring incidental differences.
         """
-        return (cls.normalize_url(url1) == cls.normalize_url(url2))
+        return cls.normalize_url(url1) == cls.normalize_url(url2)
 
-    def fetch_new(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def fetch_new(
+        self, dest: str, url: HiddenText, rev_options: RevOptions, verbosity: int
+    ) -> None:
         """
         Fetch a revision from a repository, in the case that this is the
         first fetch from the repository.
@@ -477,11 +473,11 @@ class VersionControl:
         Args:
           dest: the directory to fetch the repository to.
           rev_options: a RevOptions object.
+          verbosity: verbosity level.
         """
         raise NotImplementedError
 
-    def switch(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def switch(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
         """
         Switch the repo at ``dest`` to point to ``URL``.
 
@@ -490,8 +486,7 @@ class VersionControl:
         """
         raise NotImplementedError
 
-    def update(self, dest, url, rev_options):
-        # type: (str, HiddenText, RevOptions) -> None
+    def update(self, dest: str, url: HiddenText, rev_options: RevOptions) -> None:
         """
         Update an already-existing repo to the given ``rev_options``.
 
@@ -501,8 +496,7 @@ class VersionControl:
         raise NotImplementedError
 
     @classmethod
-    def is_commit_id_equal(cls, dest, name):
-        # type: (str, Optional[str]) -> bool
+    def is_commit_id_equal(cls, dest: str, name: Optional[str]) -> bool:
         """
         Return whether the id of the current commit equals the given name.
 
@@ -512,19 +506,19 @@ class VersionControl:
         """
         raise NotImplementedError
 
-    def obtain(self, dest, url):
-        # type: (str, HiddenText) -> None
+    def obtain(self, dest: str, url: HiddenText, verbosity: int) -> None:
         """
         Install or update in editable mode the package represented by this
         VersionControl object.
 
         :param dest: the repository directory in which to install or update.
         :param url: the repository URL starting with a vcs prefix.
+        :param verbosity: verbosity level.
         """
         url, rev_options = self.get_url_rev_options(url)
 
         if not os.path.exists(dest):
-            self.fetch_new(dest, url, rev_options)
+            self.fetch_new(dest, url, rev_options, verbosity=verbosity)
             return
 
         rev_display = rev_options.to_display()
@@ -532,73 +526,68 @@ class VersionControl:
             existing_url = self.get_remote_url(dest)
             if self.compare_urls(existing_url, url.secret):
                 logger.debug(
-                    '%s in %s exists, and has correct URL (%s)',
+                    "%s in %s exists, and has correct URL (%s)",
                     self.repo_name.title(),
                     display_path(dest),
                     url,
                 )
                 if not self.is_commit_id_equal(dest, rev_options.rev):
                     logger.info(
-                        'Updating %s %s%s',
+                        "Updating %s %s%s",
                         display_path(dest),
                         self.repo_name,
                         rev_display,
                     )
                     self.update(dest, url, rev_options)
                 else:
-                    logger.info('Skipping because already up-to-date.')
+                    logger.info("Skipping because already up-to-date.")
                 return
 
             logger.warning(
-                '%s %s in %s exists with URL %s',
+                "%s %s in %s exists with URL %s",
                 self.name,
                 self.repo_name,
                 display_path(dest),
                 existing_url,
             )
-            prompt = ('(s)witch, (i)gnore, (w)ipe, (b)ackup ',
-                      ('s', 'i', 'w', 'b'))
+            prompt = ("(s)witch, (i)gnore, (w)ipe, (b)ackup ", ("s", "i", "w", "b"))
         else:
             logger.warning(
-                'Directory %s already exists, and is not a %s %s.',
+                "Directory %s already exists, and is not a %s %s.",
                 dest,
                 self.name,
                 self.repo_name,
             )
             # https://github.com/python/mypy/issues/1174
-            prompt = ('(i)gnore, (w)ipe, (b)ackup ',  # type: ignore
-                      ('i', 'w', 'b'))
+            prompt = ("(i)gnore, (w)ipe, (b)ackup ", ("i", "w", "b"))  # type: ignore
 
         logger.warning(
-            'The plan is to install the %s repository %s',
+            "The plan is to install the %s repository %s",
             self.name,
             url,
         )
-        response = ask_path_exists('What to do?  {}'.format(
-            prompt[0]), prompt[1])
+        response = ask_path_exists("What to do?  {}".format(prompt[0]), prompt[1])
 
-        if response == 'a':
+        if response == "a":
             sys.exit(-1)
 
-        if response == 'w':
-            logger.warning('Deleting %s', display_path(dest))
+        if response == "w":
+            logger.warning("Deleting %s", display_path(dest))
             rmtree(dest)
-            self.fetch_new(dest, url, rev_options)
+            self.fetch_new(dest, url, rev_options, verbosity=verbosity)
             return
 
-        if response == 'b':
+        if response == "b":
             dest_dir = backup_dir(dest)
-            logger.warning(
-                'Backing up %s to %s', display_path(dest), dest_dir,
-            )
+            logger.warning("Backing up %s to %s", display_path(dest), dest_dir)
             shutil.move(dest, dest_dir)
-            self.fetch_new(dest, url, rev_options)
+            self.fetch_new(dest, url, rev_options, verbosity=verbosity)
             return
 
         # Do nothing if the response is "i".
-        if response == 's':
+        if response == "s":
             logger.info(
-                'Switching %s %s to %s%s',
+                "Switching %s %s to %s%s",
                 self.repo_name,
                 display_path(dest),
                 url,
@@ -606,21 +595,20 @@ class VersionControl:
             )
             self.switch(dest, url, rev_options)
 
-    def unpack(self, location, url):
-        # type: (str, HiddenText) -> None
+    def unpack(self, location: str, url: HiddenText, verbosity: int) -> None:
         """
         Clean up current location and download the url repository
         (and vcs infos) into location
 
         :param url: the repository URL starting with a vcs prefix.
+        :param verbosity: verbosity level.
         """
         if os.path.exists(location):
             rmtree(location)
-        self.obtain(location, url=url)
+        self.obtain(location, url=url, verbosity=verbosity)
 
     @classmethod
-    def get_remote_url(cls, location):
-        # type: (str) -> str
+    def get_remote_url(cls, location: str) -> str:
         """
         Return the url used at location
 
@@ -630,8 +618,7 @@ class VersionControl:
         raise NotImplementedError
 
     @classmethod
-    def get_revision(cls, location):
-        # type: (str) -> str
+    def get_revision(cls, location: str) -> str:
         """
         Return the current commit id of the files at the given location.
         """
@@ -640,40 +627,46 @@ class VersionControl:
     @classmethod
     def run_command(
         cls,
-        cmd,  # type: Union[List[str], CommandArgs]
-        show_stdout=True,  # type: bool
-        cwd=None,  # type: Optional[str]
-        on_returncode='raise',  # type: str
-        extra_ok_returncodes=None,  # type: Optional[Iterable[int]]
-        command_desc=None,  # type: Optional[str]
-        extra_environ=None,  # type: Optional[Mapping[str, Any]]
-        spinner=None,  # type: Optional[SpinnerInterface]
-        log_failed_cmd=True,  # type: bool
-        stdout_only=False,  # type: bool
-    ):
-        # type: (...) -> str
+        cmd: Union[List[str], CommandArgs],
+        show_stdout: bool = True,
+        cwd: Optional[str] = None,
+        on_returncode: 'Literal["raise", "warn", "ignore"]' = "raise",
+        extra_ok_returncodes: Optional[Iterable[int]] = None,
+        command_desc: Optional[str] = None,
+        extra_environ: Optional[Mapping[str, Any]] = None,
+        spinner: Optional[SpinnerInterface] = None,
+        log_failed_cmd: bool = True,
+        stdout_only: bool = False,
+    ) -> str:
         """
         Run a VCS subcommand
         This is simply a wrapper around call_subprocess that adds the VCS
         command name, and checks that the VCS is available
         """
         cmd = make_command(cls.name, *cmd)
+        if command_desc is None:
+            command_desc = format_command_args(cmd)
         try:
-            return call_subprocess(cmd, show_stdout, cwd,
-                                   on_returncode=on_returncode,
-                                   extra_ok_returncodes=extra_ok_returncodes,
-                                   command_desc=command_desc,
-                                   extra_environ=extra_environ,
-                                   unset_environ=cls.unset_environ,
-                                   spinner=spinner,
-                                   log_failed_cmd=log_failed_cmd,
-                                   stdout_only=stdout_only)
+            return call_subprocess(
+                cmd,
+                show_stdout,
+                cwd,
+                on_returncode=on_returncode,
+                extra_ok_returncodes=extra_ok_returncodes,
+                command_desc=command_desc,
+                extra_environ=extra_environ,
+                unset_environ=cls.unset_environ,
+                spinner=spinner,
+                log_failed_cmd=log_failed_cmd,
+                stdout_only=stdout_only,
+            )
         except FileNotFoundError:
             # errno.ENOENT = no such file or directory
             # In other words, the VCS executable isn't available
             raise BadCommand(
-                f'Cannot find command {cls.name!r} - do you have '
-                f'{cls.name!r} installed and in your PATH?')
+                f"Cannot find command {cls.name!r} - do you have "
+                f"{cls.name!r} installed and in your PATH?"
+            )
         except PermissionError:
             # errno.EACCES = Permission denied
             # This error occurs, for instance, when the command is installed
@@ -688,18 +681,15 @@ class VersionControl:
             )
 
     @classmethod
-    def is_repository_directory(cls, path):
-        # type: (str) -> bool
+    def is_repository_directory(cls, path: str) -> bool:
         """
         Return whether a directory path is a repository directory.
         """
-        logger.debug('Checking in %s for %s (%s)...',
-                     path, cls.dirname, cls.name)
+        logger.debug("Checking in %s for %s (%s)...", path, cls.dirname, cls.name)
         return os.path.exists(os.path.join(path, cls.dirname))
 
     @classmethod
-    def get_repository_root(cls, location):
-        # type: (str) -> Optional[str]
+    def get_repository_root(cls, location: str) -> Optional[str]:
         """
         Return the "root" (top-level) directory controlled by the vcs,
         or `None` if the directory is not in any.
diff --git a/env/Lib/site-packages/pip/_internal/wheel_builder.py b/env/Lib/site-packages/pip/_internal/wheel_builder.py
index 92f172bc..60d75dd1 100644
--- a/env/Lib/site-packages/pip/_internal/wheel_builder.py
+++ b/env/Lib/site-packages/pip/_internal/wheel_builder.py
@@ -5,21 +5,22 @@ import logging
 import os.path
 import re
 import shutil
-from typing import Any, Callable, Iterable, List, Optional, Tuple
+from typing import Iterable, List, Optional, Tuple
 
 from pip._vendor.packaging.utils import canonicalize_name, canonicalize_version
 from pip._vendor.packaging.version import InvalidVersion, Version
 
 from pip._internal.cache import WheelCache
 from pip._internal.exceptions import InvalidWheelFilename, UnsupportedWheel
-from pip._internal.metadata import get_wheel_distribution
+from pip._internal.metadata import FilesystemWheel, get_wheel_distribution
 from pip._internal.models.link import Link
 from pip._internal.models.wheel import Wheel
 from pip._internal.operations.build.wheel import build_wheel_pep517
+from pip._internal.operations.build.wheel_editable import build_wheel_editable
 from pip._internal.operations.build.wheel_legacy import build_wheel_legacy
 from pip._internal.req.req_install import InstallRequirement
 from pip._internal.utils.logging import indent_log
-from pip._internal.utils.misc import ensure_dir, hash_file, is_wheel_installed
+from pip._internal.utils.misc import ensure_dir, hash_file
 from pip._internal.utils.setuptools_build import make_setuptools_clean_args
 from pip._internal.utils.subprocess import call_subprocess
 from pip._internal.utils.temp_dir import TempDirectory
@@ -28,14 +29,12 @@ from pip._internal.vcs import vcs
 
 logger = logging.getLogger(__name__)
 
-_egg_info_re = re.compile(r'([a-z0-9_.]+)-([a-z0-9_.!+-]+)', re.IGNORECASE)
+_egg_info_re = re.compile(r"([a-z0-9_.]+)-([a-z0-9_.!+-]+)", re.IGNORECASE)
 
-BinaryAllowedPredicate = Callable[[InstallRequirement], bool]
 BuildResult = Tuple[List[InstallRequirement], List[InstallRequirement]]
 
 
-def _contains_egg_info(s):
-    # type: (str) -> bool
+def _contains_egg_info(s: str) -> bool:
     """Determine whether the string looks like an egg_info.
 
     :param s: The string to parse. E.g. foo-2.1
@@ -44,11 +43,9 @@ def _contains_egg_info(s):
 
 
 def _should_build(
-    req,  # type: InstallRequirement
-    need_wheel,  # type: bool
-    check_binary_allowed,  # type: BinaryAllowedPredicate
-):
-    # type: (...) -> bool
+    req: InstallRequirement,
+    need_wheel: bool,
+) -> bool:
     """Return whether an InstallRequirement should be built into a wheel."""
     if req.constraint:
         # never build requirements that are merely constraints
@@ -56,7 +53,8 @@ def _should_build(
     if req.is_wheel:
         if need_wheel:
             logger.info(
-                'Skipping %s, due to already being wheel.', req.name,
+                "Skipping %s, due to already being wheel.",
+                req.name,
             )
         return False
 
@@ -67,53 +65,31 @@ def _should_build(
     # From this point, this concerns the pip install command only
     # (need_wheel=False).
 
-    if req.editable or not req.source_dir:
-        return False
-
-    if req.use_pep517:
-        return True
-
-    if not check_binary_allowed(req):
-        logger.info(
-            "Skipping wheel build for %s, due to binaries "
-            "being disabled for it.", req.name,
-        )
+    if not req.source_dir:
         return False
 
-    if not is_wheel_installed():
-        # we don't build legacy requirements if wheel is not installed
-        logger.info(
-            "Using legacy 'setup.py install' for %s, "
-            "since package 'wheel' is not installed.", req.name,
-        )
-        return False
+    if req.editable:
+        # we only build PEP 660 editable requirements
+        return req.supports_pyproject_editable()
 
     return True
 
 
 def should_build_for_wheel_command(
-    req,  # type: InstallRequirement
-):
-    # type: (...) -> bool
-    return _should_build(
-        req, need_wheel=True, check_binary_allowed=_always_true
-    )
+    req: InstallRequirement,
+) -> bool:
+    return _should_build(req, need_wheel=True)
 
 
 def should_build_for_install_command(
-    req,  # type: InstallRequirement
-    check_binary_allowed,  # type: BinaryAllowedPredicate
-):
-    # type: (...) -> bool
-    return _should_build(
-        req, need_wheel=False, check_binary_allowed=check_binary_allowed
-    )
+    req: InstallRequirement,
+) -> bool:
+    return _should_build(req, need_wheel=False)
 
 
 def _should_cache(
-    req,  # type: InstallRequirement
-):
-    # type: (...) -> Optional[bool]
+    req: InstallRequirement,
+) -> Optional[bool]:
     """
     Return whether a built InstallRequirement can be stored in the persistent
     wheel cache, assuming the wheel cache is available, and _should_build()
@@ -144,10 +120,9 @@ def _should_cache(
 
 
 def _get_cache_dir(
-    req,  # type: InstallRequirement
-    wheel_cache,  # type: WheelCache
-):
-    # type: (...) -> str
+    req: InstallRequirement,
+    wheel_cache: WheelCache,
+) -> str:
     """Return the persistent or temporary cache directory where the built
     wheel need to be stored.
     """
@@ -160,13 +135,7 @@ def _get_cache_dir(
     return cache_dir
 
 
-def _always_true(_):
-    # type: (Any) -> bool
-    return True
-
-
-def _verify_one(req, wheel_path):
-    # type: (InstallRequirement, str) -> None
+def _verify_one(req: InstallRequirement, wheel_path: str) -> None:
     canonical_name = canonicalize_name(req.name or "")
     w = Wheel(os.path.basename(wheel_path))
     if canonicalize_name(w.name) != canonical_name:
@@ -174,7 +143,7 @@ def _verify_one(req, wheel_path):
             "Wheel has unexpected file name: expected {!r}, "
             "got {!r}".format(canonical_name, w.name),
         )
-    dist = get_wheel_distribution(wheel_path, canonical_name)
+    dist = get_wheel_distribution(FilesystemWheel(wheel_path), canonical_name)
     dist_verstr = str(dist.version)
     if canonicalize_version(dist_verstr) != canonicalize_version(w.version):
         raise InvalidWheelFilename(
@@ -189,8 +158,7 @@ def _verify_one(req, wheel_path):
     except InvalidVersion:
         msg = f"Invalid Metadata-Version: {metadata_version_value}"
         raise UnsupportedWheel(msg)
-    if (metadata_version >= Version("1.2")
-            and not isinstance(dist.version, Version)):
+    if metadata_version >= Version("1.2") and not isinstance(dist.version, Version):
         raise UnsupportedWheel(
             "Metadata 1.2 mandates PEP 440 version, "
             "but {!r} is not".format(dist_verstr)
@@ -198,47 +166,50 @@ def _verify_one(req, wheel_path):
 
 
 def _build_one(
-    req,  # type: InstallRequirement
-    output_dir,  # type: str
-    verify,  # type: bool
-    build_options,  # type: List[str]
-    global_options,  # type: List[str]
-):
-    # type: (...) -> Optional[str]
+    req: InstallRequirement,
+    output_dir: str,
+    verify: bool,
+    build_options: List[str],
+    global_options: List[str],
+    editable: bool,
+) -> Optional[str]:
     """Build one wheel.
 
     :return: The filename of the built wheel, or None if the build failed.
     """
+    artifact = "editable" if editable else "wheel"
     try:
         ensure_dir(output_dir)
     except OSError as e:
         logger.warning(
-            "Building wheel for %s failed: %s",
-            req.name, e,
+            "Building %s for %s failed: %s",
+            artifact,
+            req.name,
+            e,
         )
         return None
 
     # Install build deps into temporary directory (PEP 518)
     with req.build_env:
         wheel_path = _build_one_inside_env(
-            req, output_dir, build_options, global_options
+            req, output_dir, build_options, global_options, editable
         )
     if wheel_path and verify:
         try:
             _verify_one(req, wheel_path)
         except (InvalidWheelFilename, UnsupportedWheel) as e:
-            logger.warning("Built wheel for %s is invalid: %s", req.name, e)
+            logger.warning("Built %s for %s is invalid: %s", artifact, req.name, e)
             return None
     return wheel_path
 
 
 def _build_one_inside_env(
-    req,  # type: InstallRequirement
-    output_dir,  # type: str
-    build_options,  # type: List[str]
-    global_options,  # type: List[str]
-):
-    # type: (...) -> Optional[str]
+    req: InstallRequirement,
+    output_dir: str,
+    build_options: List[str],
+    global_options: List[str],
+    editable: bool,
+) -> Optional[str]:
     with TempDirectory(kind="wheel") as temp_dir:
         assert req.name
         if req.use_pep517:
@@ -246,18 +217,26 @@ def _build_one_inside_env(
             assert req.pep517_backend
             if global_options:
                 logger.warning(
-                    'Ignoring --global-option when building %s using PEP 517', req.name
+                    "Ignoring --global-option when building %s using PEP 517", req.name
                 )
             if build_options:
                 logger.warning(
-                    'Ignoring --build-option when building %s using PEP 517', req.name
+                    "Ignoring --build-option when building %s using PEP 517", req.name
+                )
+            if editable:
+                wheel_path = build_wheel_editable(
+                    name=req.name,
+                    backend=req.pep517_backend,
+                    metadata_directory=req.metadata_directory,
+                    tempd=temp_dir.path,
+                )
+            else:
+                wheel_path = build_wheel_pep517(
+                    name=req.name,
+                    backend=req.pep517_backend,
+                    metadata_directory=req.metadata_directory,
+                    tempd=temp_dir.path,
                 )
-            wheel_path = build_wheel_pep517(
-                name=req.name,
-                backend=req.pep517_backend,
-                metadata_directory=req.metadata_directory,
-                tempd=temp_dir.path,
-            )
         else:
             wheel_path = build_wheel_legacy(
                 name=req.name,
@@ -274,16 +253,20 @@ def _build_one_inside_env(
             try:
                 wheel_hash, length = hash_file(wheel_path)
                 shutil.move(wheel_path, dest_path)
-                logger.info('Created wheel for %s: '
-                            'filename=%s size=%d sha256=%s',
-                            req.name, wheel_name, length,
-                            wheel_hash.hexdigest())
-                logger.info('Stored in directory: %s', output_dir)
+                logger.info(
+                    "Created wheel for %s: filename=%s size=%d sha256=%s",
+                    req.name,
+                    wheel_name,
+                    length,
+                    wheel_hash.hexdigest(),
+                )
+                logger.info("Stored in directory: %s", output_dir)
                 return dest_path
             except Exception as e:
                 logger.warning(
                     "Building wheel for %s failed: %s",
-                    req.name, e,
+                    req.name,
+                    e,
                 )
         # Ignore return, we can't do anything else useful.
         if not req.use_pep517:
@@ -291,30 +274,30 @@ def _build_one_inside_env(
         return None
 
 
-def _clean_one_legacy(req, global_options):
-    # type: (InstallRequirement, List[str]) -> bool
+def _clean_one_legacy(req: InstallRequirement, global_options: List[str]) -> bool:
     clean_args = make_setuptools_clean_args(
         req.setup_py_path,
         global_options=global_options,
     )
 
-    logger.info('Running setup.py clean for %s', req.name)
+    logger.info("Running setup.py clean for %s", req.name)
     try:
-        call_subprocess(clean_args, cwd=req.source_dir)
+        call_subprocess(
+            clean_args, command_desc="python setup.py clean", cwd=req.source_dir
+        )
         return True
     except Exception:
-        logger.error('Failed cleaning build dir for %s', req.name)
+        logger.error("Failed cleaning build dir for %s", req.name)
         return False
 
 
 def build(
-    requirements,  # type: Iterable[InstallRequirement]
-    wheel_cache,  # type: WheelCache
-    verify,  # type: bool
-    build_options,  # type: List[str]
-    global_options,  # type: List[str]
-):
-    # type: (...) -> BuildResult
+    requirements: Iterable[InstallRequirement],
+    wheel_cache: WheelCache,
+    verify: bool,
+    build_options: List[str],
+    global_options: List[str],
+) -> BuildResult:
     """Build wheels.
 
     :return: The list of InstallRequirement that succeeded to build and
@@ -325,18 +308,30 @@ def build(
 
     # Build the wheels.
     logger.info(
-        'Building wheels for collected packages: %s',
-        ', '.join(req.name for req in requirements),  # type: ignore
+        "Building wheels for collected packages: %s",
+        ", ".join(req.name for req in requirements),  # type: ignore
     )
 
     with indent_log():
         build_successes, build_failures = [], []
         for req in requirements:
+            assert req.name
             cache_dir = _get_cache_dir(req, wheel_cache)
             wheel_file = _build_one(
-                req, cache_dir, verify, build_options, global_options
+                req,
+                cache_dir,
+                verify,
+                build_options,
+                global_options,
+                req.editable and req.permit_editable_wheels,
             )
             if wheel_file:
+                # Record the download origin in the cache
+                if req.download_info is not None:
+                    # download_info is guaranteed to be set because when we build an
+                    # InstallRequirement it has been through the preparer before, but
+                    # let's be cautious.
+                    wheel_cache.record_download_origin(cache_dir, req.download_info)
                 # Update the link for this.
                 req.link = Link(path_to_url(wheel_file))
                 req.local_file_path = req.link.file_path
@@ -348,13 +343,13 @@ def build(
     # notify success/failure
     if build_successes:
         logger.info(
-            'Successfully built %s',
-            ' '.join([req.name for req in build_successes]),  # type: ignore
+            "Successfully built %s",
+            " ".join([req.name for req in build_successes]),  # type: ignore
         )
     if build_failures:
         logger.info(
-            'Failed to build %s',
-            ' '.join([req.name for req in build_failures]),  # type: ignore
+            "Failed to build %s",
+            " ".join([req.name for req in build_failures]),  # type: ignore
         )
     # Return a list of requirements that failed to build
     return build_successes, build_failures
diff --git a/env/Lib/site-packages/pip/_vendor/__init__.py b/env/Lib/site-packages/pip/_vendor/__init__.py
index a10ecd60..b22f7abb 100644
--- a/env/Lib/site-packages/pip/_vendor/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/__init__.py
@@ -58,13 +58,11 @@ if DEBUNDLED:
     sys.path[:] = glob.glob(os.path.join(WHEEL_DIR, "*.whl")) + sys.path
 
     # Actually alias all of our vendored dependencies.
-    vendored("appdirs")
     vendored("cachecontrol")
     vendored("certifi")
     vendored("colorama")
     vendored("distlib")
     vendored("distro")
-    vendored("html5lib")
     vendored("six")
     vendored("six.moves")
     vendored("six.moves.urllib")
@@ -74,6 +72,7 @@ if DEBUNDLED:
     vendored("packaging.specifiers")
     vendored("pep517")
     vendored("pkg_resources")
+    vendored("platformdirs")
     vendored("progress")
     vendored("requests")
     vendored("requests.exceptions")
@@ -106,8 +105,16 @@ if DEBUNDLED:
     vendored("requests.packages.urllib3.util.timeout")
     vendored("requests.packages.urllib3.util.url")
     vendored("resolvelib")
+    vendored("rich")
+    vendored("rich.console")
+    vendored("rich.highlighter")
+    vendored("rich.logging")
+    vendored("rich.markup")
+    vendored("rich.progress")
+    vendored("rich.segment")
+    vendored("rich.style")
+    vendored("rich.text")
+    vendored("rich.traceback")
     vendored("tenacity")
-    vendored("toml")
-    vendored("toml.encoder")
-    vendored("toml.decoder")
+    vendored("tomli")
     vendored("urllib3")
diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 44980fc6fc07a83d803c9c2c8f445fbf0a9293fb..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/appdirs.cpython-39.pyc
deleted file mode 100644
index 56bdeee96913eee10207643cdb43c03408645567..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 21427
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
E04j}20{{R3

diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/distro.cpython-39.pyc
deleted file mode 100644
index 7a4216e49825f65191a088d7d1e2bd48755d1cea..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 36906
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
KY|I?uT#NwYlpyc`

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

literal 240463
zcmYe~<>g{vU|^UdaWM6hHVeaJ5C<7^GcYhXFfcF_U*Kh6NMVR#NMVd(Oks**N@0#-
zPGL!5&0&dRNnuH0%VEuBi(+SF0E=-%ae!&gC{8fV6~zUnxudwjG*1){nC6Y*1=D;{
zd|;YCiXTi1L<yv@q_F1*<_bm$g3aW}5y};g5(cwbb3~#<Qdm+rb3}8+qQt;rTsh*o
z5>XP23{@bV+&Ln-l2MY34B-rUax4s~Qk9n&89*?FC50zPBv%?F7s-&vWB^gmn<JAe
z8zl=?uK-d%fw7VWq#kTGZ;l*97OF!bg(ZbAM?O~}N&zg-pCg~E7^Rr26r}_<!2oJP
z7~BND99|^Vya?4$6G3hk$l=XZj#2@eU<Wl}8N>vzp9FGL;qnqt`2`U96xJveh)EC<
ztX?ojAXhC)4Q!qgRQ)Z8dUu8tp%md3h7{purYJRto>aAFhA8zEkyQ0~h7{3M^>_`i
zh-Qjds%AVxig>DKycU?$29r8qQWs3>rAVYmwlJjXr)oAcx-c{|rfS9;q)4Smw=hH*
zrW&Sd#v7$Gq{u8{j51C&N#)EkZDveiO_6P7l4OW7OEpVjkz`1b&1Q-+Pc@&wR5T-%
zGs_~%GSw=|I@Ko1Hq|Q1F4Zc^KGh-BG1V#6In^cAB-J(5E!92MBh@pVJIX6BE|oLO
zJIXTEC(1WPE=9hDA<90TA<7G!lKi6lQWO^WFJy3Gh&77}s1ix_S`e5Tl<Jon(9E=u
z5ga;FEDWi^6PPMLKtd;yVFFX(K1is5Sg9c?iYZDh45_{;$`JoGGe(7`sHCX2Fhqr=
zvSfv)vSdYwGekwEs6|DkMy05WGekwFMy5uIGepIt+N5YSGe*UxXfB9L(E^*pk`)gM
zrG<=92@@DooKv(@bXpjr65Sb6bW`+N7*h07lbV^MlHD0n^ivF47*Y&Ulbe~NQrsC*
z3{#9+7*dSD{8V>_6yp?=7KRj))YN9?s5Ezm6w?&57KRivu>N#+h7|J@ix!3yi`0x}
z=BP|}h7`*bs}_b7D=<GRRdGRfY8EIAQmj*KS{R~oQfyP~S{R~oQ|wb5S{S18QXEs9
zS{S18Q=C&=S{R}VQe0EqS{R}VQ`}QLS{R~=CNQSBq<E!xw=hN(yECNtr1-Wlr1*kO
zFL7r`@k{Y<VMy^$Eoo+sDs^W_2}lWSVMqxC^UK^BQi4)~TNqM;Q_Gr}qsrYGQbJNf
zTNqM8!Tbt$hLo_B@D_%Ya4^5pogpP6C9;JfB{H?LnK`N|wKA$YwKBCNzQ&y)B`PJl
zg&`#xtg_afAtfdywuK=j7Ob+)ogpPICBB6rB|f#bnK`Q7ogpP5C9#DeB@wK?!JQ!`
zDJ8juAtf2iZ**r!Nl8g<VMs|$ZER+aYI0{tNlQs@VMs|&ZE9wYYIbKx$w<j;VMxgY
zt8Z~<NXbgcZed8t2J>6p8B%gma$6Wua>4vIcZQU_l>8QklzcG1-JKz&Af>Q{A*B$^
z?{H^GDM~4BVMr-X?Pz9>>U3vFDM=}9VMr+j^Sj&`Qp!@wTNqNx!TfG_hLnnw$`*!{
zN-)32ogt+vrMiV7r5eodb!SMaNvUmNNT~($``j5)>Qd@k7*guN{C;<al!lbX7KW5Y
za7;{aXGm#EX>MUiX-=Kc%p5h*ogt+qrL~12r4`Jd<j#=NmeStBkkSt3Pj+WW=}75p
zVMyr&^QX8oq;#cpw=kr1gUy@j&XCfR(%Zt2(wjQ9nK^2jJ3~reN`DJON<WxC-JKz2
zLdwJzhLnk5{tS19lu0R*TNqL%gZVSv8B(UCOl@IEnVLGYnK^2fJ44E}l<6%DDbvCH
z+3pM}Gg4-@Fr>@`r?ffl3@NixX16e;%m(Y9>&}oeCuMF6L&{t*f1W!-%Dj~MEet91
z!TkB|3@Hmz7Pc^?ECllxxHF_IN?F{(kg_;+K{IpILU)FgB`Hf=7*dvk`HS2cQkJDG
zZ(&GT4(2a*XGmF*va*FCWhI!u#GN5!Rm$oXhLqJ{_bg3Wld`sjA!^wK#uV3-^(h-#
z7^9X?U`%mK*_g7ag)wSH%I1_UEeugBQ?{mTYhj35m9jl$M+-yL>Xe-+yIL5c)=Xeb
zaZlNuvZsYHYHiBilzlA>QR^l!rg)_6PdU)S7_~m-V9KEuhNulGhf|KUFhp%kEpKL6
zuqox}LdK}gsa;_9v4xCLTT;8h?Bfd=qqe5@fY~P&GDdAn?FF+>E@X__p4ylin{q0}
zGv#zI^MV~IXHw3#Ff3$@+L_vta;}+i!H$&kP?24!Eh!hkA{U_|yHj_j?s8&C-R;DX
z+Lm%DMLFekFOw5P)SlEuse4kFq+D)h6lX}?BhJvw7_~RGGUZA$W9r<LtIdoH_N81~
z2$EZrIxBT=>K-SCW=62+b&zPv4RMC3{V6w7ZnZE(9Z0#Ia;JqM>R`&<lzS}<QHN6Q
zr#xt3h&r6|Fy&DTL)4MfBPowT?rCO>I+}VU<q4F1EOklB(`LrhB`MFE8Pk|jo~OKM
zVT?MS@-pRB3q#b2l-DV5S{R~Ero2sg*TN8WDm9~-A@x-J=?RP}o+<BBKD01KodMT=
zXTdUO<Ih3q^QlWxK7!5t1UC0`%9j?#s0*nVqAsQ`Ol?W|+RT{p4dmkmn^L|nWQ@85
z7X8u8nDP@U`fDL$)Mc<JRBdWY3RE5x4huG={9ecybtQFSYIVw=X2#Sj3pf@sK=uAz
z$QX4s<zvdH6jq3M8cWK*l>aS^QP(Cgrg%+YOktS7n8Mh?7<E1Mzy!t=re?;d8(<c5
zGh@`v)Dx+VsgbEM6Btui#2K2I7Hpcpn8Lb{v6(T3De6|#?bJJ|cPB8Wuz_mJ35+T1
z%^>~vQd=f4rf^JPOyOJ*mwIo({e=vmSen3?!Ub{F1jZEZg^W=TCNQS(OkhmmZDELd
z2=d<q#uUD0#tDom{BU&w3mKyxfz1<aW(3<Vw2(3CF<3;nnQ_6Bg$!U(k%f#=Pr;(1
zP<3Jp8Ka(|o0|Fz5@Hh=Q^XfCMm<k`9`ypOO9HA(av@{X%hZLbvr-#V6H-8VNUE19
zb#7|o1jZEUX2#UYly%LF{0!m@pqv7tK`9oT7GFVKBD0V&>UHY!)VYxGPJQjfkfJ$(
zF-5kQ32KMjLdK{!?x1j&pTL-+&;nv9G&4oL1&b+8U<B3pAQD_QyaS6WPhd<@0jpF2
zi@pbos!m``Q3H#rrM_=wj{1=LA?st-r>xIl`b*YlaRxB!D~uKYIn{guPf=3px6}_4
z7*o_!KV*GxW@co7@-<RFWc@(mYo>n4`iaEXO8t=a3yH6t`XTE#5?=>o8;qazaROtC
zE=VNn6N;D~SnMl`m_AtS3ruVRV~RoQhpazHe8bcaS$~oEMyVgN{(<=5kT9OW2x`}W
z$Y!Rf{}UKfL7{4z%`}0x=uB$e1jZCIP|Av81hdV-Y$kZxwg9E=35-$9smmuYrZP`p
zOtDN6oxqr41uEfEk1k}Kz!=4nx(F=G0*-A^KClLhvrb@4v6;Y_%Id^0fia2=tOmOY
z>`)Wf;U?IEP2iZom<meub|6=!vQ1!2u?D5835=;s;tUfQQ#mFurr1J6qBtiorgBbT
zT);JfF~uI#4oiJIfia64D&hba;lU8$g^D<W)PUN#6Bu*&CNM_vflc6Bup{-z1jbap
z35;3%&5R&55OJt3Cy+=AYcPX`HzNZ>;&m<t2Cjn2g2bZY%)E4k-29Z%oKyu}1?QZ^
z;^Nd|g~YrRh1}GVjQo^hg_3-Ql+?7$yi~AgYDH>tX-TRAOlx{kVs36?Q8AY-H31h_
zNJgpxh66J}E>lR%DM>BLODxGOOI1iLC@9KLOwItgGPx)<u>|Cu#Jm(Ph&w^N;>_HF
zoKyvvLv<9&iuDvqGEx;viV{;YOEUBG5_1%CQY-W;6O)tS2I?r}7lBl9l@_Ne<fkbV
zrKXqWBo-;8RumMa78hsc=N0QID1>L0WFVZWqfnV&s*sYOr(U9vmztUaa#T)gVo@Gf
zqC#G3xk7PeUP)qwLRx+iBt${3gE<RiU2bAYat25c$r1%!kSk!p&6Nv@se+>Xvdk1v
zL@DHCCKV+XRf61@42`{#jKmVKQ$TJn$yZ3u&nqq|Dori{8N~&)Q6VL>C^fkxr&1v^
zPa&YPBqKjhkBiGAwJ22q6wC?*Mfo6=AU}ZOI#of*BQ+-{Uq>N4zbGd~QAt4~zepi5
zuTmksC^Z!v?D=UR^FiLr<w{6UvMEl?DJ@9^1+bltf=yyd3Mk-GQ|%O$5)w3Z6p~6a
zb4nCS3lvJhY0wJndaH!+{GyZu9WEHxC$l8AC^08N2b}s~qK<hf2@0t>sky0nCB<AC
zpxA^-scWm-1SA#}rxv+F<n`j?6H`*+<Lwd@@(WUn5=-)niWR_VB~<~Y31S{1YIV3k
zIRIpAaY<2TUV5=YVo|C>VrfafZgPHJS!z)UBz9r?VXj0@9-3BGTwDqY3JPgO`MC-O
znFV_BWvO{7`9*q&be)-7kY7{+3eprEg~XhKjKpGy9%V=hfhSu~^d`cC8f+{$+!buW
znl&JLH5IfKlysC7v@rw~l_2J3fZ|ZW7Ckb-1{M@$=9MUDfR*SdDCycM=|F7M11ErB
za7aL;H8r6*6q-o#OG^q$ONycKpOceco|%^p^FK<uQP8zhh*k#+sp}}H>wpMwiUKhd
z)ng&%Leir`Q7S02rRG6W5hx5mQ36Vqxrs%fWLj97S(2(yl$w~5n3R*MqX4!Slw?aX
zQn`v#bJBEED++QF^FWbasQ^x43VDgSsl|}w1TqbjNAlAY)U`nls8I(eGxa!iL|V~<
zI0+Wj;ItK#T3nh_Qk<ZWpOlrFT%u5vT2fk+mzn~OYk1lPD}^URq(DqiNKVXCNJ`~O
zOioTME>2BRNGw(Wl@Z0Dbd{4?T%x0psF0GG49Yx-MU~*fC@~LaTREuI0eK^ZE3u@c
zC^M<FB()goOhnp(78MzZc_}%m#R|pwx!{5f<mZB-{G^=JTu^)^mVlFXNo7H1a$-(S
zC0AK$1*ixr&q&QvC@;zc=j@WyiV|=Ulv-2_PSm;zsTCzfiQqyjvlyIz%QG@dQi}@`
zlT#JI`7tpmzbqAAij-&O<R~QO6z3~I+yhQ<&=Lh4{fbID&_t=AprZgvzd0!i3Lw$c
zl4LziE(HZ$g~HN&Q20QzBv>dlHz_qGB{fAMIX@Rt7;tg9r<Q<S9bA$K&ZoLuy6Au_
zEVDQhTpU6YMQSm;C_ss{1aNY|9`z;pT*axW;3S`vSeyzs2weK+<`<VJ<d<Zm79pw!
zE^zuwEmp|P%SbKCECDALJ%!L>h#@KY$xxqxicp2ribPPoRSZh?8TsW3CHbI`*F`GK
zb09^d0=U{hE_uKP!#xBqn?Ti~f&yIJIk7l3C$+d3E)R7cmjbdS$r*`7iOD6YMGEEl
zMJc-JMfs%#D0V?gZ&0d&1rxXg2SqU0K#*~uaDw;&R`3?37NnMBf~#=k$_`=}%%G^$
zqI~}%-~6J~1dwr{A{i#-pO*@ifrUHB9#CF}sQ}djj(I6|2|92etJkR8_=4(Kx6GpA
z5)_#@bsPU8y96C{d(_p`ZCn$RGf*lIaFv>y1ZomN8yCoa$jmFr2N{!_Uz7?;mIXPf
z6$<%zsl^}{CKeaxCub&>q(X`z1#nib%r7m1WUmy3B1p*ssT4uR!2E-fF7=92OQ2<t
zUt%sOcytvYWeGSvf{U6Ig_OjSL>-0ljLhT=P+<u#q`-v@in&m;z`>jkF491bP0P$n
zfs`8=sW}B{r8!6uuTY$kUsR%-3@Y_=GP4m?X-aBNW^QIlYKl*0aS7N!<ao=^OZ87n
zfEx}DqtfD3klCOdoS%ne1t_C{y#sS9yljhys0Eu2DhG?f#SSF7Rk0fBndq5Ui5eRy
z_$C%97#SEDC>R)6nHVdChB#Mg1tgZ{DEKD3mu42FD%cd1<R+&(loqEJ73&q}mlh?b
zrsWr<r|RXUme{=nO^WzwGTve?N=?&byv31{Sdv<jnVYJ~c#A8uBsDiZwWK7qNR#mv
zYk5&(L9r&|ExzRZJWyeoo0ylF4wm9h%LFx7(-L!vLHc+yQTePvKKaSnAj3UD?VO~X
zR86K^e7>b6p!&==v7jI`FZ~ufl%dIZi`%~_CABCu#U(SjM3eCre=xXl3rYjvFh~YD
z85uLe=5lx#7#LC+q8L*cqL@+`gBdiLiuf2982mJuZ*j!Og90%={uWn!Jfzl$kH5te
zA75CSm;;en$xtN3zyKkBRXSV6gn~jWCN(D|vna+tFV&?8)EL)Q2=(&}a}5gi3~>xr
z@bq)>_j3*Qbc_jh^>qynaSc*1iwOwuiAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#
zOwLYBPc4oq$Slx@HkS0^k*-%z33l={1_p-DAU}e6iH=MR44{0X;HZ#XlwVw|Tb5b`
zYMz6$USdgRQf5wONhPS*Ov_9!EdsYk!38YbV1=~Q#FEmYRA_YwuBwt!!Dbev=A<Tq
z>gUWng+zt4QjjtQs0DfoPL&G9(7L89F{cz<vMZEiWEP{@R+6s}QdF7>E?g8!GV+U4
z5mrJP0t%^lpa@R^wZ#jHGV_aImK1}Xnw+0ofbdF6YFTPdegUYu13MCwze-YzL3N%U
zq?HFQ!E<s_lS|?gb8_Mx^HSnV^0QO(iWPJf(sB~hK`kVRjS6X*kPeAwadBy?g0h*h
z0=WK4%dAK(R!A)>%Fj#9FD+I8m;0G{>0k>L6hM_y5wxTNrI2C;aC;#!Pr)%S1t|-I
zik-YvaH|GX(t$!TPr<(k)NVi&#MYotRDcwkp!PB-tdLxoRGJQQByv<BqRvRqSkD05
zJaPl&FpxHIld-4_5`hW|3I#=}x?p9HrU$5Tlb;4Ie&MApS4iSyW(Ec>m(0ZUy!_&l
z%w)6})JV+90ky~zOLIy<c7QDdHA)mf?UM4uqP+Or(wvgaf}B)nNXKX9fpb+#JiNP_
zpNARzAg$p31tk1n#Xl^VL17CDLr4caMIj%Q3=ts*3P*qBJ}IO=$<Ip#$$$%2P<#}Z
zCLvW&FtauC^KvQ`Kn^HY$V^j+2NkLXi6!yzddc}%(@tiw0v3Ol=7G~jY6{f5kc0;E
zKGc{@YWW*fwkBrgfg%v$9f*(Nj!;1LD<m<4+MO_8XC#)T!a^CG2#O&xy5Nui`yswK
zwIn`2FFrN5prkV1Ex)Kdu_y&^)FpzV1*R~w7?e^n^HNhFCM!Ukn22I4sQX)@kdaud
zkO%Icmw-C5sQRET%126CkoIAGVo`c=d`W&hC~u|_au~SARmg;TQ$Zm!FFC&m+Vcms
z_)}9L?t`UYh2oMTg~X!tQc(E<)ujt9pW;(elS<P;VFOB-De;JCKrUIp-DGI-0@eUd
zwmCVVxG7F8EKSWTfrSjn0pJlPjMfdPO4HEfa!Ur)V4%_-gqau^7+4t?7@R??6I2)&
z7}6PP7-D5=8EY69Fr+XnWGt2evltgL7O~VYPGl-%0o8O->=4()N3nvEd;ChqTU^DU
z&OtG#P|{?&#iVC&izzP`QO6YtGcYjR;<5pC#XyCx-5yZwCjufQ85kHas#%c3z>bn(
zU|>jLEMbUe1d~i)k{L|0q%Z_CtYq>F(PRZxxha{6>GAQmG{G){1wOvQ1F96B)WK;L
zR<NVyw_9>xQ$dl0H8I~(1<MmkT1epmuKmG*A`%Y`Oi;}NG6qz9?E^&!2Pldd*}$+!
zfq{WRv*Z?cd_1(ejE}#?59fqr=B7g08;PYQ8TmyJHYlV)1yGSRDD;^f^HOf{!+I&+
zsg<A(2tokbZMnteoRL^m?3Z8SnRkobIUn3Czr_M-AKhXBwcKy9x`OiYEiSiw(6~fu
zic{q+c4%I`#pRwKlJA_KQ<|H1i`5;}x4Fd*vx(g&GcVOOFXa{|hym_Q-eQN_8c>v)
zoSFhQjSEpA-(vU62lH;R`Q?{5=2hO}g!fc#aro!uRQl&7r{3c5F97%Kb8a#D7u^y9
zCw`~I;#Aj)<W#WCEn%=2bOg&aFC!78jSnISSHutHgK9iblLxBHEwLmq2VoQsSQWH|
ze@g_+3kHuwBGmALMPWk~w|D}<J#EN{&n?NI)a25l;>@yCcgSEbLLX~TYI<tLEw<q7
z%z}{oTbvLbpg`k>Fd@Ol5nNgTcH}MA5Kueh79W^$h7P3_-C_*~jUL=$0d*a3v4cpE
z8Jr*n!~`xxU+@+SD8_Gbf``2FN^^^Ev4NSzx40m*MN($TE$+m;O6Q#X;?$7D^jlns
zd6oVJsd*qaZ*p)+WlpLyWW3-Ob8>#pEg?{UA~86%Ah9SB+H<)j020g3^9b?vam_2q
zEUCQ3lbm0gSCX3ISX7i)d5b@}pa8`r{*<H~lyCzH1m`3cXTa>@Md=&eVgn8E_@~|C
zOUW<KOHM3K1qVv;Emm;FbBjGAwF2xt?u?S$9GDpbS&3zdDE6}CWag#bVh54nKm#!#
zfyM@6=H=hw$xX~o1$iVSF}?T}H;5PE>jUQSfd>yj3DdE}IX~x?AebLelv<XVUs~*1
zQBZVC1Vsp*0U*sfunPXX(wrO@P}SfF9<jQ`0(LhmxazsZo?qYy>h<0df(^ey^A0FU
zbAbmPL2cjSTO0+YdCB0&6Dk0YN27R?2QvBtNmjRbic)j)%TmGNU3^QhD77FbF&XSf
zXk>9ig+L?px44Q@i%a~|K>7F<e{ni$G_e&ICFZ54-r|JRuAngFhA<(aC{R+An4AjE
zAW-k|mgZ$9=clB?+)`SA6nng&I>iw-EO(1HGcP3-lxm!E@{_Y~@#hz1rf23Q=7gkH
zl(^*=-C~E9=OBe?nH7Hdkg?8N+&THlptJ}MU`~*k;JKMwT;N0vDPuUmZ7tu#f?ERc
z7BQ$5mz$q=OAsLfb?q%~C<9a_+!9O9&x6c<I2I%Ojj1U0B{QgsL#}s00-(|zT*aj@
zFff!b)G(AVHZv9R)i4AzRB@Fs)i5+OhBE{+urQP`SH?kBRh2M;L>I7>ur6R*$dJOg
zkg1ljgdH?TUCUI%w16XpIfVtZ_JEP0hG_w34dX&aHik%sU<LyQ&`gykTcSK81A|LZ
zet~Xg9%w8W6vd!c3Aj&GTvDWwpOmEuY2uX>WrF%|`3gy?3ZanLfweId(uy)u^HOpu
z^%Oiy6w*LLKMD}#FeCI7Jkub?q$OtN6ocDCaNUV8^IY>laqe1FlwYI+8kWdY0F5Am
z?S%#`*gardN-|RO;3n8WhlfG^%TxuZTG&`_jY2Be++vVvplAje4QdF2x*BjJz-mAZ
z-x>uyJv{|GJ-Ey*!HV1*&>&q=Y8o`jSFx!n$E0XmqcojB(aFZZzz__osX<LAP@4o4
zK`Bg<44{YrEzJW>Y^E@$Fo4+N48aVVtbSEYF{MQy%`ZW1oR|Oq|NpPabc;D7wc-|Y
zW?sok##@XfNbLl06M@4fCowlECDHCbsKEqkHC2hnmll^4>Dho%bxyIJ9!!OwCf6;l
z%;L<v;u3Hb#|{miTg=5JMYn{YQHd1vx7fg8k$Q`{xU%?`P<m=fN@^M?tiZyVdFe&&
zpvD7VacT*2vgR)-O3W)x%P-1>WLiz;Tg>@MS)ievk|-{uAOtsbzy#PUtYCM)0R<XJ
zkb#|xk%ftgnTv^sNraJuk&m%x1p@;^m059Vu0l>~o<eaxc*waZ71ZiUO;G?fAQehV
zK@*V0sU_g~GEi4CH#1KmH?aaGhCty9!l1@wG03tShFC68(>9EOk)e<Y+<Ij61BbOH
zQ;|5xmyDHQE`$KPm(wOaH4oG*x8q@CU?>8GebH(L28NfQC`7Ri)Q$#WaGtgTH(P5N
zQ<zeiTNqMU7BGNTPc}2wGL<maFxD_NGr2Itio`J0GS{-yFf3rIVXk3W$W+Tvr~u0U
znygj&uEoiT1*r;ZItn&A3U)dQN}$Od1<=?%XiOs!)T;oc-~2T2sH9#MtD2pSk~)fu
zK%NJcG{vCMmSSK4we5v!8B-W)7{wV<7{wW&0l^f^pvnA;QSBF_HCk{KLqY-+c;FU1
z*z3ZufT)s-ugJ}bPX)UaDJjB2tV%dBw?HAiL?NdHJk_9(Sdd?=$$X2oxF9F9<Q8*P
zX2C6XXdcsKy~P3=UcJQwn%#>puFOr!&ndpeRgw>9vw~%AF_+}WqdDsqH<Cm67#SFf
z!3(lkSQv#Eg+OU)2Pks63=EBoO-#+qEi9vW9G#q9T-_3rl2cOCUdDi=8L);OIPriw
zAvFxKBA~=m!jQ#S##qEu!w3yMhG2%Gm7vBs(=9egHFt{(F?X{Pma>x3+zbv%Sy)ge
zgW?I)+y`M61_lNY28k7e7LM02rZAK;7V*?D<}sx(b~4p46-ksZ<S~^nb~2PObuczF
zb~2VQgXngKcE)z5G-hzR<7j5AWv*ckX3%8utC9s3#i=O@prKh^*zgCu&O)&tWG^Ts
zgEBxdsNYe-(7{;408Y2e&5Xq|9Sk5|2U9b16C)@aLHy5nizO*PKW8O#(RxsLGUgP`
zW?*1g$$X0=wIVsbq_QCO7E@Z@E#}<fbVyi$%)iA{kf;iZF_4EDm;@NBl;Dm+sYns&
zs~}O6rN|Lf65508;f^mU%FK;VEXpjYECM-Olcne=NP;~#wYWGjJ@poA8mIwZbR47w
zoRklPSRmVrCNVHDD1fX74d*g23NZ38axk$m3bBA?K#>oM5I6>f3@Ad115iePqnJ~K
zK`TgFK&xU{Q`l12TNs)dqu5e7QaD=}qS#ZoQn*_fqBv4`z-zlWQ$$kuQv_NVqqtH8
zQ-oR=qPSB)u_Rh#3o84}!LwhfuwDsdJ_cMxgGxHkR0JsF7nSCLhRzk>>Waa&ieEA)
z2w)Bdu|aMImq~V@5`d|OA)cXzIfbE=p-85Nu?F0+u3?C0%HyeF2JygROf@Vu4DrmM
z7_VVY1Bt^r+eN!UNuBi;b54G8(J@dkvlM`87G99M;7bH<v4DnDKzSN8XIyj^6y9e*
z1VjgDp#dZbfTIHx6QCY^W?p7Ve7pfDIs`yIU}R(D0AVIb7r06qTmhl<>-6H|A-a-5
zg&jx}2!q%luY<iU2J$vT4PzDvGuAL>G1V|;F*kz-G8n7Y!0Y|YJn$lz9EG&R<dXcN
zO6YPO(BLF^PAW645;E5Y3VhIjASgkDhHb%)g7@Iy=79<;g~U9_l%=jhVp)D>O0hyl
zVi`z3%+(6Tndy1pv2yVEXijEwNwGp=Zhl@mXlw^O{{ouk0uACSC@5&MpoL`7IZ$LU
z-C|D8DZa&2kcu9r{P7@H#KV(_H7IC7fy2O7r37|2T416o#|Tq+Qt|_ZDPsy_HdB!p
zsOg%;Si_LT)XWsjP{WwQRK`%GQ^H)sfFjDA%~a%6!h$SX!dk=F%-F=30*VXPsxQT*
z1)$X%pxJv^bH7+2sS-S@2%1#4f(I^mlo-+(Q_w|e4T1y}@=9})Qj0*51DZyKdtU)G
zlZ0wUa()h)0m<OO3lfX~+la*xNTaKGTv3z_j>4iSP*!4tSYDI?o=9Q?%N2q14LApZ
z)PUt~@xl8;;O4U?Q_%&Ge%3_L2o-uN;Es<^Pc2C-DJhDNcLt>Z&^#3b8>q1b#Y|Ol
z*ir*R8%EU#YWae5R~#rMFk~?lIe=mo)NRRPXlBf2Es{xLtYs{8NnxsC$YKD=fp7}5
zIJhk=#;^dq@d?y{$zw@jt7S}KuVKhy0Tn*rRKr@skj0k9Dh6sZbNE#W>nNn<mx5+O
z@>0Ojnp#m(#RU^oEh<_ADma;9Vtz5kfJ>+<Rn=nEVg&__#1aKiV_rcuMN>yX0~A+Q
zswp}O$@w`}swtY9?1&t7i#aDXuV@pjl!65QHAw7$Lze^WgyNDS^Z;g$k1qxVZV)JN
zVI`LUBO8+n6AL2~qsad%DXhT@)`SwYphhJqe}aP+)IkJgu4YDP3u7gualDcd9NXxw
z;E0b0E$@ksj{!LYWC{Z#jv^DH?iaJ2q76zO2i3vsu;E}EXw24vVvsR~QG%hCxrVXG
zB!y`KQw>uJa}6`7S5w1S!&JkZ0%oT%FJuIFM41<Y;*F)M)fKd;1yrV?<^WJMK-N@%
z#53~>N=u;aS;#V?+{B`6=tw!F=mRMO^>jdkeBk)cNJUh9;O?bDqC#;&YI0^`jsm3Z
zi0ILQ69+g|_-V3$^G^{dT5qvr<!9#IVg<F?3N%^3VG0`ADauYQg7j%_aey2OirZV<
zU=}ocf-5aB0j{}tLC*CAc><&;4ix&}9LB=N$i>LQ$j8X@pN*+X0ZS4<(TI@{K(PT%
z2%t_!3L~fsQNjqyVW3_mxHrk<SH%yq6FlXSqX1%RG8b(C6$Q*GnMJo)Ky_5neNd7H
zI~PoV-OL^zpORS=AD;noEi|oQPo!XFn#_>Kg`Xy4(L+#{;3?t<nF>nmMS>vvKnCU~
z$Hy040`a)PRTpHzYtdDZ%9|kKE{J#lBA$bYS0DoHCIkU;9k>~!19BNioP&{tnTwl=
zk&B&!pM#5oiHi#?kI^;*1sAw&CWqEGOJzx619iw-7@HZRSivJ9>_woaW1<yosvBN?
zE0kmu<(KC{W?#Wg8l=hBV(3y-@c131S!NBcPKc|xbiomnmycHAfMShsbpu*LL~d0D
zu^5}R`0FUJ-&`TfreJFiLHV(ys1l_r1}!d2(EtrmYJ%3$fM=SNK<%mY)FLHKl*Nup
zj!w=>(0N`31!x|IWDP_dBo-?aq@vmY9@W$+NJVG`IRqlA1j&|G3e~krdY}=B#1f5y
zRM4a=XjLU#T``guTq_DvlR-=0psqyJ69({V!VpqR7$U5M*<%P<6z~$1`ccYHP$vRZ
zYJ+oa0V8PUDupSBp_U2MDk^0tk|<$Zz_gH|mNA{7mKoGSDq(46D)OpfUI4D|KugL&
z>=aPji9Llyf<c5Kg;ksZF3z@qql6PQ1enED!>|y%^|A)k3S*hTSd>=7l*L`cki}EO
zn8M!6RLfGr+sshQTEbVuQp3p2kirBit(zHL7-BEPFx9fvve&SuFiJAia@25S@h=ca
z;YeXx$W+T&!d$~yBG}9{0o29i$P&sDPT?$LEILy-rG~SHwTz+YTH%x$)&(LpoFG?~
zaMo}(GuCo}UCp(CqlPO>w1z8-tA=wSGe|x!poTMrsg!X7W04MuT5g0|h(GewYB;il
zYPoB;vxHN4$`~dv7C9770h`OafCD7D5WEP#hB1Z3f&tVKFP_54FoCf!t#C>T-vY53
z=7pd|IQ)qPEYRgEposScFS!S`;Y$*;LF?@m5RF0bDi6>gRt{+O7^sGUE|LYMi6YP%
zcJMfLQetwp0%!@ELLzwZ37jcFW<ytJ!-s`Y3JUO=kL1Ks&{7wW(Fkixz(cA<iJ8Tz
zDX`Tg3JRbskeHiV0$UFXvH;x3O|3{)04)xM&SNP+G%BQ&f>u$3*SLZD6B^*v@p<_r
zpyAp?kYPx3Upk-xBWMu?cfEoFs2+v-816dIh-zYqLT+Yy2G}U5ZJ=c)V7pQk62TJ^
zh&-X7tB{gfP?Djb0Ub89H8j&y&_ycHazLwViWQ*Y2p)|sE&&B9ICw#E10K@@jj=)Y
z0U)~(6iI2Nd0<Py{eWU?(Ao;W{Jd1~n6W}yX-<v;vU#8uFlfX%CkGT3Afr=Lz<NNd
zTJmx#kxd81Oj=@Q4k!pAtq@RQtfK&`ms5)%Z4r3bKwBsZ(B({^^?K!bkdgotTS4Fz
z%b-=q;JIgAkV!BtAXk9w0NDp_2EZl;LEA4<^z(}pQ2hvsFwlZ)khvfXcY}H{vR{#s
zk6(UCsuehFQxHpTAdAQ$4$jO=&M8evg}DgS0!%H2Ed&Rzi3K?h5ebOq7dR<{LJ6`$
zA6zNwDTHLC7K7G(fMy{P#=yb`yix|X#xXMuzIP&_IJE>+JtQElPEtq*Ep^KTP3mN(
zWrAj|AQ25p8I_=goJfw+Q}72Z0WQykEb*;`_zkp5736wo3WWL*9?_sGp%}JoGdHmk
zlrEBsDhoiXl1lQyi`|hz61=`WGfzVkv`h%Rq6eCFKx1clDXB%!y&Ve1NG(iIyWQ^>
zqXM|8`HL~Gilf?~)=Ht;uvU}t7CWex1ugFe^&&KxZgGNx&@;Cn=N4}~nC+MEoS2-E
zTE$y!P^(vMSgW9`P;FFO#SZ0aGTmYaEr={gEvn+Mfh;Jrt75J;sJ+F=r73=kJu?r~
z_AMz|1ZsN;rl*z^K_-~<^T10-i{^qFTA;C|TWpC11*v%{kXA6LKY5D{6g-I~MWDr*
z;6~jozI4#`lf2ZTv?9>T{#(59@!+fq%E9sRx0s7lOKx$d=9T8Af+lxwaiqnAn&vsh
zx0pdTyMWxlmKG11+W~nUysF|BGibL8sJ<+E1a3awVot3{zQqbII*Pu6oVOgLj~%pr
zCAFyd7E5tzYThlz%v(%pX}6fuigItUrNx8Bl5TN=NXTd+3&;-iZV)>(0-HeXM<38=
zkOT)42O|d~3nLdJ52FO51QQpd03#ct6e9-{A0rPV4<i#J2O|?B7ZV2~4<idB(?1So
zE=Dl>KL;}#NS;ZE38bHcsY(o-ec??NJ*Z`%cJW(~$JoF@SOoSds9jw28ssgWV$dXH
zGPFGmo=5<-Y|)%v1ZtCJgPaZOU2`z9h%qsO#W0$>pyUQ_>VoV+EJBT9P5}?)g9k^e
z^1vg#;PxyyQ^5-nlr}DC^-^AOW-(~J6tsv3C)YgqlA=t|lF8D%6l;azlKg^V1>`}<
z%-r166wvDHoJzlyEZF>x<VUcV!R>p{;Oz;JM?r0N4n`Ixu!~9dCa9TJ^)9QlxI_VE
z#WXmMP#0|^K-PzWLn9AVor5;Kfp%wridV=|!94h~cJP==a7liFjbmPlUOb#@m!P1b
zu8Y{oqN$LXmy!vZRfd$7;F1!Qp+RMRCU_YZD999$LP;Sh72GONNX%0x%>(5qP}a%@
zMG&~Wg6?PotrIN*uVzb1P0fRheL#vEzar552G&po1;<&WP-QIwiC}~(sJ91BJfM+%
z)WidttBL}hM8n#`5XG9p7R;c@UgQQETFJynJxP`D@B)W7tV+`>OU%gxE$mJJRn)Lr
z47SB6IlnX~1ylfM<`xuzmM`Q~DnJV>=mJxe1~tg7APn*dcuog2KorjapL1BrcuNoz
z;Hl7sJt3f#1uLPWVFJi9pvCh@p$1NdpswmOP=JA~U|_6L!nrO7G0Y6gdZ0oDgh6bO
zR=Dd@K*OL6;6W=UzbaXr##t$-78mh@=6<mB&5J<2WYF|tG01EN#wtae=IB8Op8Pbi
zmOJ3SIM_HOpCfW1C}JOhybmpIm^qlik&QdW=%DnhQ<z#9qL{%wYlbM66xI|raH?TX
z;b>uqVoTu+X3*riB_0n>9njTMpv5EpX=%l&B^VP<AkTsW5;S%K8dXXIPgNjCHFHU6
zfhIF#poXcy@D@{n5t7H?QTi6-Cy;Rrj8zIatVcvBSRp7j85kHqY!C*!12lyQ9=l|e
zgiY}ki7+xSK$BMy8z}z3p$R5H)`M2(fhy0E)ZF;^_ejoA#_bHadW`WO_-H#QL`uM8
zsGuGjXgF{slOK3MMw96l3#chqBnom2w!{P)ZTX1g5<CF{GAKSCcm4wnLxBPW<cJzZ
zr09_XSq=)CA_))+92{T*944H_sU?s&|BU1gMO+~QSM8_Cj$WaFGHj6~$PSRViex}6
zutf+0WMvU(hWZW2GEirngOP&?1i_*hX&W?61TGC%F(U8hh+<BOh0W-tFo9-MQ<zg(
z(;#zuNHcq>tZ9tk**!+2**(4#{uYKPt`vb3LGauj_?)OHo>ZPF-V~7((H4d%z7(+(
z@fL<Ce#og$Q3BADo&-~5Qe;~gqJ&a~i{_*XM2VydMv0~hMTzC9qzXidrwT?%qzXkz
zLQiNCNl{2qY+;BJO;JiwZefTLgPx}(m7<oS-og+iof4O#k)qkc7$uXUm7?9k5G9+U
zlcL+g5G9wQm!jXo5G9{tkYd=v5T%e}lw#b%5T%%6l49Dz5T%r2mSWz*5T%@Akz(1x
z5T%l0m15n(5T%-8lVaP#5T%w94?f?BF-jeJzL7=><a{Gd==nxkDG4baDV{BiQQF|s
zjToYIAZHsz>82#6_@@N4Fh=R61f~SFFhuF61gC_wFhm)ogr<an&bvwpPl;$@h%!ov
zOo?h?0G)W1l9Upi5(6H=GX*ztl8c-e7#I?RSs56D!CSFQi&9gd4H)P~3LS-#e9(SL
z(8g{BaHkBkY9u!`F%R6|fo<;s?=1s&oxt@4WS19cYapm;0NRZJ-rWW2!YODZB;=&#
zX+X`_Oh|zDgLOgkRA4or<!Kcll~7gD2C+J@mFm%ku?Yz};6)s$Izf{&;9aLk8ue_T
zCV)Cjb_odzx(c9ef3Uq<;9?bC>7s34(}eU(v5eh;1~<}Ei(uQF!Gm_-mIuhUplTa5
z+^t}%paE3~8qk9l-XM2qC{?B=7Ab-DMXT$p!!?35BV%oF6DvKn2t#{reqKoi1^QDG
zE0r|ifv2FXkXl%pS(ccSnpXmvBF{w(8!Ceq#-u{M1N9B6^A+IE)KEfk7qSG{LP&6e
ze5edbV~_~~_{<}8$ORfu(4}bb(1FCGf-T%Zs6(QLmX?<KhDQ3vhDy+Q16h=knx+8S
zgrrfdqmY(o3o4v75uO97fR28u7K65cs}?IMs474dYowMX=4cdaY9a*`*eE4X3WX+L
zO{8I1h$O_B(FU=&WYocdq>f8o4-!-$r-3lUP^cczhz7)b48zrPGxI?Et<~|UfoRoB
zDa|d=&{Wa^_3)uV1r7w{p<VDG9n6oQkcn0Y1u$qcx;}_7Gy;)erm>-VELtQ*8^nV2
zK(wICLHz<%VT4HjFy|#!f;Af(BBY>t5Pk!x0By*E8;-^QAT{8fL2yMd8^8eok|xqu
zx(X?Yl~xMIhH#T~6~M7*rC?};BnHaWRtlhi0t@<upe!Q+H4x#g5hciSRnSsY&~jDA
zU<S~rb`8Tq##+`C#v0am<{H*uh9b~<Gffuo(8Db@$QIaJ?D6q=spawUw?t8D|M>Wn
ze9$TmO}3)TpzbnzNq#mcrQTuz4d&fqODqPp-fywy=BFg)++r(AEy+*HLT~xWF)}bH
zGQpO9foI;h7}*%BAnWs?Ia3enfMk%5pp8BT5F6Ck1GoB;7(vVAvKWfWK#h4&R|B*t
zCWQgCL?#nNGJ}`Nuz(lHu!0w6F%+4lgGQuTYZyz|nwg3MK%$T}pEV5e?0IrEAQ_Hk
zrlPbGHqeR(uqa0jV>)R04SNY^Gss-78m1Hm@JM-F4QTW|u7;&}3V8OMxrWJxp@y}F
zsf4?ksc2aVPYn}jAz=-uear|pn>U4_nX!bgge{G^nW^Xk*nZ}8hBRi-IC^m$SPfq@
zQ_%yEowbZL%o7-kw7{bL;E{fg5`hx_8pbU4X3&9GOf?K38}q~<qM-Gx$l@S-YnUV%
z;u-TyssunY8<L>qU`#fkgF=;97)k_7gi3_dm?tn+#z2-WgF0;>6CuYzf?D*NEPig_
z1}u15R#T)1v@rRWFj}er$3A*eDM&0z%`3SjiKaF&Ik_|!R6`YGBra(35kb=dNlh%^
zgeHb22TOo_@u0Pg;3G~#K<n37KsyX>VNnedFPaG&#{w;11rMg(;sUMX0?jVxrGpzQ
z;0EX|4)4@T@QA`KPLPohCYNVkN@@j|t;q)N;1q#Yr4=cHTDVFeLK#GW$MMkGx}Y|(
z7AW0=+CvQBy+V-XQXmpEY6TkY;$q|hje#)<fJebVqg!l@DvY4~0UF;DV-jQJVPaww
zU=(4j5(PIb5cvg^F|qUtKqEKc3<FvTSHe)k2%4HsV`^q9lBi+GVy*#qnm`es#Ztyt
zWKzSB#R?Jw^&LP7Dwv@JGA9e_)_`R|r+I?9HsIvJ>Q^)!6qukMHcGz;)H?%N4PJE(
z>X3jptnq;6gHjkI86X?fRx(1;7AU0P>o3dD3k=Y{vj`^Wn%*iMG;hPZWr%f$h|O!7
z?BH?@9O1WEi*quQQ;W1g5u^?x^gskCHn4Svz}=TXP<(-k90o={MlL2UMj@su30w|H
z2Kg6OR)M-JAU-(gdq68Rm}{6y7@C=i3_$B^7BJN?mM}LnEM%%-N@o-Y1ukO^qYXn1
z6DZ(oS@K+Jm}?kISV~yIQRN59%UNs?6}2pRYN%$Efb}(_nN-UHTC7~c-po|gQNjV5
zjjUmb=LAJt5vU`m$pud5Mc`2Q2Z}^3P<Vjzh8c(j4k%FY++r=yE=o-+Qe$Lb&}0Rt
z`df_IMW!G{pp<@#xwte5E!IFi>|)SC7oZ+?6et)$iGYETi&2J=3lx})Y)nevM2-=l
zaBV0(Tu>}<z?Qu1f>v$tw7d>9Nt?w2E^figlWajdH5kD=H9WvmuM9<2puq}rhFZ|l
z3`S6K2s%5hma&8tRM;<IuVGrq*v9}_i3>W1kP#FqoC~->>%n8~Vwh@KYFTTTT^M2w
zYS~J-YgoZkv`R5dwd^rWwH&paB|J48HJmk^HEh`|5)92uHLNx4HVlO=g%yQ4c^owi
zS)4VDw%`%5mCTSq0q`V*CNCn17J<Y4HYhH@fe(t1Tda^xI_%&f%+zAgLTvC7dvL_v
zVg((?P+ar}qzBZS*5m@m4|vey7He*0PHG-V2WZPs3b>TI#hss=Tv}9=nwOkfe2X!w
z$byl9;TCHdXdC}6j)MH+OwigLEU^jN!UY~LNe9IyXr(ncQ!qjX;W-%jn1mQPK$ua4
zQ4TYkz_p{qDyWzMVQ@A9MKQP}Vkm<R<Y+R2y$M}62X-sE(|ADpxARI8GxLh$<7+@}
z0~yG`SS5*;Q9;Ay5LGB86{zR}>3}-{GJ*pt;vmbVnTilGf@S0e)L6<%&5Mt(N3t8e
zF#}eBVJ*mNxV4}W8y*H8n9o--LP{!ZHgd$rgBEbd$2TEaiC!N-RAAVN&#Nn$Zn1!l
z*1>BtNI`sj8y=e>DllvY6^UTqf=U8NAg3^-Fr+ZHGD|Xmf*Ukg2Chv&C-q@n4aEam
zItNbuDe>{0NKQbHYuGlF_;?Iwz}v^5y+BZBfHriALCRFnia2m#!U%E_sI=5%^1H<W
z@>6zdWw9p9E%uDWV$e7MIAs<EfJ#9h5P>bGIOAa&dqA!QwO|<-c^J816IAf(8>S4a
zb3sln1}%?nXGmjAVN79a;pkuhEi(hv#h^VQekj^NQ4G>z4BAct(pJL|%U8?T!2qh*
z(KbVXa}%`gg=8;;H^4)5pglB`;kB<eYMuhQ8eDP|Bh|j3mRLnWk=;thBG5uhq=*C?
z4Kno>H#l4%S|@=*2IOW2M)bM>VLplnLHP#cK@cV}TtIa)I9x#8o*IT&AyA715;AE_
z*uthL7&UG|&IfM^nFbFOEzCdxm&#beq$mW{G(?DSfkOnWZz@uNh~qFDYj}Wj7ieu0
zC|NIHTnNrpnv7Lp@HG!PIp8^a*!dp{pd_uJffzW0pNObnq*tK>KAa7-+YdB>oL>a$
z8$%bO80%GN>S;0+fodp776AJM)Q|(GDDWnvTPz^s*T8+lR3(Vw8;~qX{)oWo4@gR)
z)F-z<hZ_|^%tA`GU|)ga{T3TUZUd5+Ap6x}`4}QklBd#edMZ1$QWs(%vd2KnnLyj>
zz=uRZql5U!y2S~~Q{ZHV&4)$yj0_B0kh}-kq7U;PSRaP(KzSFO^gtCjDCuQ^%T7(k
zstLiFdC95ZRHmVc7=%M4DbU)W%wpIUj?7{O_*#@ag`~=YMDPiF;E@i{NR@(u0%#=x
zWXEbwettG+#v6QCsX}T6cxpTue9|B2a8B6HDae3KF*w;5gOcn4P*Vxq=*5;~L4`Xg
zUG9K~0W;djL`GsUNC8SHfEuQtlEoiX;`V`B`;5h0DU9iiwTv}Pkb*i^3%ZGrIfW@3
z)C*utVU}d5VM$}EWh@jbVN7AEVHRTm?XoBoDgmuSWR_$oVQywBPAOpljYXueW-}G1
z)IfAGlra?5LD;pdH4HVZk_@$MAljCph7G*810=#;!ye24nH)|$$cnVuE(pAZ9K5Cp
z9x0%xRY)v>EY42LOa-0Dl#*J3ST3fJkdTvDT#}HW37OyqMF{A0gZ!eBVuhsqk_?an
z(8*_zqXQEXKwa&G1cl<%+{C<+%w$MhB_tH&7iefEB!IRa!y^_H(Wxn*6JcQIuYiv6
zNrWr_0F8pfgmoaBg>!O1+vDIC!p%Y01zL|*kYAtx-Y8y-Si=q)MF1_RgH9npq(N>`
zfVcr}RH8y&ex5FLI2wK|jDiOEd_&MGhMY>!Qg-mspql8;f_NQn78Yk^fKJFODoQOb
z0PRN4OIHAAbcj2#Bwx5uprMvxJq1UF;?(5)yc7l4QmP{Gsy3)8u+RdnjDjzU(op~}
zz(@p@8*t+wv7`r!6E3&}mKh09go6gVAqNn|gZGnbKmrhLz#F6zA^|qp05J^!k^zqd
zYrszj(Ey!w0a=ucwglNg!O+N9!Pv-9NmEln88Vn^02&lFG%^NJ#zx5F!i0=YOi2OP
zK9HjfG?0BkguN(M!b1sUXHH^LY7T6g267Guntu~ZN)&7r!0I%Vd>oxzeZcc7SVI8C
zXh=vEB$kw*PDD65Iw67vI@k^!W(T<lgq6XkYl7nyRBb0hW<#K>LP7Iw5dVXVMR;pK
zBQL)MbR;KeFAnIaB(%ht2|BY0zT608i-NKO#2m=^uiznl@azsKi$P0X)WASWK;V!d
zDgnU)4JB|u_Cr%WB(0&yf&&eEl!NU>brqQb4c3M-rvY+Qw7R3C6DWP6q#2M54C^X@
z-C(8Q=;(yVav)j!dck9Dx7eY19z1qdr3;DU^nB1BdxcWa7I?^t`E1C!L5QMDUA0&p
zJmlb~$qKILiwr@HQP2nucz_Jt&DG?9j31l_jqkH%mnRmb7Z-ts2*ATVw^+fmrbXa2
zfILulfJ-h&s}IpqVlK!p*bAydL9-AHsw|9bi~^uz1DN<ggFpY7n7IBiF@sk7u`#kR
zaWGa1fb%A-ol%fqfP3AE1h{^!0o8#5pzY0|RUb7>!3-&&b>&Qn(M%{c9q4#sNbL_#
z=HP81prv1+wWy#)t$Cmp3ivF&Owe%{sgRSv^B@z>plB&BP0j#k6;OL66?7yA#8`v@
z2?@~92m=kIBqV_9uY?59^5+Eb`YI&DFqCE%BWhiw1+KxFxtXAY*Guvhpv820Y6-aN
zM5GxU#Wbwif}W9$I(ZE85YhxPR4wH*t{`(Ed7ii#RFHZY2InN`WS}0%o6zZNXt|Fz
z%?HwjsUsu5v<P&TGH7)@Xqjy$s1*aRI@D2w5%Yd{%!1WApjd<#F3^J)psSmhvr{W?
z!7>6k>d`Vn5ol!f3n(Li`~E_pMJ{NGJsoY46{s-@-`p1jO6&|-3=6=gQ7mKvk4iEv
zU<Qv$nn0SAB`h^8@X<(C$fl7J)*7}N_8RsY#%vbQIA;w@4XX`9p+=zuG@D2wXA{r7
z;#5#G4s=#OXwNrjl0LCS0km8gG#Ut6KABnpsz*Qx9(xlCktR{nEl9CmCfIo5k}f1(
zvDS^Kl^}7g19-fF;#nEoYQ(GyA?`ygEkX7;STwCDKd%H-r-A$rZ8}1dI%Gj9$Z!w_
z)ou{OKufLjG;;Ej^FXUxKqrvmZX-c-Xc*{#?9IbgGhq)7wCW9F4A^4A4H^R-1$EqQ
zDbPAa&<OM`Hi)5+p)OG05NV_tT2p}bQG(S4mlT0Vn2Vf1)e5-IZ~?JgK?JyF0282&
zbP=fc#LdjWPz*}!4E&(6V-dzG)V?&tYK-Ax(4Y^vw+UKP4H`5BWew0CCTPM2Enb7i
zx?@U;0_c$ToK)DQ381!5Dr9pqa+L#Vy5y(9lz~o_2gN7|<0xbYBBg>33Itt30!oLV
zlXpOa0igRrK-WHidTb@B>8VA~GyW4(Qb4_>l6-IyPR)a#$_erlsN(>-@*_1bCBC>c
zmtZptvK>JKq%=3N0JP``p01G=uYgR(7c6Kg7GfyKe!>YBBem)%n3$L#mWB9fGC_u|
zzk`<dLsu4qMzhfmw=4oFPynSp(6|KyFIuXDxCwWvQ-e=EH8T~7fsX_N?{~}N0Zpea
zU;!QG#RzMQa3UA7;Is%n1r#z$0WE03%g?ElA|X8uw9*3FC&B0-fOg|xmW2@igOdz&
z5FJ+TftyXKDWEkypp!2_@vi_nQBMJ6NKR&6N>P3;{On;+N&u%Zkc#+%M3_9mgqB)S
zlA4#I0ku0tBf2Eo%1YNT7Syd!C;`_&po0{PW6_cw$U<m$KwVuAv|}7*6}&J2DS@O;
zY`p_ChoYs(oZ{@1EQR8fob0SLg`Di-6hy-UECrDPNu(5K=cHw2=cE*8rDPZ9AX*xr
zW;eL84W3iwh>y<%-_8O~wYS(H{)SF;-C_p~#}ua)qPHf}85tP#L1`D<n&1O17eGtD
z5OYA~D{Ly70XAF?E;S+J-dPMOj46z*Otzp&PVin=SemUehliIl=n5b3HWGMJ1r4h}
zD?V_0xEL`O<fq9D_6oSJxW$?b(u{S8F_V#j!3pFC(1;lW3lC!z>L4RnCq@PYRTN+k
zfTnG#xF8LG=(&3gm2!{;ERo=hX8@jMEjkS<2pEe%$JD@<f`gZ7fNLQz0j`Qb8{R!Z
z&H>rL0NP)~$b&Hvfpo$KxYU4#EvPO6@xcxQO>5PFr)5BAE7UNWgZ2|M!H<Nv#gd#~
zPzhTW&k8<o2HcTCi(}AyA~<3AgB%5pXGTy*32hh>dbbZsIDr&{0u|(}V(_8^#w>=S
zEYM+hSxlg_r`j1|^GBVaLv|QI?Z{dt@T?N(L_&@lCeVx$=qxH1hFBfwoHuBIk;R6g
zgr$Zxg;kQFgteKe$fkr1yr2Lq63<>}Q^UZ*06wsX$((_SAs%!T1qbM4!z>O^)eJr>
zjm-}uRf56}6bZ$UuuEagW+>w6U<hWYVd!80otyw(sQ?ZjO~zY{iJFYJ*z&>K62M~M
zS%#uH3=9n6%&_$#>d3V^X!ig(ERm*SpeOX9xCInwoD2*MV7HjSj#mZ+03#?aT^M5J
zKxb-{fDdGnWat3VjG#%&W~MZziOhuppyQTTGJ$*K;4Zc%BY1JeN*3^Ob>I&4E!Hwn
zV;J0z)?~cJnV6D-;T6zQmq<{wgB--h$oIcWlc0Api%USQ0z0tfnq1)Q2ky#4awE9W
z1}}Ds%t4JY&_a$P&=QziY^4RDt{`kJQ!Z#N02erEf(xKqd|)<cI1|hVdj#wQaQJI7
z6_tR@1MQ%P#6=n-149VN1CaFrpo2Ad7`Yg^7@7XFG4X%~02l?B1Q_|SEMEf06H0Oh
zr4CS12Inr6dRGd(q=TtQ3RM4sW^6&r20-ZrG+zr&Gn&ju%PMk^c7uSt2zES#0L3`y
zNUI{S^(i2ygK`lAqYx7ZGsYS#h$@t%11elWu?2P{XlMd-yd-EUxtS3>6~ffan8pO#
zX~dzSTCAg>TCAzbTqF$&IZz`T5@T2<BZ@$qCvree0)+$vW|)E28e^H^hEKGE4%h%q
z7cT&xbJ+qe>p>YDbg3oiyn<i`O*X$@jM2ZCbQDlL1+ow1De!@W8sIKytU@iwLy#pk
z5}+B1X2v|W5@yic1lqhQbTuhtEgg879mub+NoFkDalrGb1vs-X`1l>991NRa{>2!p
z$pqe~3Q6kNf)KPvD<3Hc(HCZb%?2-SL`ixe&%=Wev^g~$RG2elfo|5esb#KVDpIIn
zEK;apf^|Mhm};0o(=|mFpksCxuq<Q%75{}?AQdI7HO!Ek2|;{lg`mj>aWtqk3Q4Nq
zW&v+}VliaRI%p{^_>4{1kvGi6sRg%~^Gi#LQb9=vT!VoLP#P|(1Brn=3hEXyfLB&=
zfO8%n=&U}-kuk90H55BgA|8~QL6Hwm%^;IN$p@Tp7(fXJwALW80=ZEOo4f>dNWdLq
z*cJ-#+_3`WtYmoS3fzPQkGz4~aG;ytazF>FmBH_ogDk@&ruT)vtqW@F!7!x3qF}24
zZuWs)2?=5irQ)2F>@0<xVh{;tBdvM|X;)TAElbT)D9Ok#P0xTfia{5kDS+FNps5sS
zb66KNB?M}t=7Q&fKo<!nmz09;6$3So;rC4<m*((x7RVy7c^aT&fS{vbny}3%&>=7z
z@JT%i>hNPM^pMR`2i+|P_5f($8SEbr10oWO7@GlE1(_OvEVk9q1oelZcLIVga{xOU
z9A7BTg9Kqbr~*^4g+{R+%m@^f7#;y@g8K%-gUsf@yaY0pfCoVC24R%M3QDM;ObT9O
z3L0kyuQ8QEDyO7sz-`++rW!`bic@f*533tM8LkMlXcu;>EOSvR#zCr}D!B(o(F6$q
zq>>5b6G&z33CfPx3M7zywV-?oay<h-TI(HRB8D$P#Sy3`EH(r8K8rwoO~zWrJT}m2
zezlC?1{`=<P$xqPGnfZy&M`KFvn^;PlO}888qiHIpil&1<ctfNR7Bg8g_3>2^?!a|
zVo@d1@HCE55$JF-Y(i|X3_YuZ_wDF|HcqHx8(~Awc?CtVd`N8m(}-3_-Lj&ipbp->
z0=6?&N1<9hC9zW7N+DVUGMufWV4@kTqo5Aj(g76)ZFw;O3xfB4KtzoV)pZn%G-GSg
zdhpOZ35p!#JPEo0LW6)8<3XChc@pkVh!C1*LCVza;4X)`8|GxFhhc72H#StSMK5cR
z%TKi3SJ0{HV(@*BkOCC4*H1?QbY~;@)Kt*Dvfz1Z@WDAHpj#9{m*0Z5pp-k%3q`Yv
z^AYEdgVH&qJOT-WCrXRaq7{BZgp~q(mA@7EsBy?_r-E0ozn?;JYEfolPG%K+`#;EJ
z5XND;UScsM8emfh)zE!wRtieShM-9b&=xE!1tn100C7QSKncV*QmTb}3#AwU)y$wG
z094sSivj3K^m>p+Ft{-cKF|+b0Dy~w8gTXxX2@d!^}s-lV@+n%UKpqp0+lXcV?n(z
za2d)2SuNO%Txx=g&LR^~Q=0J>TS>lWNh)+`4WzdSR8E2l81Tv4Rp!W*6Erjs<s?Ki
zf{(OdAF>e%(sYal^+wnrLAjE#Xc=hX4(PNHh)ck>HZw9XEC-dQpruEk)#af16%nQ?
zWg_fH30_dpg2Dm3HW1Wqu3?B3i(#q-_5VOCC&A5lw017o9V?j;T|7w72+fJ01(X}$
z6^I&Mhr!P<*JQcH5)c`044J2m0#zoupw;)#aZT{>P<&b**abyk3&FwB!pOkT2M-Pr
z7SI{VOgx+zl?*6xqIe&a3_w8uZufx>lmz!(7@HZvtK}K8m_aStX2u%Ec+in&tTl}B
ztTl{TYzsh#fwDn*_*on^jPV>bph;N9DtCAyhSf8mOJ2(rKtmv)@x(;bGbx}AQ`oJt
zh(RSyPDoM!_me;&0O>4&JGJm$Y*8sFd_ad&!^U|)^V5*9K{Sv-oxn|?umLTQWMBd9
zwt<|ginb~d<U}`=U3H*s{oJsv2cV_CDU7wO=?t}OB@Cbq=iufsxSauNA~!SEvez)D
zu!w_BY-1_5NMWsIPGPO(NMWsIO<}9$tYJ)HD`hP5s$s0<gp3&%h1D=*G1qd|a2BW4
zFcl?%4n9m_ujQ;^t6{BSPT{EGOyNvtH3!)TI+Yi)@nB61Q!Q65cL`e!H+YA~gBq?H
z_A-W|12t?lpflUpYq%sCYMAmjf$d|c;izF*$dV2klVZ!0gQ!Vit6|E&gehOxl)_fa
z12ykU4cMewo*JGBjKv(_9d9g!O?fOS?6o{4oF!Z}+@Mn~Yk9%0<w)VE;Ys1F;Z5NJ
z(dnEZR~I&c<(N~r5I#v^UBF$#20jUnyQ&?YSTtNf_a1`|YDv*lfTbL)U5f}`A3X)o
zMJ}N8h9T!YgDxQkU0n|DT7a*w1vST@C#8XJKf}Hz5N><X7xe2tKqUeQqx6HJr2^<;
z03py&8E8Kf=$Hj?>A+VAzGQMG6L=U1GFe;%8k#{*j-X=UFeo{K%;#d{_+O=pRy2UT
zh`2Ta-sxphPyqK={cf>%hPe9vVzl|iX!ncBMqiVs2rY+zvIJzp4xE4Bqd>P<6N@8!
zeTqP*?Ss3R;7+tAA9(4<Ew+^W<dVenTYTVVA*h%y23?Z_n&V3W?dao#97I);nsSRN
zFQ=#hR7!Ip)ZXIHORXsJ0Uag>+ANn>a*G{w5>!ZHdJ(wm-w0CAR+L%{x|4{zA~(k=
zKcy0MDGYiDO<-hT*b53F(D7FcEG&#Hj1o*7%pjVDk%fr`bmlk{8zUPNScHj%Nr*{^
z5wv9vG~&d>$n=+s71RR;v)DkYL1&bMmYc9Z50hg1$H5|mKKcv}8I-XA(0C9ilE7sn
z=)MTZq$79+9<->F36uz27-D6h<E4x>ETs%ZVl_-m42%pQ9L!KCR>%daePJ6)z{^iT
zg&1t$%@S0Cfu~H1K`ijrD)4#I;PMMhfC_lfNEK+^YiYqRP{2ScJt0QWz?uN&@DM~L
zMmZ1nO9OadCyN2xod6HIW-%6lS`&<*qc3Y1i!?ypC(wpr$l{tjKhVYq&=%8drlJZE
z8?@sJyqvWHyo-t<i)8^jXw`W$c$q3_|6mGB8AB05mIERSF%LXp%bF;Qt6KtT;6fJf
zfV$R@8%Dv4y^zju1m7bKx<(g#I#e;}{*lBSc%DwlOiN1zZA3-VQ4Bpd5j+|JTJs8;
zz$z-qOfCg2w}CBsph8!txHu1dQ=o#a0{FTxjUuI(6cE&f6CeiKm_tT>X>n>i<Y;u5
zcF;oGqSWGI4RvL8(3uYKHItwrl!A;z%x)IwP_cN>MIE3sBET2CX<!(vsiA}{hUN}X
z`xb_46d*>xe59$NR9u`#ga&ALP*X!GF+EiYZO#tt#>~95d<9zt#H1xy6y$QO{T&5c
z&?1hac#t;K1tCU83WkP;x<*F2#>U3R3d%-ChE8ZMOapCVC`ru)O(Q~57wSn3An!t&
z^q}Ex&_X28PGt>E9R+nOb<n_0YHqYaERwsxiZNCICZ?w<SSc7G_U(hrEiTSeutIhr
zJdJ{6k>dfZ*U$+r?+30+K$QsS@?ua&0K5=Tld}k1z=PUB7<;K9c^@(l04i;6v4BeD
zB2eq4C=yh}gd;U4nF|sz&q_~+oB+wl!oW}r9?h2oZBz!`^uWT%#RS@p%=4d#N#-9D
zvk(*7+!RzR*u^L<DNxf3bRIRhC@o_IU1JG4i=dXRhPg<khIIjWdorXu)657tPdASX
zB%T5}Ll?B)KBopeZB=xsgavY>RSm-eR#0IKZilefu)8qCRzS97*02`kfOLae8jK7e
zRto4O0Ja(y5r!I$G-fgIiM=IkHJso!)PWk#q75KbHJqTvENCFNh9!kvoFRpymj%?w
zEj$O3Enx(mr3>bVf%)LGbs_w`StVR4oS@6SAYHF!(22S^H4L?!CEOrgP`4qq+(75&
zf=o%_0=2}zE`zc_Hj6OSaAUe9jSb@R!cX{gmN0_aW(c(@Obd8wSRrk$L^tF?T%_B7
zAx9sAOIuLu2{cxlUs?hl`2_8s1Yg#gp9W8wINI@g3XaL3gK$Ax3>5Og7ds~AC?q6+
zR*&YDBqSgfr4}O=S%OdH179Ky83a~<-4LCdl$w$P-jJXG>P3JrRZht)F33r&1ob7r
zQ&gZMTN0^IWP@hIsC^U-D1Spr8(a$`35`xcbb|*lG&BhoKllft;Bg0X7WCK=&@cp=
zICxM8<v<dMdeBG(%9$kKRx`Loiqg^m^(H|W+;m3mP=ih(XlATo!q{-9$yhWW)X8rH
z6;R+t510V8e85vg?ko(Do4u-3P}<6%<7SXX6JSl{DlX9761obi#a0SM-5@hTw@+xY
z6io&-L0Ld265ry<gq*hv9+$qw77sq?6vZQ;t}&>|1ojAMg0F@lRsb=^3~u!^Avf;e
z&1~4PGE*7GnFgTNe=yuPf?$V6tER+Sfmy1>n!Mm;N|44mXvnw-G8h86WeqYa0JrBB
z3n&1<6N<N(6Z0w|O@7Gvt>7j-*uzB&Kq0UYL@WXk;C4HcpAW<^aN85y>;yN`7lTxQ
z10PI)V_+$$#sJj@ppzsRM8U0Y&>^i%pgKVed?YIuqXhUs7da*YCLu-<Mi$6LO^j@e
zOyGqT5Sr~T%Wp0&P-`42`kRX#trHIN5K1h7k`gEuz&or!2V$0hZz}<9a!hBeVO+!*
z#E{8Q!?c94j}f+#B~cl<VHr@AT2fM}3$CzJi@*gOcqRz8D!dpn;teYFbQDTKYX(7u
z9z0Vd6o7Rq*kqKH6ck(O>!;)=7wbW8>(t9HO4m2m&&f<GN-V0>hp5y8-Cb&z5U-G%
zpHiBWiWt&>my9WpTPPEA6bhib?h|uB%f^uw?t>i#>$Rrk7oj^x4`LUIu2P2Rf@%i2
zk%)p5)b)c6>O)qP;cR;5mFB`!Vzx^`2WTtUDnRccMjNOuNi70t1)njkPy;%fTmjbd
zRM${f&{hEJ)>cs0L>t5hi`&@PDnPVqLz}Cx+lDnjrw`<2mZYYDW>qyn)*zp`1uEGf
zMXZ7?*b3B!Wm;aMLZVKRjz(Hul0vdhijI+ifu@e3fdN|U5@G~2ST)KsQ%W*yO$>-A
zuG8`o)pg);3v!J@v^s{6f_f6VDurlu4bVJaT3(X6jzYA0GKiA`B8&_S)IpOAn(DD=
zCM&2Lg5*$EPTpdJBnj|r*h<LS_9D<0kfK;D1;GkN28Jw9K>#Wm86?q07a=C0WL{8{
z6*N%?ZuaRxd!3*)5}->KK!abP1C@&8APu_$g%r?21@KT;8cP~%0Tpb%9MqUC0*&Q?
zk0SxEVu3V+u}rqz;sM{NR9uo+k{Tc1268fJEDtn0&H*l+SpG8o$2cb<J+%a?17#Qh
zRQkX@0lQZVbfQu`_%1C;h8WOQY>c&_;Q)qsCg>Sd;Gt8{od=++UcugUDPaYj3su7q
z&z8pq@@hOAxc0CH6|d}&MFC(>f*bdsRXULIP58<k*m?j~uq%t^fhsee%sfZ<!AfWY
zDWFg&hWn`(5ei(4B8;GRJO?8W6GkW?bYMg!C?vp937Rhe4TgZC5;PMDipn$=*a8O@
zh+n|o&;TVPO%Q=Cn)txcl$Q$LZ4@6r9pprC+JfDS1RWpNLsf^{VW4WdgaNef4b&+p
zVS=PAP?rMXxEG+72KX>_@FsRpe+cVxMbPCpvyfbbzJdgN?+(gtCD7&#5C(@)5%_{p
z&=I_~%ry+@paW)DYQT2{xiEl_m0_)AD`Bi*D*+wJWLE=9_ROI1(iG-iCUb^bmO=@T
zSPfe`=mat58n$M}6qa6Qs0>pIYbj$<UJXMHOFARyt|!oaA~m2}+SsZd!wVFT)SQCU
zBFH^B(Dr>vK4{rRaY<2Wa)|=kv>fPeIfX><44aMu_}YLX@LhPYBceg&6KJ?k7rgOH
zp(r&c5wuAJTvtJgK**3yF?d^TVjiLcpbpZej%fU6B6d%Jw_)iZ+V{xqJILh$NvR4&
z;7zWnh=uGJDFC#F6TBP%bY^lD4`>#nnUN86;F$;uLkVN00_r-^5~d<E&^Q+Cpe4}h
zD_}lbGZTmn%9tye{M<Cz!9C|&obc(wqIOVX1~<V#P1akiNtGq3#YOrc(N+)vZa0Am
zP~+(qcV;p8fCtbF;u275f)qqd;GswkCKg5krYh9KH9*k-o|HwjY>~`Z$q3$Sp~(cM
zz~wgR(k#%JB4jlYsH=U86K;qmJNU@HBJlDz@G{s<AXkDXN)T;7uzSG-$k9bx7#SGm
zf*cDHVqoXs=3o?H<YE+Ik^-;fgC4RE%bW<iSp57#LNpmchwX!Jp#&Ww2V#V1vVc1Z
zAtB(Q0gwta^rM48=kOPS&Ip8f19WN{_$aO-E0BBLK!iJp@Bk5Bpt6rUK0Yr$uPU`D
zKR&+57bNTtB7#6fD2NCH5#aa&XL9iH2RNX>XSYOvWWh6RpeA-v0*DLRv<2Ry0%?VV
zR$Ui?mMs^777G{Ufs}w&Iu=!eSfEvUki)ydYp}qrb<ji{q?Q7WVi(N;shbZXK#k}k
zPz729I>)$ZEl6w~hyWEcMWE}J!J&>+goDB!vbYkoUgaC;wB#HH1_lmB7A-DL5p@nu
z9$pSn4rUH!4ki{RFwF)cSr}QES(sTEnLs2n3o{1`7_xGhbBS|^a`1BqbFg!;aj<d-
zaBzUsb8&MBa;R`{bJ=pRb7*ima>#J7b8vxVm>7#dHltLApyoJeTpV1)f$~}nV=Yq(
zBWM*cGeb5*kqqcavS!e7UXwf)Mut2Q&;e#COcD&BE4Q<mK$p{j7Wsl!$E7fX^etqT
z0AEFy2s#5BHuD2Hr>X>W31De%9{Bn=@C`SR@c|u$<b2TGs(I-Od8y@~Yh1uZ5Qw2r
zoLZ0wJ`E7EKs_WQ6?*?U<Z39;#(2m8tAZh<?Td6TODgzQZSaO^(C|l6D(Egy(7+*N
zr$$8qXc2r#ViI`u7ie+{aw84IQJ_LMDK#y>C{>}jB(bOjWCBPHsILKH7Zl|urxq9M
zDJTS|f;UTGKPDKYJQcD?EdktD0bSGrG8;7PS(FPda24|N;Ese?UJNSKK__8>Y)VM5
z32}4+oktAa4^&*5o}LOCJOP;lsRzJ5%1z7!AD^X=2+|I_VxlZFwH!3M0&_fk;|F*P
zEZAbO`(eZ7kV|;Lfe#8FXgI@qHlT}sN-{D*E9p`pdSUxWz#SuSaR3?R1kJ%|LXO<J
z#afh>nU|u;48B_P7E5tSQ9Ag_Vx-&wE~h{fM7u%d6sTpwz|F!4zNHf-!Gf9-@YWkB
zOM&WO(Bj4#hK0<a+b%(uFDL$FWMDu~d|)p@6AS2?dh${r=pG(u5(FCvT3rIU{1lo1
z6+kIaK^N5N1nrvvUF;4HC{R?Ao&*($PJ^fu@$hr1krN;&y}%Qp0{JNrYz{mXLJxf*
zI|+hK13MG6Z4#U#C`yA0kbx{vUj>{JH5qTQf(sZ;CUE*I+72qFK}iRa{J<#>bSdmf
zP|5?PF9xn65FaJofl?$q-9ZY<1)#k*OrUfJx^Hd)Be?hj^%_7Y!>|?^fsQEzrAWxV
zouJcPKrK6Qh7=ai&2YgC&|7%n=LUgtC^${!gASsu02P<u{0vGtIr+&H6q}%y9$Kh?
zw%Kh1)w(R;tjU51np<q3<6)eGZn1%88k~b5p#%;ua8QBn%DoB-D)6i&Gw4Pi4n_ec
z@C`>O&1X>E0&hNBfEPTbFqSZaI!)pXDNN#^c0D7gEuX>+T83W3(9Bc<x&fO3v>8K;
zL7V~9;sdqZK)0#0`6iYmXDC#0fadu?p;5)Ip_-xtx>A<q7Ats62QtV8iaBtxp~-xU
zBQp<Dpn`pOiv@JC6`FT$NyI}p{0D=Id6(3r(sanlBKJXl1Sbc^qWz2v3@8&Iprio8
z;Cd6Zlc|IO>^Ekxe?Wd?s$l``$^r4={$Td2;sE<2HASI{1#}RKCQH#CP;vyXt_L+h
z!7V^d)}p<jxZwa-JvsTwx7bqiQa~4g?*j?5l;mfluW!921@}j3GN@)k^2sA4pBx7H
z1eBPeJD<S!-h=pHpMW}o$UcF)oXM|B5Z-21fZS4NrOAYFye13S$>4x40=cq?3FI$u
zvH=sIv~x=a=190%NX~qU<jf-=XTqEaqCwdigxx_WGlAR-o^)oaa#wfB*9Berotc-e
zu8;zXKIq{n;C+ptrHP>VR)|bGC@VoPX+yoxPY<%fLz59QS^{=4m;gDu2-Np`0e2k}
zm|rvvw8#XUK0xkcU|;~Hbx^+rl<tc`SC4ftm4FVn5NT(E?bZrrNMTNA>|{=1NoVY2
zEMZJxNMQvP1}SXWtVM1qA}OG|TtF=_(G<=Ut`^2lhCH4UrYz=KrV^$smQIEg?po#=
zrWDo`o?gZjUP*>pmKqkw@lz>$k_<J>;tXj_oviH)?TqbA?ab{g?W}2R;G6F`YFSeR
zYuTzKN?1FXQiQ;ya5GaDTQhSlTR20W6bnNMd*u;Gud0Nj19adu8|3(CP$xE?4Rpk~
zrkEc_1_uQID2%`xz&jW~nH$<Qhh(&a;LUrtSU>}N5D}1S@Ln%gR@f|nY<x*kW^R09
zQD#XcqL*X?-QfjpRJeh|Ta&413IhYfOHkHB=`(`D9E8DrMp#*s%~Zsb!j#99!d%N(
z0=|Zxo1umQQ~*mbq_Flff{sxHZ3|0bNMQrTLON*88#`$KBgm4XW1s{KN^>v&{{R2~
z<-h;`|AQ-(m5jGoA=kWtl7J@jExzK);*!+dc+i2CnfZCQI6+rTrGoC7y2T5+hAuI=
zBp!TYq9$|EDUhL{eO9-4!MDAEHcjUy7F9yR29e}I_eycIGB6Z_TIUQ*0*q3ORZ3Wc
z3B?ACIt!Flz<~lOq(FClgZ5nYGJ!qLBni4>nmL65a-TFf09gErPJ$c>KEV_0L#CoL
zpkjv$W>ZO$Cd)0Rk|eNaZn1&=QCxHmqzUW+Fd+;YmO0PJz#stk1tT9L2V<2yUSE_X
zy#)Cf$qAsj9+X>TK=BN^>P;L}6oB$sl~M;&4MPVr=*Z<1@O9^X47H3YOdX6Vj5Z84
zjPTv1Cm`t?BreHNWYffumsaHgI!u2d11J~OGJz5>=oXq@CJ;XbT2*&|j%>?lVhCrb
zVyj~cXDD36!cf9o*#t2ylA&;s0Yjb)L@rMVEH@7(m&atlU;uSn2TL|%(IJpKSwa0L
zHgg7M1{;P*hC+rWFloS02;T9k$qqSJI0U>r0G#k4;Q<N?O%}*;Kj5neIZ`W<!7C_k
zae@{&K+ZE~hLmC8A%P2^Wxi}hpm?~&1-?$*5tPY_j)Ec!looHX=O$Kw4hOm=RFD`C
zx(zTM)CP$M-HVn1NtEE2{LH|>pa_ad(6BE96BDBdXxSF{lyep)(CCK@BZvkML;hug
z3`a8YFoMoMuadzU<FE@B`D`GKKgdO=cHnV@Tb%Ln;C(Xj@tTmc#bFfZEkV$nPEM+0
zQMyxUW==_FUUAWBkZ(X~v<Q@KAiiZ!Pb~qT?h0C`P_zN00#v_hvP1lS9V7r!eT&n_
z)6X^D#na907AI)d8tnffkbiG+f=Vs$eTtBfxC+t)4vrHH3=GVm-~ipw#Q?s%kd2Xz
zS%8s?m4}s$k&TswnU7I~NlY4aA3Yl**MANs9!5S!Hl`wwPL$*fsy#qe2l!GX(210&
zSHwlJq%cRZrm}&OWeY<yV-$NTTMAnWJDAOp%9+BE!U<+`rSzq6rEs?}MscU`r0}*d
zMDe6RE=J-_=?7np#2CewG9d+YITB+Of6BxZ(G;;3#wdXl@f3*`hA6=l$rLHjRY)n)
zDKae#QNk&*DRM0gQ6eewDGK0Aj}%jsz?U9PN>NTxX<>{KPf<-#Yhj3zNSU0Xo}$sh
z7$upanWELg5G9qOouUJ}5Xqe(MK?vSg&{>RRi>FaN;Xw4MZc7B0z=UccLvB+NGXP3
z8TmW`cZL)r(B()lkxYgtg;d36hA5>J;}qj`rYPl<Dd6jp7^75DC8JbR*&vrDH8V!3
zr7%aSr?RC?O|eX|0$*CBkuojCI>n}iF-kL4D}_0YDaAI$4tzP1eTqX1LzGUcRvIJt
zDka7!U8oA@6c_L%Nv<hw;7gL+Q#`<zBzdNIfiFq&PVoU>lH{A>2f8E)e5n#clnL}w
zB~$37N@mbYmCT`+Dp^1;RkBP0U8uwmWt9?}64$~IWt|eAlF-5sWs{PalGMTwWt%cR
zB{?Ofg)z!5B{e0jg(1p5B|Rmhg(1ozB{L<fg(1o@B|9ajg(1o*B{wCng(1p0B|oL0
zg(1o%WkyP2N>K}Alxs?HN=XYtlv_$^N?8j-lzU2fN<|Aplt)TsN>vL(lxND!l<Jh4
z7RD&AlvydYDRnK3QQj%_DGe<QQ9db+DNQX5QNAh7DJ?AwQGO|{DQztbQT{3IDIF~g
zQ2{BlQ#w<+S{S1OQ|6@fr1Z8hMg^tl2Qz5SEdt#^TBYfjR1B*5N)$l%FerepAqIDS
zQ;T4yu|USI^{QADxHx&;P-<{cMGI<7fZL&<u0;()2}3+1q?wlps*AxLMNn79zbv(=
zC^ID$v?Mqc-pMY{$Sg@ME=WvHRY=ZAEGkB9V8OA&Ng1bB@LFWBQ926X!58o<Wa!`&
z+!<h}<fZx-`Q{g;LQX$~OsHz2ojH-1lnk;eCNDiBQz0umM@drwvT-h2JuwL~)t8zE
zn(Rx@$OKVY**WSMd;O9#67$ki6-x3U$3K=7r6!iZ#>+rc-o=^ed6{XM$%%-IL_rRO
zTuluh4k%77aY+S_i-p63%NZ0}8cGT=C1~@Yh^2hsWr~z|4rP`SoLp`RySTbJhWdoW
zhkJO2xW+qsI0glSnpWV*gOs=MhQuvNoDTN^mBOHe!@yUi9soK&hp=Z!NO&2@>#KrO
zOCTv26b(tKpaqO6-~koz;*;Xc{5;S|8>GvrkOMlPH!%k^x>%AA+B^z&8)TFc95V!y
zCDa6{mEfz*Gm8~`Am*YZL+I*E+_UwxS`Gy>7j>c?v<wM$!4^EJg9JgT8?u)Uv_lTE
ztqy!C6e6>Nf<_sXgQ2M%wqh2=zo_w?nFngJK*Oat6x2S@fN4YBKnHWKf-UU6H0m6e
z2Q!z1V1Vo~1bZIjWe^69$$(1ITf*_ssE3RkJLe=87q4W5O#FcJ1egFdL~aRV@q7$C
zONdk{5)3MoE(0hdfl6X<DGaiu26XZWABe1FEMx%f3WBVCXS~H;k`xabA<|@mI1JR(
zM9;STkd_~)Rsi>hia;&{weK0gi;b#eQC)|o8pCBE*MVKu1|CfUU*p7>0=mqJ2~0AB
zNtPPM8ish#)mRMiY$fa^99f*rAQ3Lm09`zH3g{Xq9x%yU!T>gd56t5SlLBB>f+@^3
z4Dmu>wr~n)L4XL@Y*Da?7+9q^cx;N*FT@Qz8K%kX=jW#>0X|Co7B{#}3mHhd#Ra;|
z9m-}eE-4C1EhxIhU6cyifL;u0x8LF_PAp4xgxtEtSDc+$fGC}deuFwvpkz^WAKVKA
z*K^=9`<5tZj}vlv4iV<dO{|2Be!J!tlvLj0$WBcy2uVyTzQvuHo|j*g>RM4yRD6pS
zJX&&#yBJiL<btwL$}Qg9#7fX^56IO>x7bpPigJt7Z}EWdZh}q_g3d{VkCGJ^O$MDX
z$^+^-1Qda0Yl>5E@q&0RrA3)}=^;gxu(OajK%UIWEG|JyCE#0gD?lj&bV3EFG0g_r
z4g$Vei3d!A7N$WKEh9+iq$RwtkB^65oCHd~pf)uKgAxp=y9iD+knL~_7(g2#YC#tV
zgRWp;1a<st7~?^FCdgSzk_<JB;Dc|Ni!4f5K-Vb6vw;%6CQ~Bl$R>C}<eQkC3Z82z
z054w!^&PMe!YAk{fKKrR?QKZQF9J0MGV?O?(%}ZB!1p$QQw?<d3UbaiXi&H~F&8q~
z0vf&ooqdp6lm}bemYiRZnF_jI6K)zvM}ARedS)JIMH;BmfwjH}*FD(k5zvj2;A{#>
z!5WZJ8PI{;#a5tF6m&dSF=#bCYEcU{${SJC>VZ<LhNd3c;c+PDfkrk#R|0A&7#bLv
zfObg03UUo4Z?xtK)CONlY*4^vk*^ZcS}#z+3?5!aI_Vl}v$sMGC;&i5_4y*0XpKKp
zZv{gG0|he^18)T*Q!`)C-U)bIfepskb`Wi9Xk?%R(x#(eW@>6|W}u^BWM*MvY-(a^
zhSV^0EkwDA6V&!dNC1s-Lqj?t0W?3F1-h;sBCesCkYI(lX%*x(ga;5+A}LXXGXTMc
zD<~*{ZWYb}^_yRSh)*B_bWt<74G1pLir#@1OhGrqGA9>c426Mo_k)TD&{7BnG0=uj
z0Y*@f06lLEUIc*B7w$R(Gyn#!85mMPnVkW2SywzGXmqtmp@sppFP4!3w7Xi9DKVZA
z>F8mX)U?dJRPZTj;I<w(pMyd<wHVam(*d8ISBx~k44O7Y+}@s>T3no%o?5H`J`OFl
zh;SwZH@3kGE>W8kj!w?-o&$XR+)BZ<q5yJGbhwp<fuWJHo}Qkjf<|Hqs0~%5V4$g^
zpaCk|tqei)>^WA3sM!?BvSP?a5e+41@>W7i$%O2OY9r3>Uz~7vYqCPtzJQiQ6iI_>
z6UEd#(E6Hqa0L~gp9da-NdfPnf&_Z;Ee>#pAgMIHC<~ONKur}$wE}Jxu|xf`29#_-
zok<2x(8v@x(LnB3f+rfNN{oSR(7-9U+5n|G&~b2}>AZzZ!3>&=iJ%kR;CUE5eH5jF
zH>xFr3TyDrG!O&4*$up`0lxDAG&lvmf*5WRXx=X)6}~zO(sza)(gIok0M1l?{vobb
z3gBc|1YSs0tdOXn1xox{pdtXJ{KvW~0k%Ec8g4V#u*_nGV$d0*iO_8#Ihmm2gF%}&
zAS;&@5<wmN%w$+~qN4ylP8)RT4C1H;Xd-~j;KG6;6?A@SW**{B=z^TY<W$I70tH0v
z2U=Bzd}2^!ekpkGNMcTLzCv+o2`nhUd9fI=xLYAHDXA#6EHkkLw78)%uOzVou~rsZ
z@+pA~SJDI(iFpcO>p@`!kp$In(6$YzHKqYq3lAS%l$)UAA>*X+354@9tYZM$yax>$
z4BJ3EF~AoI4Cn>VaKD1m7@k|6LDERRf_jSVZWPEk5Y}Y8#UGD)sWxo=GH8|CEk01g
z(J?0nGJT3M`^kr@bvG#AgBpJfqE#~B#tU+OM~Z8dY!Axv@YW*e^gvLyUkI8ZVFb<Y
zFJvrI0^jt?1Zp$ZGNv%sGSx8FFvm01F!3<dFvm03FoRZ~_}yaE0*~B-mdWLS+Uy*u
zc`3!9H77-{L50<KP=&_=+0g;=ToE%91H&!$ywq~g25U$$1}@M*Wmyp;69dB~kbfX6
z4MAI>c^E<G@N+O?^q){eAq1r|1o;f+!(z~2a}8q==>AEDPKFd#@KGa7Da<XLkV%ku
zM$kg9c!oSN(4yNch7=aiVUeIU!k`(Xct}ObR<+zWwIm}y1vDIznOByd4Z3t9RRMaL
zQ9())v{p<lQUGu21s5~WGe{MX7L6(>C?qC<x2NSRBte?GsVRC2py8H;gruU>#B8^m
z#Poy&kUgNQoIy0CiqKI2U)!uug4lkhprDYFSq!Q_z)O-qiAx~_<4#Y|3?e9ai$PnO
zQW#Sha=??RpnWKepmQM^K*fCxb2DfaH29WHrd!MfDM`0Di&IPD!Tnk2Bt3Y>`xa+P
zKBReEd<)hUf+RZ*CI*I;jJJ5=!A*Nea6w`iWcw|4u<uff9)Thl+%ab409~ViIg;fB
z3I@dFC{*7qk$6~JA8a4Q0!^ln5KZP=Y!FL}_(3<E1%eVCGdR)R;somkg=rBVNDiFX
zct9+$qd;{l*t**wSAkBCV_*d(I6hW3M$kM47bAM-t2ng;tN~?U4V2(O!3^H&69(?F
zgAN%4U8j`IR3rvEpeCL%&!&V4diVw-<k*d3gA(Qx7SIJsB@CeTypUaH%}n4vJm?xG
zwiMPBwuPWxJUh6(#-2Ed9kacbpO*^SgacY{2k%go<SP`U7J-gEfTYJ_$WjT=2C_;8
zcwG&SDOe>3?X7_pMkA6FIH;kfDx~FsTG@#Tpgu1s)j`)oftTwj80Z?qmq{1vfYqd?
zfQD-m64LTOm&fPiCxaF$WEX>~CgfTx4Sec6lAHoq3#fwxRtoYQv}vD~2Wr?W=zu&`
zl#0~8*HtK1P*AW1uSJ6;6X-d23Q4J;b_v+8DGD0Jsi_L!OJkB!bMng(O+;PLnk=XZ
zuoZ%!iWAhxfCpG{DQMsyxksxD?j9=GDkOrBphMA-3Mwu@2kGl56eK2RC#FLJBoVdm
z3@xK!O%=rWpeOid5Ag0DP^5r{R~6Foib316GSe!-UWGKa!0Q_;!3_vVGYKS@3krLX
z;~_%uO0Nub+Xv*<rnEdr;{~KDH$Me@`vk%lkV8qzGjnnjic%r%2#`Wp=pxdHe@RAa
zQF&%@stzcHq~xc9FWpgq9e)L}UjcMQ6xeR0ri5pj0_dg+P^yC5Wd(CHII^J04zy`2
z2ehicEHl5f7<7jfcxx@P64(F&QbCL8wt%NNAYGCaB)ef7tw0y4l;;<vAQCTPgS{>|
z8N-KnKusIy5-MATgamMToRFXix@#g6bOMY*W*W353z^|nD9*?)%}D_j^hKq43ea^p
zpndL%8L5dWpsmI!3W+%-sYQ8-pj(Vmi$RNT5eWdazS0U5m!Pak>GDcY?LhhxOK>O$
zgRcw&cL_m-3_K~3zphdNzNQjx7}b{df;<Y!%M`A!ggXq!<OQ@jNXkTnf;Q-UJq2yp
zNCY|`5%VBFz?z<@U1QMP0*Mn2Aj4o7a-Rq|R-xGo)WS&4&jX!j3SwsFl@x;(9zv9W
z4zz;@1jr0*z6Le(!Sw{BT|n%x8O(o(K`r#~K<A@|k20hf2k*g$IV&wQH3yWhia=$2
zIVhZqbwJ9XRRLo24#+Ps2M`WmP@qH4Ml>{nGK>w8X8KTC1EAJ8s6_zYevP=y7E-&T
zZ@y-{#R02Mp_{LZj)I24!3`BK0cxm#_mWGpF+lf{>w|+ExuFjhfP_Dy<pe*Qtx66O
zoseRwSRofQP?nSmF5N&CdC@OM1_n1x4)BP65oq}87IR`w4tV*^E#}<B0`OXnBJds)
zkWy%W<rZ^VUNP4FmP;5I7~X-JRN$7p1|K8rnr%KtEWH#Y$D;%!C=fyGMZnD}NH2wj
zA&UWYg?b5d2_vY91!^pTk8cNWz%0<IVOqcnS|bl`G=Yy0)MT!j4Nt<L3oVeFOQ^w8
zl8<!cj(Rb?DnwBQYOJTiYw+UK5+v6ncawutQx#Gx5_1c3Qo%JhY<vPVdXa#rJfT6)
z1`c&d_=|#?r=Z0%U^z&ri-E+z$pK7&(!?!3)Zt}$HrN_EHW@|{jBrL(j1tbEz7lBY
z2prCk72hrlu^OP=f1qoeKnF$FFfCwCVO$7mlrn=Fu?v|%d-}j9h=BJ0u@u;WRj{To
zBZWL$;vQxO22hwMDuC|xPEE`M)#E9U$`Z8V2-L0tl{$#p8gH<};}I5^Xu%JzqTuF&
z@|6N;u|Q%;X;Esio<e9I_{igg1T<|4h}I}fbFl)nK?1(YEHNd;8Fc9-$hip#=q($V
z*Pv}|eb5{jtR0vP(?)X313H=tI)4K)ESsp1Tv}X`pQ`|qDFJsOA(Q2hZ7Pt}$_nry
zS$KHqDx@WrB<6sd$eC#hpq`};WRD_P3uNhp8%PO!xD^yF#U=R#;1&(20iBtfo0<X|
zdCIA@Rsf%10&4SNm;yHdQCgEwgOXX7fCiT0GxI=~Rzj-+=)?d#1V9BoOciKe1|FZN
z)fK4I0h*PuvsExMFfh=81-7jc=s-CI&?4*nq7ns=NyT6l;Po;&i6yB;Xmd8O+C{+@
ztQzb(lInlRtSKn|L3_cAONt2AQ}Cd-QXuGB;>NCvPJ-&9Qw*TmfeFC@7fhP0kTMH=
z9Q-7ZI(Yp6-S1r_4l1?4`|+{VX}5Tgvy~>O^a2e)GYD}o3Ndp1=VBINtb!Z@53lHu
zHK2_6fT~;&1`lI{iZaOb2e{MBm<a0mL&vTmH6SQ$!@9@NHajSVgEB6-@dFvXsQ~RH
z22Fe*N^1oL1-Hb^98l9KKM&N~0iBu-uSVfrHOO_(C5hS4g<G)OZBg1E;7)Ea_y#o{
zaJ{3WkXlp(>hYFmq=GuPpd<^$pzf_Lv=M{SpG8jJupTVD_X;)#Y&2vp0n+hTC<l#W
zmz1RD7Jx>PL321Dk0b3-R!~sT1#5$LhavSJqKt-k538o4BB&mC8Kh8>QIubf7&cc>
zPyp|3EX_*>6{pZS08p0^auu+if`Vs>LT)0cgIkne4zFp!)hucem4NK~%rx-OJ7{{U
zII{@c^;W=De(7m47QF<m7lzEmVQX>S;w?@s0mU_>QRM_mo}hY?fr|~c#UGw5QB<Og
zvx3ICIN|58g7?*fj$SPCNCEAhf?UpERLfE&Rl@?hmZ64eAyW)fEfe^JG3G*vaE3zA
zB5S5fC)gtELLmc&LZLzy(Cwisnf*fCG?|OQGmQeEtY#0|g1`nI`9kbbxy1#Fxnj5c
z(!7*gjH$O+Q%ZAl(Wf3kL(<uq1)iWq6QCAhu|LSepiMHMqbEQI=WsDHF@d&HgN~}i
z9F0ZMixLE&aWPQ9fwQIu^dyZUp&I!8khP$jcbJM?Ku0muGM9j_4zFdYVX9%tW+-w2
z4Nijgdz69LOevt_V3`Wlz}{zqoHD1$3JC!PPzbyQjXHy-S;6PXX|ke+1ygwmbgxuS
zY93^C649XIC@4w=C$kuk=fR_apyl1*B^sd9H@KM4M+0FRPzGH=zJ(V?plvcWOz8~p
zQ$fI%u7r+>gZ4gwhgFNXK&}Tn1x$b%ctsx>7#K1@P63(5z*r>?b{ss}fwQG&Zb1%)
z?VyDr;P3`H1vFF-Ude>r=3AWLK_t+m16Tos0NH<wvmn11(!9;a;|iD>lwD(>T?_C7
zh^H_!Fr+ZXFxRryvekmlUj`jC%uy@@I)q~aXsUrBi>ZcHlA*`~d?W`eXjuwqP`;U&
zk)f)ihNUP7lr}&l=(0LcCaLAjW2s>R9Y9>mRl|_QTAWkES;7YD5M;9!t*HWCa>ri7
zSi@PvypS23p}4~t3iq)vlyFq8fMlf-&KgFDjv9t6t{R4BmL|qXhQfUY40)imiJ?0$
zj)kFwdjccq-mY36MusX-dS$9%mt-jV0CqJy*wvt0zId8h7(v|;&_Q|}&~y$KU&zA9
z0NPs-$&kWO%Tvdb#|5E5`zG@GYFH*P7TJM(3ZZfNbpm5?48pe)7>nj%_ivsC$iEX9
zD`(;JF=*EYHXqk8EZ_m<y&CR?%(dJlyfxf43|V|N3|ag&3|RsxOua0%yfqA2f)kjF
zQfindFc!b6VaO5!^Ef6j6<w;D29kAQi0!K7s}iW;t6{9+s^M*BuH_DA$g=>ujH%Lv
zk)f8Kk)cYigfoS?nXy)&hQCH2Ubse}i7}i397_Ck{NPaHuj2=WQVn+sLn$a+f7Ec-
z@IqL~ZkxcAUsfVg!(GB#BAUk33@TZmZk@nb_#>Pl&jTEbOqJ&t8Njiq2aCH2Ohr3j
zY_MAyYQXV`GrlGf^dEDj3Yq?6D!KvnA5+l{6#p^jhvD!aQ{jyojtR^~Jz!t3Nira_
z!9HTDVW{D4W(6JVQ^N}?k2G08JHSAN1$eg?c>9ee6L?={kuoC#LlvSY0o@1*I)xNm
z?0{N8nfZB|Vnv|KOTm?C(GO7B3)+ufqyj3;zJj>7LG40NIaXu@;({uuBJk=5@HQ0<
zkUG#w4UpNwHy|aTDMLuZ5;W2P-X4<(I$but2z+!2=;RwsL9}8WQhIWO<`$Vlf+BCR
z`Z|U<d)#7ibM*AN#R*<p0oo9Gi>;t26|~2c8(icSgZIILE(QRN(cfZDEh@UjS(I85
z0v`DWHwtbEfPEVeX*R~ERwQHF>{;}Qfq@|(R7CcHmf|sTF|sl7FmW*oflrX*1E2N`
zVuMbclVK8L6kr0KV+1;xL<)4dI9Ohck%>`^k&jV^Nr;J$NsLhpd;%R8BNL+l_!@FH
zMkyxH>2xfhQ=tCxu?R5nFp4lrG2v3d#R9s$OpK{Y8nx1ZOqBWMJ0~V*q@q;RpwSjk
zZ3V74>=+mrK*dTHcy<spqSDI@+9(FyV8&Q!0WDNO^TMEP#tbV$K?MqUxhRXD+e$`A
z%z%=ZCQA{xjp7JO5%6>X9Z5p8Rv^_6ybip@QBqV1_Q5ew_=4OAy6_MblIV3YOd*D+
zIAIMiBao*AKvUhIk_~h-bvQ$w1n88V5~eh!N)3pY;5RaYE@%gx@WJfo7NW^qWClvC
zV26W~vMGoQb|;tsSC~A>iFshh`lVKsoB=r))E5Cc7#xXA==~XF<rq7qK$Sjd@)~^8
zAY!K!=v<~K<`nS!J4QP!G%pF%%u7vyL@y}ZK`9c1VeK$bG#A$~Ffe2?bTWWe1+#!w
z6*G1+wllOdrhyiQGPQ6(FX#bZ$pgJ@ku`;_g`*a7RS#(IE=Mg(3DW}bE_TR}510o!
zBmgvD$qME%*D!$P*uXp%D32YSJUIO@dT^lD3Md?lc^DWNIv7A_>vk}L79xS0FDn_r
zLt(HB6B5Dg_gk#VpoDyjCojJwJ~J;K%!8yMkV#-2H$f2r3QY#aDr0c;z?)F<r~wAL
zd@(PxBt9N7hKhdGIVku*7-Txwoi(7Xl#Dju?Tlb|f^CPTYmh68KzB;7WGu3Vrx=iC
z@M`BflsK(8wFG4t4;0%VZ-Pt*I}H?s3mF&@PFu+cITHwcqM044b21qj815rE$CT8N
z0#C8wb`U7*mN0ZMfNpjIhto<%a2p+Rf*Gn~ZgGO+F+L|X?-7!dEJ=0}C~bgD(c~zS
z1ywFKpelm3q_QBj_!bvr1p(*|9dI%MM+hW*Kqoc9`VQbh4e-izPzV({!b8mp!~%si
zcvbgRkUL@hB_1X|W*#u)V+6q}$Q>#Klbzp6mLl*bPEg;Y2-JoKn+;A;NCe2zTl{Eg
z_X@}Xpy=mdEOKRHVDKZSK=~zs7Q}9uY0#<yWHhK80bx+L7L-{*8KJldyxyUifdyKQ
zlrS|jbTXinCQR)N?M!J*;KQ$BWeB7^VF544fs`k#CCm#z{XR&U0pTG^5Re?a1OcmL
zg_b8A<dr8y7N7{U1QFn<gcsxB)bJ4&oD7V=AotcGVh<iDM3xtzqz{U-V$iyLSa|`-
z3muHvEJYSod>sssbytiG;S7ZwEDR+~l_s$2sF1^ep%CoJqV<raEudD_E%t)^0??W7
z;Ol~mY?&B9N3Da(m|HBxnN_Kf^a8RLoUp%u{KEr^Jn$A?CPvU{CM5Zc^x~$-9u&B^
z3Y$M57lBh1<1YhT$qq{hlUmLcIpA^yC@=p<a)k*gu7DRUoJd6rPrQFoN@`JR3h26`
zA}5f=&L9G<5CN4hE1}~wo>=5T4g<%ZCNreg0F_%sV3ptq1syT>2IO!^fy2YZ#>B_W
z#{nvGK*bFo<1e($Q1O^a*00C~WHUI`BM6Z3x400>UxRD`MG^;NQ2-MI1386C5$NQ0
zl*%5Z{Fs1RelUUCB}@yL(-}IL7czm{C7`l{F$L5v0hJ_-?aXP+h_VFSYQa{Tuq<E&
zjUqr>ARr#BG+{3R@nEG12bc#dO*m;$n((tTFcgD=k%6(u9Tbe9k`t5}K^Vjam8PJu
zFE#;<kU^UiB@7*m&5RvP*(^nBpaP-;d}UJ#1E}R%$kD+FYJGvG;6N@0SE-sTkSY~)
zA|SYY$Vp8rfgA`3E*~JN3A9V9GCnOcEgzDkz_Aaq99&Qcft(5|u|V6Cco>Bki@ZP%
z1~o1~js;;58{`>~9&qav*3jqxpAw4H;6RiBnoN+C90X5vAl=~VRsv)rC;&h<7J1{f
z4dgIL$q74q1#j+_0T~T)Dg$GY52%FXLdvY%$@w`sso+s)@D{Pc(p3Cew#X0Wcuf{0
z-(bm{oFIEaQ~wN%JWMQ%p!R?O8y^b~GbDQ!`GYEGoEZ?D(>OpzfSk?&ITiwCcnvhP
z2EyRJ8tA(C6vh}P(C`}Ql6lb3X$^B4Yb|>TLl$HIKSqWUhAgI9jv9^y%r)!_89~El
zH5^%>D}PRvFl4dTu(5&;>0p8!(orQ+!?1u2)Iq9Yu3=foQp*|6kY@!xG-n1QLoF90
zLzPku#{v$}En8WfHC$O-ec%KMA1L9f<I1y0VW{P*;{p%aK-6-AdXF`npbK^ua4%#?
zV*(}O8qRPACWaIS76uju&|qIML!J}ZMXbm!D&eW&Ea7ctDtcAJ*~D0bVG_C-;YcRt
z2^lg>U@TTLV1U)8kkqNk;#X7%Y7v4C8UY`>qsa%}r~^72Bsse%u>{hUh|kGS&c4M9
zTD}Jt1Gf)~K(T&H7)1hf^i4@Icr>8M7SzoJHydw)tT_+jf>uaFMlnF6ADY~FMln1*
zLvFG7dIksIVgs!gD=mPeH&9Qa=nBXzaHa(lpnP<T8`7@_cl)$KDF?I%2$Y{d2ho7;
zG>42vh%oXoi7-kq$uNq5Z=Padgr1^|XxxAYJiz8)l=YxI3QlpL-HV{K1v(5Hbas6@
zV+nH!1L$fc5l~uVNnrpTP6O=|f!7qXf&;fG43vSu?PyRFrYIc51$zQPfW5<2lv<ox
z0(ON9$TuLH8JM^jtI*n~2xTupS3_a+K0rk)*u{{8lCl_!O+c5OgZ4nCFqJYCDU>jP
z{7}LW&z#3o!mt2TB`|_`pj24G5YLtZ+6Kd%c!`C9!4<qyr&vJ=8s|!|nQ_o+)Xd}z
zg~XJUVujq)-2BWc&}?D}Xom@8i8qLwlb@cMj53oLlv<Dq-pBzCa)m_5lpJ&dGF1V*
z7ZSF^K0g_}oJ~QaJOgA^Mq)uhY97jTVt!glY945OE*G@Y5_F|+PHKfhdQoC-Zemff
zCU|uy(iA>)-VL;?6V#GPflR(37D6Z}D1eTXOHE7xEoCT5)lIEPO)dqkPlS0}zbr8)
zGbIr$l$@WEs;8jf3-^3xu|f)Xp$+2V6$J%_r2LW$kVTnDR~Y0$uJHv05q!=Nd25V<
zf<i!IQDSatNor9s(u!a3BqgMq2x{)egU_i_&{fbtTA^uZWC2>AsS8?|nFtD;63`At
zkPAvv!HZ6d^2;()P-i|BAS)Um#(@^Rf=ma60f-HadIhk()*xe1*RSe;R%@cnbt-^F
zAnFysCV>~!f=*O`4b^~+F#tO!vA8%j1#AXX2S_pUB&PysEoo|68mQJPOU<c-t^Y?}
z*b1It1?_MuNKH*CEdWoYf>*&Sq*i2tSC}dk6y<{w2Iy3g#1hci4&XRVg%0XMgpsWU
zUqx7)nUbmtu^V(4tQ+X!!i>yfg`(8N;`}_w66d1C60lLA*aRhkOz`f66wq>Qlu!ZP
zk(-uTR9vEvnOgu_P=UB3TtOiuAMB7a@S4~RP!0kY$O>tx;DtOo3YGb#h<haz6ky(g
zENcU=`T@li_*5m>5_Q;uA=DN=WM@S{BG`PSMOmO}{`?|^q|{>gPAtfZc7=ol6g}Y8
z=*YP$F|8yO#cdG(fx-jfMa0S&1qB5hi(?cNAZxS>G7I$L%Tn`FK*#x_g%xrXfffoN
zY{279r28vEKs#1J`|WS>$3s&#q>xJik03xwYf!7dC>m5ygNAQ48E*-I6MsA?F+(yP
zxTgXkz=bz2N)UO0%5QMTQyR3T9dvR(55^2SiVl<kTu_4#G>8f=#m|Ae3Xq*EplOa`
z&_o|IXo#zZA&bR@A(jU;yAC>xl98bhG`+}LY*E9wfDLpxV3kb`!vc2DiE!XKc9vS!
z8m6M68ioZNHH<YZ3z=$JN;sPtO1PRC#2ISYYCspog2fp@N3jQhrj0;{2G+7OGE`ZV
zFl6x*^))f%DV6Znu!GjaH8ZC$mogTusbN^aSHqsgzmTzpJ)XaY9XgT4T+3d^p2wF0
zropWuR?q>7pgmNHzgdyCbhv^`S;*!hNVNc(yoWB|0PU*+7boDO=b_6%5LHSDC^u$;
za&M{v=!9g@^4HX&G|(|Y(7GrYy3sK|B~?cuKQ9?#52UUrNrfjTBr7u#ixrYmQ}Yy(
zKqrtPEn<V5x&W~Z?9deOeO90a{P_1bz-mj-3Xdd&oses^VH+esv(Y-BeIKBuD&TYd
zL7e=gtkmQZ$aWL>p3-7aDGbW*kU#;u1(5^6$JKz&PlBwbDu!&RMDmAc8mKr?C{N6T
z>;(mti@AwKpcO(zsfDGPMW8T(?h{STD*^G556@OW@&a`IA7qaW*d36vJP*91Ga&&i
z<d~C_fY{xo0kWbjF$c8$6twy@F9msT3D{SV3LN6;gapV^eAm1bP|2f-<PXSR0jMPq
zRiGW9xdl0y$(bcNpxq%kImMvz3w#<l=rC}Q5ug*fLDnGq3DF41%u~n*jb}hY15!{I
z<%4f#$j<?tZw@(R8oa(0>^pG5ou7xag%`Ss1=)Pincbixzl#+>t^h5dgQq-@Q(!Sr
zTAT`6g;`XLS}%dCE0DT`gq-|j<crx#@<BT>QY%2|9^CeV8w+hkA#Vf%*COCXQEFas
zX;CUT6@cqGoM(!I{eWR+B~qINvR?#L*h3>CJhLPNbR0=S0w|zC^%kr}20QK=R9zuy
zfW;i#8U@IXC0P9h4rREh$h()IJD0(BfK@@`0%`LwC}k=nBw%dDg0GPUZwErM8nLSx
z6yRY0LrWbbQ;{uG2c@uLq)34q23}B>lbH-kimBiv2rkLMDIhZs6#7L9C>B8XszAdB
zZjOQiG-%-=1((86lY;mCt0$_X?(tVo1c9W)#6)$ZGs-|>>WFpyph}gXc2LWws5sRz
zC&w1Ft`=q*(qc^b{{PfGaBI3GwW0*>YH;VX=obS6gP*1Vq?Z%}s%^i3w$pMUPOO0}
zasu5o0AA3Qn3n<yJII_Wc)lHUK4Xz5sBZ}Bd)^W%OD#&uFHQw@N|Up}`#6hkgSw*6
zK?KM?O%6l{^cDv=8Xa?TisV4HgKzRR0L_*#6{ljG^M;=L1Br!PP#q8I6f!7+?nvWc
z;sVWqGjf1uuOW9A3xLjqWMp9m(NeIxd*HoJu;mc5P!=<RCPP5AKd38O47wBpv@f@q
z545NTTI+-EwB`XF4h(4(6pDZr&=i|MmXU#O*{p>w^8v4^W2<4vVh1ll;;7{);atE4
zG9`tvma}RR=<wfc#-blJoHb0@3`IYx6ly?=fY_RuYPo7aZ3He*J>LsjPQ+cy13gHX
zyK)I+T%m>we1AGyBtv180YeRU4O=!#(YqSX6c%%aTFx5K-Q?V9%%II5HOxgX;3o6d
z@Pbv|tKqI?D|}PK23F5j_zldDf|*(v70!?s#==m-Gl8)(fRUk=kCCCuri3$#cLHOP
zL=!`vN(o;LA84~^Gc)L}_6dxjrBn;}YxuGR7BbfG#S7H%L0ckhwS0Aad0Z)A8q^X=
zVGCx^WKS$)L288rgN{PL$nu~QeUO?4;7yUBW%UZKiOCtTwWW~lf+eLz;1%icR1Q`Q
zD(4_8FLWSRO`vVl0%Z@_;#E*@GO-fW-2s&VsVR^OFdup`C*0hGgxtgm=uUa0Vh6OD
zR3SMhvp}IZIWZ4(1d#%`Wv-x}rw(yxYB6|UU>az;9JJ&V(N9fC$S+GR%1JB$)t|)*
z#RaL!;GL1+ep#LZRI&i%8L+Rwr#s~2fSg*C3aTShk$YpHdKt1_78IV~Q_ev(o&vI8
zAx?p5R)AbjR0ci)5uyonycFEa$h8>cQV#eUS)^=)xPt@7^#^eCAeAHZh>BF$&848i
z1*v&~qiikCFD*(=Rj^f1D$YsCN;5Pv&M8jG%F0eNHZd*ENy*MivoN>J$<8WHOR=;t
zSAyFKDp<iM0%<@@KvZNP8Bjt)Nhdns;L6NX02juIIRzPs#hQAcsD+dnFjEjaH$ldL
zFvJpd1$8Y*&}%EG$Ej;+q~@jQf(6j7cgC&-;ug@sPl%oy*kFwFjED&Zlt73B0TdCi
z5hx-cM}aU%X<S?!Ryk;}W0eExg<yyY1QbEyjesJEc?t>&L>UQJ4M_@cv%z&AXq6CX
z=@w)S8mMCO(-bTMRewc^psEPGyctyQL2f-r0*Qe~55ct_s8fnmYl7G3fa<>@(1a6u
zg~yLn;c+1fj$7=|Obw~~ltDItD!^M@1<-Te-12U*gEJS10nPPAdZ6l&JukJQ#3w(w
z2wYi$d7#@1uw4njg-Ec=K@}!wrxk-d=%gMlM#%Nl9N^O~Kq8>Slm)=c$3RP+_?S4r
zv$iaZT%fb4nYcg`e&A(cEX+cTd>F%`2#Y|W0GhG^W0bx$1LQ7irWD3n<`mG99fqno
zpnA22aUr7%Lu^zGb1e&aMuBMoXpI+h4fyze&~#G`OHn}ya}7%g=%kDw&};*!o;7Ev
zWy+HSi?cN|6{Ug1!D3uBAQQm1QP;55G8amL`HVHpDa@eLML;G(PJFIm0v(G`%ap>l
zfW3sHgtLSTbjE%&(?Zy>=G>LP7#W~FaGosQq9foQIA0BW3VRAOv<LpEhG7AJ4Li8r
zV~-a=>w$A2df?y{R2+%X$TzOKR+OaXfp&a=Iy|r@HzF_-z|{(Pr##Xj3ZT{;q;>+!
zWP-OIfL0Vjiv8TgN_culx)2UBx|0YVErWG%^uS|ZrNyZV2?-@diFw7K^BW)~Ttb2l
zXcIW-c&<cv7a}naaj#rrNeQSHMl}%RjZ9F#Hn9Y9YCtA*LkeV1KFp=yjgE+M1W(ZU
zCZOsK!xgX|W1>PyVo`c(39K^!8m0s_=kvhTEqE6mG?O6ulAwJi$ma+^6r?DCgAaPt
zU$H`Ba&mqVs1powI;ipk51WIAwLu(k7KDc;WKpIbs7HVnT3~lV{0JGLfb{-BeuAq6
z9iRl>*G{;WD^G##@`hGDa3_EYw(=Cbo7SK^%JfPyOL9_CuEGXs23I2*<tch_cR}J?
zLn$x695f~j@^(3BPg@aa3_8EG2sGpiz1LhJH!&quAw4I*2y`-nLUCzsZfcQ25@_cP
zX#BSnd`53&eo?j_5l8X)<(DgX7K8WZghTA}PgC$OEmCmFEQZ<V3$o80W?wMGKBr0r
z@W@keX`X_AnnEPVK6n6uOZX5!l!+P8q$X%$27FlqXaxi4e3V$8TE-g2B9<D)iA;r{
zqiEnWLMxeyK=&WqV$6q(F@hyP1C2$J3=9ln9I#E%hNy#{XaR~?(Psl1Tmp@G*?|u;
z1$VtP1&hEnOg^aS2XANtFE$1*O$OhN2U>Pq1iGKP2)sKNbcxL^j`*}3(4<WsWU>!5
zkczd|LF#4|fv>P;1zkJjS~MHfS6dGvz+EmZRYuWL1_p+Ypt=IoxnmFk-H->mkXnRM
zh!Ip5@G*jF4lYJEMo=vPT0YDM?P8&?3`GkKlp$8o<Qk}x1s-ArT>w)h1G*Upw9ph%
zA%J#VfQsg3SV7EGnZw9X3)-DwQNo<XQe*}$h*?2JdJ0Q3a|%l-V^Iir8ksqZeIa8F
zb3A(uGqeN3Qp;S&oX3>{rokN$(B+@3i3^YmV#hr222+Jpf(3GMCTNH&trDEKGe9LN
z=t>}1=>ciEDS%t~@HAPH59tDcN-PDWQA6;SH^@*c)p{SPiABj7Ah+S`ejr+vIGWkY
z;Ay&o%#y^M%qmb{2y|Wvxcv%kwkPH(lok}E79}SZrz+&6mXxFx=_sV-=j7y<r>1~P
z1khcRpdnPy`5g)%QDmhk^N0$`i3RcC15s>|o7;L|^EEU<r?G&V-+Ev}aFk~-BlL>F
z{)ZK5pwr_)m13TPXAx+|2<(`WjKn+zpVY(@9R&p6JwGQ!!4tC4+7+}$qX;yLS&34N
zfr?LMa2ytw=4xm{MyNCMz+-x#`L$wj^`?-UT9lp&KTj_+4}3y7=-}*}RM5m?aVqru
z9R<kfGCY-ljE9uYAmeH1Bcu~p!S-QvDx#y+K_Lga96MSa6mk$2D9j)%P-sC|o)8Kt
z$kby|hqIt&=_o)<(os+co1>$k4mJfO4m!FV#RPbmpcLbvVgt0O99)cp*1CX;alRPl
zTF8yk7zMc|3%DRhFZaOZIhcSK>gMo59c}3)a(cpAqC>h59N_Cei@>EhxHEvWY)0OP
z2RZ;B>rfXDvbBmF3=GAf^|=h9OpG!}qgv>T`;j%F3~F&QFo5qO0}pD2KsJT4q%hX9
zf(Exh3vW`GdO^clS~1L^{c^RS!6()lc2Hv(I)G$T!v?wm2+ZTCWi1q|VXR?=G^asg
z;HE80B50`<JnGz2^HRari^66^OY#+p3vx0+cPT?g0FZ`sA%!B+SPys_27W^+qN(VM
zdx%B>JTwEg0)1cxF}DtxKLE9CzzT~I=X8Rai=eg-Y{W+)Apts<6AU_fJFz6c2zi_t
zW!fKhFp~~!Y6$9b<hd1a^Al7sgWI2ogPNe0q`;b-V0Xca55i5wg3`QX1zUyuyj1@*
z4NyZvLrG7^+Dczn(H>NIfeIBE24{AN8jvnMuuU3Dptclfs42799zrP;r{<NU<|U`<
zfZBsei77di3Lp(7rHLh}DT+#(nuJRbb&#o`d<{NK6~q8xFb8ftSR}Jp0o?|WIMSFn
zxJ9SQSOm%~pzD%BnM{)tsbkHNn^*z%%Pm1@U?O7d78_Wm_!bMO2}GbI*ucQR;0Vuc
z0-#OE5{!J{h7TKKl`v{^4{R<<Zx__e1eH(VW)0|2z8c07hEj$i0mvom!3?0Q7)zL&
znTk|Eha!Xey|s*BG1g|LVy_amEcO(}5)RO&QZa@SPRQslBls@M5-!j>yL2YdUItB8
z)IKC=LvCtrYF-Is!A^dfg0=!^$_$iZ6?CD?Zi?YUc8+-|33>{SDd0X2BqM_F7lqz%
z4jUnd=VRzmP2g@#E~uFU>!w04g-9p{Rrk;}Foe@<dQoa>30m()L0dsdM@c~&x%vm4
zPp+hhI)Imvnv;_c8vFAAF?2x6b5hXMfD^fb23V<%f|9PCl8yq{PL#tez|w@1F^WA3
zx^@cD>R=&I3e^D-;rT^5DIkU-@~tun33_^Z2?>yeFwm<^zy%t(JBiflgG^o*XMh%@
zfV$qGatRi^!P%JwA^FG${DAT?G|)BF!HqF>P$=o?=_zQ#t}f9~Pt8kFN6Md>#R@1>
zzDSdYILw1s3^hnYDIRoZLP2VZ7Wf=pxcz9>pp80bXBHHIT0^N7C7?2-2z-_@s2!PE
zlA)juGg2Mme@I^$GE<J)eFs$;r3IiNZUxW<(|PHLV~#<t0#5^j%53n;HE`e-fr_wH
z=z=S_wMfVGAx=$9%*jyznF4btqLTS#;+&Y5mk+unHa7`00s=c%6?BSpWkITfDzp`h
zQX+tNv#w;k#Ra~P5PU_GpC<P$4%eKV%!1;~;#)lN0jc2mc2Ecxf%|*<psBIPAOh52
zxW!SPSOl6oD89u4Vimmvo!HGA3_f-_93oYu3hKXAfV6;{Fkk}Qjsab{9tA4BKs{Ur
zX%0rntQZ%l1pCj%#KKsGc06}{d}2yUd_3+l40LBSv<#Dglwm21prb;?8IZ~{9V}&8
z5V$O3LMqFcL8mt{GNiDA@9Jd$nV`v5g*Z<GZy^Rg;1;y998#|3rGU~DD1Oiue!$8u
zgt5OkVQEdPs1nrG23@*XR0UcLt;tnX0}=t95P>Z+it0eJ^&kQi4Mhzg7PfE)U2xw3
z4|f*Og}tEJNThHVLrEuk@$p3j0^SR}?5KvZgt3{a2(&z!30he&)G&f7kYX#)<ryi^
ziAFJo67Z6sUS>#TQNvKev4C?S=oEfNa6q$Gg}{q*%z)N~glb8Ckq*|%0y5N?T2z!@
z1U}ycZWNXf#geG8h9f8u-{Oh~U#b{fl3!4SC17u{$Hy0!CdJ41g8~=a0A@i8Sd0V>
zR*ySDgN9c?r{a+ru8cJd5}^ILtauYHB0RyX5EaNuxaeWKl7o^odW$1Iz6cyPvvGzc
zW+DY^KnYAx>jt!y1~iyf3_2kWS~~EhFxE2WS%6N+D`9G8Dsrn~1hrm39f%T!G{$VE
zBDWNl8pagn6!7`p;tVOQplhljSHprXkcA}cqL>=S6m}+tTBcg&ygxA0CNLIxl`ui>
zVyuB4WDFX*OW{H`1Ef=u0lda~Q3`0)9kV1u8WY6q6n04lP_`-h1#$ya6^P9)$&kXH
z%~W)ugax$m1ynYH)TS_JGZj54VTFiwFha~0VSuOtWvM(rkn2EdLFP_iEYbn<nIZOo
z_%)#Y5uh`7m}{6U7;2gGWJ=glxJy7TW0z!TW(2dCL9AxxCdNFz61Ef`kXSQgGgA{|
z4O0qxHp2wQqO1~*6kgDQ%{9zWk(v^Y6h5#BQw=i<12aQ5(*(w%DIkALU@TgY$HK^v
z$5FzO!Vgx%Jb|(33v_FwK#E`sM<+uKNc}6&ed%DGmpT|b7;3<mYuB>miIs46Fs3us
zFo`fUBa3rD)YP)%$w7586|r<M*0SXBA?pCGiwI`W6iWPoJh+Bg=4c_6If<Y_qhjzX
ztNb*`da)t}Ed^uHY&haR0eGpC0KSGrK^xqRf>H^fYk)vEFF^*=ioq=}@YM#nsjwyk
zXqqIcQXx^nNEbBPoQ||=wxqNmCsjwGI5Rgh2eJ|`A)z`qGY@qCNJTBEAy=AHl39?G
znOX#HaulVemx2@``m3Pz$sr(95F=Zl<%VD<K>H*L2??O3+n}x~$PlENV_m4HwKVc{
zz{eAVj^xTOLKX#yptR)R!2xQ-DS(>gkZ{q;Q_xn3N-fHVUY!VXqGkf3LWC&SC;~0B
zPb^kYN-R;xNlh#+Q2;GgFD^;U1Kk|~kA{Q<<TK_F?gV*6M<EZxRY>m8Fn}mPb11@Q
z1CU}eYz5hk!(x2?MmXLO5y&V(3UW_E0^(vuSkS?JfN0}F!&(F67Kk?$;HOYS&NocV
zLpsVN6S3AKH@^tHzB5k&q@bXv7_vql*7=7oNJ~x3wFZq`f|}2WHZeYXQ}fdDK}#bN
z6><|RGIL9F6%b<`Ag{o^k)NDgT2ut;--A*uc)28~6P^lcVT0Cu!w)nAH>L9w%8N3Q
zmg=HAK|x!g4rDx18q;I~ciH_Qr)3oxgW9SqL9JGB;|sKx4`o=733T5t=)P$X23;9Y
z!w@S5D&R{PN*RlUY8dmFQW!v^OodE{eTR&Y##;fXQ3h@Tg9&gucr^n9!(sS%o(6i`
zE4MTU`M3r6k+mzC{QRmcK#O<sOJHS2r2^_@0qWqDG#cuv#h^Z)YO%T|bP%_=%77T1
zAdPSx`sg}PTng$`=cT46mSmPeyE9b|#i^jvJr%&k6|{>3J6JazbZ2R55op9cwXifX
z2b7p0`yG%}SLqP6(g0)vDDN6*qC^rX)<CsCD1?ha3-4+eQb0S&Wk6d-I~YJb35I4y
zaqwviATiKL1vt7CLAxLsi>w(KK$kTz=B;G9C6Jq#oeDb+-6ylS1TvU|h{7%=28Mf}
zmI|n`0oqh1!c>KJ1aW*kT129o32WbjnxwZ_!J$wz6O;;rK!hcTFa)JcP~-j<R~YD!
zdT?_T+`)pK#gGeH6Um*Mndh1V9%3oJ#hqVJ0^<~c?*RupyAzZUL4gBmwSrx?9OQmK
z&@u=S&=N%%Mj0k9Mjl4c23G+vEyc(KUSq+*B*v(~$ic|PB*(<Z1X^za!ZM5;Ol*vx
zYazH8`Isb_xR^kP{P1Dv#DQ%?X{Nz)6nG#CG|>h*fo35ibPKB{V^KfIz1SMv9P#l*
zU=u%r+z&E|0pm&vm=X+2K`8`mDN@f-1k`f`pXbAb)N9nh(rfes_ZpdzdW|e8tl&-!
zTQEZj@(37vl@Gi)!)#pCz#A7>hQGi|_uN1`fe@8qh$iDLPEbw)cNWo`-kRKyvZfXk
zWT4bkgxYJz+QBgcr7vvZ%N8G>Ulbqz1r)mAjyelyg9=)|Mg*lO(1U2f9om$4Yn%vo
zYmh>f{Qfw4*cP>b0u@_0vB$?3fdYz|6E^!nu=592k2{n=tDng4{FQJZkHA*B;7NaR
z_|l($5hC58hlVC6(VaZd!5+9e%@v?<<0n4c!0K^_8|A6Xk#Ool3Nw17E>I~4_O>+6
zV8ZMVgEim|C#t3|H$3S}4PW{KEsds13e(0_g0aWPC+4NZ$E)KEI*ef%uzK7fM|lc!
zAe_RGLXBQ24D4-VoWX>d!oV6Z+FhVZ7+kA@mQ$86)PUPqnv7K*c+yB6zBJ;OU*eco
ziAW`yj76aB>X3u6z|9#j0dCH4fiC|A-PI8vZx8Yb$T18oRTAhmR3`XBkN9{D*Mr82
zz^(_?cA#ZGphH-*n8X-B;}f73q9&7Hm85DBv|S7v+6CXlo|KcS$qc>}q6mDb0cdvy
zHdhw;GBPl@!kx#Aeo|k2Jjgh-p>B}FIAJICO#q$LCj+k@glZVm7$K8$&5Ym;nNlna
zCCrs((9IW&HH@IarAP+Q;e(K^AK>P2MG5NywiKoXpkW^76c+FR82EhQ6qan3qJk9G
z1?&*j3qidawuMZf#i*e1TF}5$3i!h0W=0W)TBaJ%F#zm|O~}J2kae2TvEYG`l++5)
zWO80UblML*zl1cC1X|J#>X)S!7iZ?@fi6@^Ey)C(e~o3}AvzCiCfZC9Z2Tb)scWYI
z>qbZC>L}pVr2$faGV%b|nx~_nr>6(95<bWgou>ohqx8q&sT(q80lpUj<Rf|vaYXCs
z=@IfEwFfvrc7g%{v=9N(%Z@gHhg4!wD(XC*LP7#D!yVCva3fFx7t}w*HrN3PYX#5}
zSJ2=FXzUBJ;sSQ-1LR&V@CXrjk`rmh7kzvL<RNGvBKZlFE@BfBQu4vq<Y11Lz@t4g
z4QYK=LPB0b0yIS?B;Xk}0dK8=tTRYL3~9g(O-Tix)s8&00W}roTEu_`d_oXBvsa~;
zpO;gqU<m3U8$tJd!jIX9-P4eoqM%W2P+M(StLayC40NI`Cun*$y4s*N7QFZq*2J3+
zs$G3R{ZDWw6ui9vG2!$BB-;(@I74m~ECQeEi0Ey?i{~OqMg|5iP{Ahy?rAcCx50sW
znS4w<j6zIY{{<MC{;{!&U>>^?pAISzQghKtMNs(;DjC5=Hh46KF@+I44g)?O6V!(U
zt<hY_5X_Lm7|fu_l=v6<M(1GATy}D433y31Y$_Y|>dXYtMIa>^3JD3I<tm7KM{S|2
zXpmBrCulqvbh|95$SZ~}odj=6PgE!=O3cgw6@du}>RRdv3E(@K6O+LU5lb>s^DxX$
zNPrx)fwX}ddgV$YXcH-DD`f)mbUVUwP@R;Yn^{r<Ix7P_*PK`kzJmc|J<OBPYj)r%
z4d=?rl8jW)4r7!I4c7(Af2GB#MJb6TiD;`NK#RViO9zp!(uFOX0NrX0T1cU*q=})j
zI6t{KH90RIc{Eo+0W{=}%_7((y;w}vP{LxAA85c2)Q<xnH-zoZXb#x5zImXe3Lezq
z2Mu^&*3+Q9cUT$`pi~J?k!VezK6t<dmll9;&w%bX$S*A^C@lf4rvP8A0gEJ*R!f34
zC<M|<!GmSlsi_6<RZgH9Gp#5;7jAlTPAO=KD=5B83!t;4sVNE&Tj1q{f+k~;Hz@0Z
zPap(mQZNB-NO6F!aw$qJE^Y#a0mwrPtmyuSDZyw&fs}*&4;sx$VXR?*UK7id$cLQ!
zTp-7vfY<6k);54#oS&vpo{?FST3i4+nE|@Z8L=EKBNdT#Kr<7d6|QiPV-GlW&=@i3
z>UPjkI-r2b1MMV%o(7SZUzD4elT)bxE-#_=2KdTBkYEyGa|&qX2K)pO&~}kh&@4<+
zDdaMaq*U-~+*I(wxZ?cWR3uO67K3)pfQLq*oA;3p003?80^iDjEf)B5QWMKk!{Ncv
z35pER!cqn{HjF!e(bQseVBoO=T8s*f6;RwTg10v@fiHt$uCjm!rhi##QBfx7a0rms
zp-ZNayakR2#0(Pnt_`qH!1qhM2OY%;y+7n3sOA8tEieI2U_!;IB?yl>XCxLCPXhT4
zlw}xLKu4jlF;+oVAj1|)fC>sUEyO3isyA3X2J;lW?gbq(0oi?@kYE$y=wt_~y+P}G
zK#8#!b|?X8?G7lZg2Dwp2a=hWj>uZRNH@rVR+y)zfo4+Bw&p`7+!2OA69?k_2k1f`
zPzFgv?1%^F1qHbKz|jD%Nsv-ih$bUs#|E}k#S3zOD(sYm*`QE|rzy1K&{0%kq$v0R
zst@uC5FyYa!Ddi@1hoDGG{J5Hx^5_oxs0*M1GN1dbaMl!Cy@u<jJ|*cq#m?Iu9*=e
z3QmWNiAPXM3dj{-p!PJhhXA?UD-(1d3#b*7s+X>(qmZ1R3tCxNtO-h`IjIUM`Jh;W
zZk~ciKREm{^U|%s^RCcq{!&xGoet2F(VR-~J~rrq5xJ1b)Kr+^pavCq^99^Iup>a1
z!YDv(Dn@D(;HXzYDiv%M5Yu<aJ9klc`+}6BtOit1Ov*{jQqb3eJ4s7lA*VPyD@9#X
zK^d~{53B@vksqk02Ac$SZK_6ca7krOsxu_OsAi##f;z+@h(-09Y)GSo;OYjvVHLcI
zC<jz7U>i<lgSc`DC~5M6nu>f}(Dh-U^ZBaK2Am;^QPz-y(lfkWs02DQl(B%VgrSD1
zfTx79hPgnfgei@=h9RCg1ylk;E<$9gLaaN2obv?QOIDDRSP80_;kP8ft~@KomdGGG
zXHbfQ5KY#i{UDDX1`(iS4Y>&dbTI_<BCuQB;PsJ^tCVi>LJ!J;a{1xMzCi@gc6r_6
zFHS9SNlhwEhe#Li0R<ZPKq*Km`j3qnv#vnXgF9zK+SK4xUC@gq7cw(4<gp=#TjEqU
zq{9)Y7<7<p-_r=*_zsFEPzEHN?=ZG1g6b4V`xLx)5wx)ft=S1(egSLVf*P*iCM!f&
zUTH2CJte6{xeB%l<tYj^pwo6hr|Ka#F@dt8vI6)Bi2OVSM7jcvfs`Y5tb&w5_D+Ih
zR|9F4EJzAbbbu^FJ-kIJF)3NW(8yS!qOwZC!qPwqNiTTCF~%Mm@H~?OJP1HH+~(vb
zD;Q`P>KLMy4q%m_bErV441l~2D{zvL7QurY2v&$`q_KvfjtQ!f@S|X$x2Rab4}?KD
zNF%WXT+u0*XzD0v<YeZhS{Z^0{2VJ&RKsvsYp!9aV}V5_rcWv=tBCW7p&=-Aj8F|F
z$uEXR=$<h&Ml}wHZwyUAR-2)!CCzG646DtMQVHk^I!Jc`bV+wP_+oqTO~M65`6;Ez
zpe7Ay8*M6R(>3_!ZE!MHfNVJ~R?vmr#fd5mIyMEVKMOxPM4=S4;S9d!AFXgo&{GH~
z$^;#!m=8My6nUo#%67$sgz}Vx1n^=jNJ9ZUbb^%0V3&g?Bq%|`)&|t50Cn2!V2R!)
z&rZVzl)~(EY?AYH>@<~-h7>^?hcoia^Yj!#K)v=%$Q|_HW|9K9+)hm?)=@}QfSI3~
zq68Y1N-Zu<Ob4H-Sq#z*IlB$i=~qIJHDt?Rjzw7Nm{SZMiAn`^dqDj`P}KzM^%SR;
zfC?q>@o9<0pi`?95*0E^a})D)K`W?0B_#NKH_&JrsMQJbIW&~ujTy-Ksi4&fpiWa#
zX*%d)An-a8cr}Em08<l-GgHB5!IkEvq!xh|WThzRf(KJThogd)XTich4U|gYwt&K0
zAsM^~Bn7M-<Q$kcKusa!C<L$Q%`Yv1k70l>s0I5p0W{W;kf0Q9rQzu0?4qZq2Z}62
zGu%y+wP-P@ua8y%gX>;M=j0X(sD44KREz#IGB6wiRixnVh$;)C023R=!U9-2#pr~9
zmY;z8zo4-L(5^M;N`|7%pe6v8CVA0a&_-sEeV|Sn1D0hI#U(|=4m5y|Ixo71qi0|A
zfPsPG3zAis^E#;oc<lnMZ3b8W3@P9%EkF(SA}P?-icFAWNnYXdCFs18?;xu|;ljWO
z>g1tM%^(i+!f2DgLlxAx15L$1JPPho3WBTzv%mznhsg)J!6`c^HMz71G^y|hWHB^&
zWl%;|^iUOISPXASf|{bB#VP3wppFV;K(Q(do~oTQQj@bmC1Pe?Y6?;rR18kyWuW7L
zK_^0#CWG!<)=>c43YN;uOUum5EJ;-;f;hGeT&{wIGEoi-1nnnV3L0mHCS6{znTaK-
zAw`MF&>Jlf{^x+n{)hXV1$_tyrUYffJ1BPGr>AcNO*Qe<fKRTkWe#V^b75g90iUu3
znp^^P-BK8vnffI_YiSoSEMx$wNnwJWSe_?f$WZKre7ZPf5~>PxMj3MrGid8P^v*1n
z$_<PRwXBQ`RTd?zS!_jB;7#-FppBa;OwG(GOr?xPGr;GOvSx8EWUOJ0=d59cZklJR
zWvye)<4OV3;7#+O2`QGU3-GwXdvItz_%JT$fNff4PAaIA2ckjc6rwcoOjAfyfC+<2
z9z+GE0V?l6t5ox0YM>K@nuz6)pfV16L?*}(kOBDxsd=DLT2S!}K3q^CIVT^qF&jGU
z1*%t2Iuo}Ti~JxbGH~5u0qH8b4%&3X0y3y54OG(M-_HxVRO6Na$N`|0Js=w7$)Xg{
zVLiMcZanlfi{e|1X;`=Wa)Mly>Xw<4%F4ySPz=iX3~Wr`MPfXRI*g#JQ}`I+2Q6T`
zloO;EcP<0ntp-}XQp!-o1IlCYX-<V22GChMph11G7-(;zRS64dh8Z$VnGL#<j47C*
zNCuQiSdluOIiR2cZ(3q0ODrnJx)y~kK0dWDK3*E+DNs%at>gopA^}?MB*2K?>4Yf8
z@CB%V0T=zCp-+%6vYB`oV8uT;Z({B5#>eNS#>cCGtOl9DfW<nH0*smlq!?@+sGfpN
zwu8$>O~zYHnJL(&pF!IzG7^h3;^Wnk?8B%AAWCq15M(37g9N<?S{(%nS}i2|Fjid@
zfmGnOj->DeSqKU*UAz{8RG<`mpn@LcEpUi}Z^M%S)!v}Z63w7Z4vf7_pxJfMq4(e`
zh;%?jAS37|PUc_+1Mt>YP1eMN$Rk&fOSHhHd|_#3a<)QAD&&lDa6tjiNks~Y>4~87
zLm?3?3#ubPnO?y?KOfRM0w3amI14y457atU$jwYH$_E)&3~B@xmnNZ9IprCkatw4V
zF?j22X@Nox=uDy_$caitNL^**<KsacH!#)(I|Xtwg@P`)#Rxj>8|G5*GzFsl2=*Un
zDR)V72E52s(1qCLn3IEc?mT4jN)yyn%t=fK84jA-0@1KGAUI$kwkJS_NsCG$=M;iH
zjOa|`7+(W94W-A9aFv3B0_Yt1q7ra$>48TBQ;Ri}3=Kg2WU%KI6cko6f{VluH$P2g
zNWls^(*}H!jV5H4^A;D#DG)b;)uOi{L1m5sC;@_!E(0GEqY&t}WQ?{Q)B(R3m6Jj1
zJ3ymdAPhRw2VMz(U}9hZ7kQu^c1k5oCCs25b&#XG7qBm6Xl8<rw=#qGikXyffVRlg
zGS_gVFqSeDIhAl`ae*#4$>Of%OlPR&N@u9$PGPF$Dd7O!E4zTFgg1o+H2S)LuY`Xg
zV=ZqAYb_sW^U?&S*n(RA8s-$xoN8YU^8$ey{uH)_OvTe`xQiCm@E0$t;a(tE!w+f>
z6_(WS7q2KRso^f#mBNz3vOuVYdm*DZLmpEKdkud&Q>_5V)+(hM-UY%n{0l^C_!crQ
zWUK|<mn&MsU&EBb(aTgT7|xLQgN30)YyxBD97cv(Ax4I(StSfLLM7tOpp8IWDV!kl
zYK2o+YWT}QTaNr{1QrOENYn^rN!IX#4nt#P0Ewh<l}N$FQn)1;L>N+d#2IRY#lcOt
zJPC*zkP1{8usClCON|g{c{s>lH9Qj-^BZc|YI$meK<)$Ge_1P3Cp3XEPa%a7#4=!D
zVJMNFz*zZ!k)c+Ek)cWlYzkiqON|JMDaXL3h`>z|sT0Y&lfqalQYQjxw191TQ^Ur?
zP|H)p4hr)LOht>Tf@;`n_-h24nQBFAM4_TqB@8v9B{I!S6PSv$K(^J0E|6Ua@f#nA
zU&2x&3W`xihCDF8Mi3?+&X5-Zb}v)qJVu6EF-C?eE0B&F!7SMtmK6S8$SAzP0>Ko4
z1#&g)S@I<cHDb+-S@Jbv3z<P70=|2gu~w{3ERQP%OoLpXCxpcm)(N1ydRZng6`caf
zrm%zbgN}V&AXFo;kP)<6sfG)bf@%cQz^jW2OF)Ogf^XjyOf2R_9#_P7^m~4uLZU)(
zY7yuFH_*0cP+0{%EkFl6f&rQcNKHg4oj{ov(m4f}HK5`D;?kUwVo=ksJR=pn?*(+X
z0_c40w8YGu)D%61KyV2TS{;&_SX`-4o>-|+k`FIgib_F_0Gp-&Dt{ndYox**w15Cy
zR43*Z<fKB2dF06gJS8z`Oa-wS9C~0!D!7n_83Y+rfNTZ<R}hc@0NDugEKC{Py|gT!
zVZ|tDBnUFcfK~;lE2~4U9zhBz&;V#=UP>nDE|<J?1^8L3uxTCGwj+>l5WWCg1@Wr2
z0=OOlEd>HqCMl5lW%x8nT4qj3D#}^0pc<$&C&#5Uw*bw3h$<=tBw3USNgRpA;KKk>
z&W?h~f!fjF8R@*#;u6SoJ180uXSRS{3OaKIymSO~!vN@p5|Hsw9iRk)@R+Uwc&rw>
zhysWEz)FfC=>R%l2b!)dNy#ro%ou{anV6YVT9g`+T3iB3O31gsfL#NM3~1P=!mbP`
zhNLgZ@w=%N1*yp(Z<XXLfbs*lZbu%610^TeUH52?1w{zR0{CGypmh^TiOJdEb_00W
zthgAovH_BLpaE(P9`FGT&>|+8AwigsmZt$q1o4n)hn_GV57noc03NR@0-xeg3@R7E
z=NN)gL{ci~79!A558wmvk%J96+(F$SWG}$>LTW0&eE?FTo0FNH3hn2COoxn}fgA>1
zY5`lp1KyNYlA4DlDS(0ow8AJS2Q+X18YBaml#ozdS*%wKj>UuoL~93ntAv$8qJjoA
z*g(7B!D&+yveOE5e*~!Xf=Yvyet|L+c%eyRi2~>t36KkmVWX8uxBF=17lES|w1@$;
zlnE5gurvc%(geyCpd-%mQo!Sn&;W-`SSuh3C{V%&H%l?fT=imT;2?a3qYVey5Eu_C
zAQWsB;7c#!LB&CSo*qP6544a8eQpHeE(KfYo<gt@dPSvq;MA|7uC9)VY)FDqP*y0-
z0}Yshyq*WX1qnlmp@9L0n6d(V(;IY}2t$c3c716%`H9f0I*OAsLBj%RnaQ9vhTvmy
zFibJiGcZauGR6>BhD|Sl2T2u(G0HGi*U$*VAa!+h)Y$}Z!J?rQT$&6zFi;6pY(auG
z+8|aTHK#aLLCFnVEh-|<E`fp*qKvfAFD@xctOQT+fLAhLIM2|)APPfJSs^#G7(8>3
zlbQ(b<)mb$XO_TLX{hUA#<Q*-_UI_d2OWBtSE+zald+zmiJqaUC58jk)zx*tIR=(X
zAU7PKs3R{N!MZSJ=?J7!bgxAl8W_YPvKc6D2qajH#2O6}!7zh_#EUKAMuP>ljf^o2
zhGrt-5;JB(js^>%nF>w8=;44b#bHZrsOO5iIePk7DZu9`L8sM&o1GOU3h<dqWAqs|
z6Ql_?NMw+delgQ7UN==2r6%S;OF*0fs!#*EpA4?7Mgg@DtVQ_70Npo+7{0-oiEw5h
zydJ<BsMw}|QSuu`bc41SK`MGkYXNc%T2d<L#+gI~Q1OwIssO65^b}AoJIaS>N`$tX
zA=}%F3lj5+Ax-Rp9K?tWNPDpkbVds{j00{RfCfse&`z-e)o8HlNTWyzqy#h=3>p22
z0iQ|?acVKLr7?L5#$b0ABNw<Dh-K^ubBYqnVXn>rZ6!&}fn4VU+BB*FJKzB{91SZs
z)r-{i5XHY=$S<atyrM4*3=E~9A+h(n_q&0YgBNXMVqmCZ*Kl(TarDtFdIy?f0$&jN
z9yCe72FVmv0w7w~HNx37AjH$(&kD58bOC5_xk$A^Ex5Q$O|ep_HmtQ$s5YwAR74u4
z1s@{}K0z3~;`}jaY@4kJ6c`1!xWGr)fkV0obPI6NBCsr^k#vg{yzjqA0yNHB3v$<d
z5UUEr0*%8!F8Ku?Pz*XV_!e6Z*igvG4tU7i5u`K&M1YRAF9K}|E&^Rc3OOosDI)_z
z5qO<DcvBB(7q+H2cpvyJR&a9)JOXr!9n>~S%`3UZ0lG^F)UCM111`#;jrdzU$Ze`3
z4bY%F3#ci1iw&$S{uWnaP7X{l2h_CUTkO!*T+wpS4sT{Be_zPifZ*ej*&r1z<lfU$
zARmB^O1{NWP!L}R+9wV<wI4k83?{&nV;r#NkPB#pDi1W`l)%L(0X{$<v;iD+0vF^&
zLC_Gm3?mmK6C>!*eJK#hB)}-dD8MMf$i*ncsKO+{D8$IcD8&d8<zkd#;sL7$4V&{Y
z3NQ&Ufz%2ynlK45foA+b8^i^e&?ll`&e3FagP{;j#t==W5C~>0iUp17gJk_c;*5S^
zWg(jEAw@fw7#KoA-2D7BgNwk?1Dc^M5(I_BYY=fC6nUVL<sx1X>k)`}3L@TsWWo3S
zfNl&g$^nTnfYJ>Mh+qT}LLg!ZNF6w7NrJf2AVL8|fUj8i2$BUwCFEvXGmwNih>!)D
z=L%x^f(Y<Uf#4fnLF0Typ&&8v4X^Oq1B+rnVsRiM0Yrc%bZ&9P`#MI%d-{by&T9oF
z-=Y$bEa?2lBG55vMW8diikd-UtstTwL`(n?lR(5|5HSTrOa&3sK*V$qF#|+^_M(CJ
zWfaW>ac6;uIUr&#h?oZ=z*z}AjSiX?2hUZ5XOSWIPk<&Qi<X1btpgDoK*UB6u^B{c
z0TEk4L=K2J10ukw5J7;_BlwC6cUA_5V$d)v=$;1_MiwR}MlOCPMlMk%MlMz^aSmAy
zelBq?PA*{%Lk=zuNe*5PUJf2EW)2pva1J&O4goPPMj=@NSr$e%Mh+G(aj<?CP@?5g
z;<DoN;xOP*;FIJ~<KXAu;o#x$;$VidKs+7}HV#$}6)q7Db`DN3l;Ggv(&k|1VCG=u
zVCG`u664?m^O!l9xkSL%CI17v8gxu8DEq)MXnGpNDF*GTPi2T=Oks#(O5ti}NCO`;
z)xsIY47t!DiY0|Dg}sF#iWPEPR1{k~0}DeGdoY70cM)j+z8l8u1juYqkz5R#Br9P6
z9ahlH1iGS^k)edShOvYNbUkA;;{sOD5e5rE*H(b8bYiPvhzDKP#1PL>0}_MW;m+(=
z1UfeT7c*$t1lKLr;?jcDBCx$h;Oqb{f<Y>ZHi1$&cvfE#RQ|9f<|Sw37Zpte<w(e2
zc+oykS_cWNWQ1&f1jjEpYC(p*0+ll0ad1XHMhVa*9gJ0?$OjDSfi`YtmY{9#0WC0w
zdpQQW$hett0b>f|LdF!(pf^(oLl#q!ANaa^hFWHDAVV*^?_kJcu3>5h-CE2H8i<Cn
zSr#%nG1P#MnuDkihw?Pp{ff?k(q|*KE7n2I03YQH3K7t(P>~pj1YN6@!k7*^G)$w0
zA%)470W?XO!VI~E9<)k9lf@5Gd4kq2+~SCb9^$CUTyzO!8Tj~o(1r9xvp}H?4mL0W
z4m(hYegTCYXilDiQH+s|u}U2++`y;vAx?V+Rq|j<P$mmO6NR9J12VPP2DBiSA&UXx
zc+g$cpi{=cp0I#8e<5QnV+u<Na|ig=YRCy_H4G`tkUOh2+5C#8gIv2CM1Z_e#R+T5
z+7$JHR{pc1`%W5^KrVn%3=_ESy2TC+2&5@WkmGJ~f>ua@J@5nJaZtrX$m4K*nyf|O
zV-mqdIVc2+K=y*$1}G<`KwSVy$VFE`u>lTw@B$r>Tfn93N02K(yMY<N6F3|!JS+l?
zT>qIEnf|jdSBYSY43v-uMLP(CClx`_2ue24DN{|xB5<|>+X%KBOn~hMt<z!TW?(1=
zMIC5K5SmRzn9FoPDnZyCbT$!a2{32_GxEk|C(x!`&~8Z3W=P~gYS1n<&=M=infRc=
za?q)tA^EV2Oh8Rm$auCUBe+?#60!uP2z+rn*wJ7D>~c_r$b#f@F%*}B$M`_UpnxiH
z4)h8eR9Jw69a6)9jJm}e9}m8)I5{;ZCq5o&n(ZPe%D`5FO3UY<hyqRDaxn9;a|m!S
zgUd3E;u(|+z{Rry0|NuRcxH@(lpRbd%q<*IEZ~Be6?Fe>5om8iRitAQsKc0C0$-$v
zvVtf<p|~^&>_*VF0!5&qyiCx^s0xWC`MH_N;0_9So(~kVpk?@}MX*aiG13aieIQ&6
z+NJ|5;<K1Q1$r+dBLk>NS;_1N+BWnXl+l=r&Vxb$<Vr}f4NgnokU_)<C{%fnVuUXw
zKRY!KUgoZ3Lyrb<y9uPL=sL)But{J7Y%n;;K{j%L%mkH;9E>c?;E<v?xIx8hmAYe|
zLTYY7321&LJ2ekFK$@6So>&PwEw3aw1F|Xyci^djD+}cMF$J{JA99rwOA2W1KPxCG
zL8UXu$`ChAHb_W<c#x0;Rdz)mK;_m~5P>UTg+YM;N_Pz4)9%?AtN2_&ZifeN(JfqI
z2(n86q#YWDOyC+BcNl8nNwO*IpbHLL7^7Ihi5GNjAxDupsAHz=r~tm`1JauWUq+Od
zT9#S_*{nb)Btdq<k|Cs}fh8naY8c|#z~Ra22evfCtx7O751i(~>rTNA&}4@MG00U|
zgZLZ1aFzuH6s!#a>PfIMRtfm!gO~Bb!#V_G8wjWk0WNz%WjJUO9n=KMVyt0kW@%ys
zIT^BChN%dAHyYRls;Kb=PVS(RNCo5qPyx%pSS1Lv8L2!AS;>w&BY_OSotr>GA_X!Y
zR6}quvM}+mgTs-EX#vz}PQ1j(zyQwtplOEGibU{*v*2g~O_UTs?{b8W9zYj~U>To>
zAFQ2}lbC^ibu2_o0k#(j%tdSnBB(VjKOd|Gc2jJ$I+#nm3Gf?h;cKgrhU%0+hABZt
z1KskA6hK$P=w{|2wrGL_BQq~u2fVx*wjjkhu{bp+wYV7Sdf3iukO|qTmEe64FpUZt
zkfRO3f=NZGiP^9bY0%6u<f0qU;0sti{F*K3LP1ak4YSi5VsHXzN*X2xa|cWgntQ>C
z5>%@(Fo0S;;A`Q*mB>7dauBo^FP<5)V6KKCp0$b(bm_Y!XelpSI76NW3quKeWe8+t
zQwc{FX9`mZ7pQp+I@+v+yM`g22eO1Sg|&niw41M)Q4FM)F9p=o;1dV2`BT_y7~%!M
zq+kt07HbMeHdE285+U$XJ<y7jStY_ClR()|lhY4;0ArO=UMc8|bI4>JXd)LfPX`Tg
z@a|^?aKWmfsQ_9om716WKI#B`K=v;dCDmf3BGB%BH}Fk~nj(<029)Z-Wz8*CaDW$q
z4llUH0cQK8=H220pF0RHL_nKRi;O@;5aMhD@HyI`Vj9w`SpjPBg6jovL4l|oKqEr8
zgyMrU^U`xtK?Xsc4Q(gg;s#p?T`dHzM8VZ5xM%^@vu2>Y4{DJ>DiP3d3m+p7Xc^^y
zHYOfM&>4JejBG4oj8y_qlZh$v96$|y#u_G2>}D}!GZpF7FfL%MVaQ?vExaw#0T+eL
zpg7B70<F0Kr3$bZD|+$BR&*a!D1zD~MR!50dmw^vk?95U7pP2QV3c7LV5|~^xgNRL
zEV>Oc3>+X}0vtZzpaI362FwT!MiyQk5%Az2)?yLlTX3rh-l}5-o$K7f2<mVLGib6E
zJphdq;jSSJ(1S~+hAD*+96XHR-~rwA$OKCCNWlX>F_HxmJm8Qa94G-WAAus9kFiPy
zGu=RTe1e+Epy95SEa>$LxHbU?7J>kW7|4tMAoD>*0tX}5%NU^rYHol^i(*hC4jx*J
zQOv0<DNN#^0SP{MPnt7|ErlOEK*1Qr4i@D~;cnrG;z;F8;Ys0bVQ6NI;sQ50xPuuq
z1&RzA7#I>8nMtT-AonUji&4;;oJ7PqvYDXMO^ZQudJ37jxv43ci6yByl_={k5*70D
z^K_xw5p#%o3JT8oxdn+ukYRdI4+q|OhbF=V*uXsKupg+HhEisl66nNUa61W{Yr%8f
zu%YsV1og}`&;cHqdEjO}`0yF^%rwWm6#u-ON>7j+q)-N*J_IeNQBBRuFR@n01Wo_u
z<Ur0Hz_16!Y>0IVV5=1>Yz@^x*Ij~7BT~;y)2OtyHPTdvEfa7|PEIW-DOM;c&qu6Q
zNY2kIE-5NaF3B%aK%4@TnFm@8kqJ6x3Dg=W$$*3uEF?iA<az1HL6n)2npXlU+(1_g
zWg;!D$WKFrJ9N^bJijz21$5~%c#8qdJ75z)*F_g0X#ii{30nF9>K%dZAIr&s>>JE0
z%}p)JOfCi;6cVolTGatFM@a>G*9s`+Kvg)XZU!Azos*Ma4m$0mI2A{w4%_md2|7gu
zy7UEiI|m+p;0?M;Xxl8Ig7B6On2)r1kO<wGdFe{9h7P>BLU!u}YGDE-0sdl&SMhVh
zDDFUA6>!@CG<Ad8vaexE0bKzkQ^J_VTnj4f7~)w<SV33(fZF#+Ed};)hCC$}h7yj-
z7-&m@Gm9&Qse~KWQh>D)Y8bLu!0iJbaQgtX29qJ47u+)71C#tUpuU(u4Rg`F8pZ{J
z3qkD%p&BL-tCp!m7<9#L4MV&LxTU~>zoh{6J%N@&(H&4_18yj2ibC25pdt&>Mi6yz
zb#n~$35oZ1jSTk>a*22La108D)OetVLlL;z16PIE8VXoi2Ddn1$@3O#Dd-NuTf8s<
zaHcQ%4VuQ{0%r_x)`IQ{FM0%W=1UOq3`BtIL~vOTF6KdPhGI}L4?5i#RE>ZqZNL*R
zuyz9v6X;|mNJj}YiNnEIB>)W~V%iRDj0_B*p{k-9(4A}GRso|p1L%x6P%jWv31%}D
zeX3yswHZLytYk4tFl4h9`+!w5WHE{}NHRcGvX(J|RHiUyGZkln<Wra=Fl0do?SZRW
zHc(ZYR|ZlCZnuE0Jop5XO<~GrDqd8>xPYUEA&U*%g2A-^1V|r9HOPKY+Y`y|M<6+f
z-3S?oT9An#drLS$YHAp=xR9!NYtTRocM&)qzzN_vC`Mj@2ymhR#}c^i2d4~hBZ+V;
zpaT?rdZ22Ukqy*1`p?89_K%5~?JpCH$R8$FA!g7>xxjxWCLxF@v%p^_76GOzL0BZh
zn@}jjAfS35l)XV1yg3Isi-T^M$YQQxjAyBVAFs@clnHV`t>330kAeK82_59y4{G(I
zB|wnM*&rW48h3n*9E?>wFqeTAWuZ6<Gyn>67`P)2>ciJClrY3Ig0}Z)GF9ndKWYYQ
z8n~uFECB?a-vrLEU}ru6IT)NRzyv67+!6zC%mnW^g&G0QSPMX|1v!F&rAiJe0owlW
zl8T{JlgZBwG|R|?-s}R8i-GPWECSmO%7sPXrWhzVAk&MlK%s|o)C}bE2#`bg7#J8h
z7+EAZnD|7wgn3w*7{M(kjHVhW8bN8K7&H!p+*AWM#h}BLSjT?UK@G7q<o-Umz`@eb
z*HOp>9i#%PenDjuXvHw(l2qu4GN3gER^V0;*aYxdDd07SkOhv=ak->a*aBUcA)sC^
z_^w27wGGw_9a+#(@beD=n~1Cya+VJ0#zEXQGUD6=SXUU{aC7!`QPM=KqLXt|6r6os
z6r6KY3=Ndv=c73Lx`58aN1~vshBTb>^Gb?9S4@B#jHwlnwc4Pi$vC^<kd+gl31(14
zfiWnVfg0JM*aOc4A~InO;{s;LN_}uooFxU+AA{79tSO+*1uLi&gpQ^$`&F@kj^PJ)
zY+=J^poj%mS4E(5=oSxTr7N^=iKv1ef)XNHt_3C7jiBTQY6LJaiZHP;@-S9OIHQhk
z5K}#XI$PkP669nCXvM$?s=l+Bz#UDfIH;lk7pyE`)eKo!x|WDC6<mnE205H?`MCq+
z4@l_)?pjKs`vP7*YBGl4?qY&Ma~aGi4n`I(9`+)T7)DM6#V06oi$UkfAm_vsR&ZWq
zPGM=`M4CEaD^dfEzFq|<ewf=7%2L6*kwJM3mY|?z5o}Be%WxZJqKE3yP;w?K(UYFq
zp}8ypx=zRsV`>^S&I(TMpbeq0<emj;L_+2+K-YbN&OK)K3t7nsu1htca~Ggs0;gx_
z&MKs)50>P6928fe{KbHjaG}8gPq><lez-^7LH6whnF5MY4n`JEa75vbZ_w}$N_=x5
z$9D=RcorXd+?}ha7gYAnVP#-&R47X<%1i|JvGVgUI-sC4gpxBL1M#WF3QFMZze+GZ
zWbZKe+>Oj)9ca-Bz05DML?Ji7xI{rcPaU)j7F@W33-FA@BJdhoXxR-*WX_<C#o%GC
z1cj2s?9^h=0{+C@)RNSqV&py^*dXY_`h)}pU8t>~4q{R&)M3y=YCwIj+{6ms%wn*n
zR8X%_S3x5o0oup1H3TjC$GG1GoF5bv;I2+B2CYg5-^5*#uaKNynpXlD5dfPC=?j6*
zBY`Y)Dpmj;bqK1&O2I3W5!(j99d^*><-|<Ler~XS&>&)J1!OM-SSP4bf>bn+4lbx$
z39g9{bDyA{9PkZ6D1n3ORm6ICkf8<n#o)d)B!VDrfcrJEBsl{bs-XRhMXAW%F9$8y
zN4kU^6tMY4ndzB%i8<gn02vPxfW!gJEbxJa;9x@xb%1s_LU)vcG$MNz5}M$%LUWP*
z0_x1errbcgP(Y(FsYs!yP!2k=IZpvRV*vIPIB;=S)1XOC1zQC~s?$(%3~_c0advlf
z3~_gNL^@;%q!cpT1*yW2R7QYRLM9S4qSfIhfW$#pc~`3=e4%co5FKq98>^$B4ht%f
z5JD5kTJ_jkNNo*Te~aDX2#^y&7Qk8y@NPNMECQOT3L4<nLTLdgn;0TRttOERXq6!$
z3yE8B_~LdTQW#=}48)T<3K$_nOu)b`R)(BI0C5f^cY?|mi2sa`{0G+o3QN544ZfWW
zQB>F>otp&Gi<tm0;sKff;Nn;lfQgO*(P;oYPk>R6f$A_2E{2@*k35A8Zm=<fNfuCt
zIGz>Kcms7N)0n`+9BiN_Ts%9N<Nyy^F#A=h!550F7NH~+)fA+#)O6G2gmlF~wFkID
zECRLWZt;Ng8Z^h>;zcQPi@@^`;Q49LWCW}ReG6(ry#o<gYS7o9x)0R<0F4_!#s@%K
zldFUgxfNcKqRyv+R#$@Rd2l!G7-+Pdsg?yar`im<o*l$u$YKO-d97uuVXI-yW-QtS
z>R#8fr!dxXq%+iVf~Fp7xj@^O!L30y&~QQxJ81i|3q!0?3{x#fEq4uf3{x#nEpH7^
z4R1Dckxvch0@fN1(8kdch8oUh#u~0{mLeZUhQdvSJ~bSm@#<Qp61Ez~8kQRHeU0gi
z&5X5tHS9Hfp!G^MoHcwYEH(@^Of`Jqb|`2e9H?!|f#~3CvO)%yzzO0O2dwzG#f2zc
zG&#W&M@5K${R8S0Zv+wGvkXD01u=!J$q!x}T(lR|Jq0f)<^rwtWd)BA7Ab?+Y`KXQ
zIr+(86L0Y&M=?kgwBx%76oI#xi{o=|F&7sl-(t>9EV;!Ftp<^n!GJow;9lq#P{cw8
zgjg6k82Ok$gF>KHylhNzj2xg#n?O@aOdO0tU>*lkl?YOlBQ=-70fD#G3`(M>K-Pg8
z;2exB3VfX4Mh`|S3M3D1HG}SKKxswsf?H9b6_A`!EGc{`oGDz8)eC8iDcmVMEgVSe
zA^D5^K`p8XPS~_UT0V670;pU9&9oMSws{tS4^IIdtpFMaPE7$19e`Uy3dN}<&=!#k
z_%P8F=$;73bR)Fc05S};Lk@h&BX}=ZW=UpZ4#F7F*<O%wfA~&7Xe$EM1aNC6DL(~i
zPgAjiMrN8qKJ;L2aKQ;}CxI_Cht$+))`46N-EWtehZxS!&CCN`nFnbeLfcp1<74#m
zi=Y)rPHJ9yNe1|wWAI@@py74sC2XLeOGwDg1RYTiy=vM}K_gKCYARHfje;R)Qv&GT
zV(<vQCg_4cG^4-=8-ab2kdT{L0UCeLO93BHpO{<%;uWPT80aYErY3?HL*;??SV1oP
zgSiu|8RAxjqEt{&CWD&FdJ2w6-UVGRkepMR0-jd|H8Kkliy$pmh2%s?Y=GJ<NU;Q2
z>5`k7o&laY0ynK-gA<VEP(lJIcEIC8(9_*OmV*w3EiFz3wJA&TA*;Aj6%rLd=?m0h
z10@acI(^WR7SO5wps5xGP<ZC&fzAv9`vx@ek_>NzL)L?VrmI1xp+VbAur_&dQDR<t
zD)<mHsI4Hgzz5HQQetvxaY=qI!dsx!0Bw##hQm-)CnSImPD4I9tr)b10b~-`9{BD;
za0?pjR?MqGQEh{5PIm-luH5`QP;CY3Jb+S0Nj}N~39#j$<`1|e1GUc~i%F6dpj%MD
z7D5792h_gL1RZ||(xsu~n37VIT3ig8cGFV`O3elB{4RpTAuOms3L#g(loo^cvcmSy
z!{@U=c7ua1RY41s*|k7126hZ6wh;b;mI5K5^S=?x8WkY(RbcfBAO|VwC@48PI)bPa
z$D-5}CCK*ryh;V|>A&DK0rpaEVoIt)X#vPKP##7^y@I+UXpAWZL==IDRCRDBRZuTh
z*HZ`qWrmXE3<YQk2DhwXVFit4Q1qo@_8Iew;9}5zFKp-lzDZUAy340nAtN=XAQf~K
zHfZBJIKwKy4}}2*DpKbU7S`ZXH;W;mt)L6H3v}`+h9FoiR+)^{3asK_9mN(&nI#Dd
z8emRRYDs1?QUrl=s$;OTr>6oW-5MHM=o*=tf<s$DK|xm`F*!Lk4}85rNoGz8=m4$K
z+?>Qxut;i2GIWRn$>{~9dC5>4L372#*b1`^YB}g21IRt3l{yN=mAOgzIiManXvutW
za#3bMNwJPXN@ikmQD#YIaw13$yF-dH^GZPJu^8m}yh`xYHPUhS@YJIT>8W8E3sQy^
zNXhxR@cItC@fA`ifI1GaeU!EepeWV=#RF*QGqtcZvn(+uHLnDeS-?_C28Kq)CZ=ZQ
z7M4nypoK<YQAok0p=6+IsiX;Y3dmfz-Qey{BIq(+@V?vR#DdHc&@MC33a6^nqI{4^
z;LBrk^2<|;Kx4eH@Kk`RjRzO1PzQn|q*$*MG(V;Rs_;OE%NFZ_HEW<cAS1uH1k^u=
zoJs)J2%RPdtr9KCfV&AS1<i1}h@HSN{R${n>%b?RL6gnuy6PyNF3QhM%mZzuOf5>x
zQP2R@iI8o9$t4QlR#TA<I8B1)-81vR)ulpiW(BB7fJbOCqTdNI4r;%WXIO-fvx_hC
zraonb#Joyq82~Z_lxDFdl42d`wY}gvNL>fv%jDuR$mTDYHxbnqSP#55wN=uAcE$a`
zjXv;FEVpFv@Gz*^2AZXSVsNJjw0R0PxCffuV`S)HDDnes6liAbWJqCLzyfa7f#)Sa
zCkTPgps8i70d3KM$+3WzSl2MQFo5Mi1B49mtf1X1pjpItwi>3Q5^(2=y#%y<1GH+F
zBToR_=>mx`f>m+Uu%xhNgI1k#)-b2AWiu4bE8$9E2d#An&nI(3<cqe{fYk8hv4PgA
z#q-p#f^-#~t6>GLJ_D27C48V&X*CS-{3)P$MSk$;yFdzO4MV(O4QS_#Pzo2QgIB|l
z#V*cJ#yEko=pNWk(0N4n!1h2`AhRJXhAeiF4)BHL4k_HAwQgCg&~<Vmc^)OAAlYWd
z6gIGmycC`iu?6BFv4xCawd~D|(C(y2o>U4iSd6t9L#~D)O9*s{dJ10+Lzaj*LkeW|
zok*2XiP!?r$z>u7L7^uW&X5PX4@`0bW91phY(4nkPO(UaJRt+n9IsfGR1HJCbcsw2
zL%b}w)5;Iovw|{*2O4t)r2%8m?gG#tZw*7N5a{OP4u&$uBBmNfv|EoMJ(PWrn{;_n
zD-caMhzz*f0=oX#gNK2k2(&u43S3;l`<{qBE%0lPspO!dAE2%=e8#W{<O(mCE5KO*
zoEfU3k`wblxgB!QBj`GISR)zQX0=f;ge*6J-4Cn*E<ZIjLFXla3PN3|LU3u9S*%cy
zS_J6<fM;~vz<X$`Sff>oW3{W;Rf|Ckttw6s1;ScYOfgBCa*$C0P!9+)DgatCPz2h{
zdW#oyNGP}!>tB?aev1>%y~PV}-$G>IT+nbrMKGjsmYP!31L=!q=7APNg8HOBsd+_b
zLBWHz))6$uaEmjs7~15xB^IAroSayY8kCxzS`h?l$b#K*i=!wNGL8r7Fi!?8Z(xHc
z1@Dh7$jnIvZy^D%ssJgE2e-Ozam9ne4s0BFv85&lq!0ZY<e0x8XENtz=7D;_6}MQy
z&7~qnW(J0$pCEbgFb6nR!O03V&*j3yz)%d@#|s+f0QH9@7+Dx47}*%P7(rVEd6?K3
zxtO?^I6zky!$~$qHt@yAAliVD54_Knhmqqy7c&<l$A1nc4n_ec&`EB5j66(Sj8(iK
zC&Lpg>R<_ImnVF%<PT`D1ilipjIl@#bgCezoXcW@3`Ep0)v|z=8=5oJGC@kiT2|2N
znOZhb8J5K=&QQx<!dAmx!`jSL%U;7&!=BAh1YS)c$xy>q24XX%FoJX!`lK+`f_D0`
zNPu!TNL^D3b1g?+SPerKN714hrW)34hN4BFAsDFMMPPZe8ip*+q8l|V;QRj$fQD33
z7(pvFK;{=;f$F<~r0)huUkyjm8%*DTbVCMYK*KJeAr{bjBexK6_R{1k0!J%imJhs;
z0u;+d44_Em01^K|G5ZfhfFfFx6OtZK$5e_wg5<#?Dx9D+4ytgAi#~yp3tve_QGPjm
z_!d&?ATm8@-o6%;MnES$g3^cp6DXB{#!Ntamqi%4m{`C&I;6lS6-zL({bvGg{9<BZ
z0-Xn4#RraiaQzQjr-@NCf$C6Dd0AY-z`#%?fLv=rkGy5BRDzVpkkwM4*aok^$^&io
zX<?`Z%?yLm09!V5QCtdm;1N`hfa=05Hh3Muk|&S?np|Z7$$<wUSwJQQGib8<p*RY(
z2m|CG@HR%s1{qM*2fhkYriLMf0dl1yXhbcT0d%S}xGG@wdkLB+gKUj-U;^EXUbG%G
z>;(=<FagSPx46I|?^qmMQnU~hs^EbiM$is$c(D#X#2QhmBQ#WTg<EN;7V9Xe7Hd|q
zf!Ug{*=}&L2Ra`cQfPqp%l!hy`5(w;!V4g`@Pm>IxD0?h2)s{uCdehAs)d1(39^V9
zl;hcW7-g6Qn5uZdF&GaTS&feeZE6IiP;mML6K>$8w-{U0z-vH21q^u14QvhWeH|dz
z^Mf1#N(~&0EGB%GTr%LnER2ydP}G2C)$uQ3W(TdTMOo7aDq}#{8B{NufXW&0-FKk%
zQMD{JEX4{Kd6NaS0s(YuXAR2&mW2$U{0Z3v!&<}!3P^aayv3ZFmvW0Wy(qu50Je1!
zE&H7UMFlv}!2~ENfWu`y$kU*eJ`9XJjG+9&!B{1NDB&UF{h)jU3gn{4sHPx{0(o~G
z$S6?jgM+aM#K#CZQ2GQlRxxMh*}$z)mK0W$nR)giP!_0~><Bs<u&6{AbORuG_a3+%
z4IV@QjhaA4R5U=z6g-9qZf++gm)II=CL}-x-@teC!ZkooKm|3~!3}uuW&lLT7SykW
z^c(Wh74p--JtBnRkTsibekgGZ@);;2fzk%JE`yaKpo#Sq#u}y?<`kx07Dk2?<`U)<
zmIa`k&k8zM5nK*{+R}C@;1UGFFJXtQoddTEL2Xp_EKoa_3!Kr}AUyz0<{~aoA^;V+
z;JWn}3#cgq-osqQ7L%k}9FwHU4QY~qf)UarVFGCZHAx`lIx~n1s``sqK`ijH4p7p9
zE^fTV4)S+#Y6*G`j)-_r2HOjYc+fsp21W@+F-8_f9!5UKDqc`K177E9GP&WI>IXS+
z2gnpqKyom$uz+J8cLD+}?Lrx(7DP@!DMBgiDIB0d>J(w<a5Y<s2zam>wl<zOg%7kg
zK7~I;poJld6TB{-E0{r3v<S2*H!*_+>i{-nSPZ&y8r&LENK^o?oKk=e(SZ{SVz^3A
z0oy1xw3!M@yP%;cs8-~CzR*SMiJ*j@3p#E-KRqwA3UQrBaY;%}W|BfcWl2VUo`OOG
zXr4Mhr8Fm1!6u`mq@dVJUq2;3xmd3NtUxcnC|%!JKPNM(D6yzgzbI8Nqa-)SE+HP0
zmOUYtW5E59S^+yLt{8j|MT!ErU@2Arokj>gGaqsfNJ4^!eSi(9lWzw)njj$ox;F}P
z6(x9@KPgoKbbn%MQCVsVXfP3^7<9WI=(JAg1POGk)iVvYSqPLZLBRs`9Mr1_A6Dj<
zDwJmyXMn~=K-;hq6;d+O(o%~+!zDqk&>R22@c=q|F9T#P$hd?ePy;vtDz6DSX$N%E
zNl_}~_F2%0WR(i3nI##iMToJt%KXwIuwmc^FYFXS=(q}KXa{uUs6vn{WEd1Q{SFs|
zgc8_V=;8z{!$hFdpYlpUw-A9X&?r)h*4B-+k4e#v(ThpZf_C~rgE}dRC8-Lw3Q%S0
zps=q@O)RpDNvSre)zk&?bMx~`GVEefVp8lO0x5}=P%hH3amorsscBXUu!K@vl9-&G
zUzS>wmXlwumz<xgUswt{{5n6cSl`IZ+}P4mKO?_fHzi-UGQU(8oa%K!moVyr2T*ju
zqa?cEv7N-6VqH+k=qBny)3h!kD}VzL<PWe0gh!Nos||EaYBijFYn)wbT<oh2bc|~?
zH6omAB7ACm>?5Fj&xjh&u$nM?PY54%7zUIKz~KyyUF4*Mk$%9dFrfP^6cQof3Axz@
z?nKb|89W-HUO~#9aCMov1^GoKpuC@20T%?fG>bq-Ar|OCBMX%BKp_k2Q)v{bM;qu`
z#;U`{%OGu-WKh!pR5^k$hz)9pfU6VG$rG^Z1TvHZ>UNZ{G&2>o)G!w7fNo((VJu+>
z?V$o~{sT2TVF!p*$(3*|;0ARkKwSp#K_j3+5)RO?N;pH|9u|fY-YmY#21xT3Y!XWi
zqZk9iv?hi~hQd7t40#qM{56aztj$bCTfi(f5DRP<R}Etp2McIJ0N7kmXDOaDkE28Y
zI?%(A#g!#k!w@e78Xy4=3yFY-a74gEIHKSo9I+aP1wtuY3mH?mOF@Gn;^5&S2~d|R
zUb2QEOJV|J5oq`XJOEO|kR>^Ru}H3lAqzAVBAo)-(ZrL;0$M|x0X_^EGVKJ~Is#g>
zkXi(qLj#R@CM2ZgB&LJrra)I;LpCqMBd#PLyuK(Qp(qs|S)d(8X{CAK*)D~|V%^MQ
zJ%!*@$hAI@0t&93+(H<ZW<j$=&`AbRHc720$VtqDu1JHF(4g`30`Raj{0c+xswl9Z
zAZ0m7XO#i=9h%_82pI;!y+2b0HZTeeI0X&WVomUQy`U9Z`H<{#iybNp9vi4~2Ad4N
zrV&&yfOZqXcQU0yCvXuBsv?C%&@>e&FQkA9&itgT)Z`NAI1A{c5<g8@NV5f06+@aW
zb3vU4eMSa`BD5`^V$2K-w^+deP=sj5fSNV8c#DftL6>BJt~)9zzQvkaRFq#-6bLc|
zd^<M0u~UR)1O<Gaz%A~?Vs}uR+9$KP<Q98kF?e0xEfH`I2epYE5z^qs^eq7-DX?N#
zYaHaxB5_a~OA16tg9x;K5U3?}57Y(%buJj#_?RH$A1wbt7Xz|^M>9a}DlSHr|7=WL
zOd^bIjC_n7%p6Qy(2)=UaQ_#yet?6qiVqwo@a7kuA&(>yx*{bkH7t-TKx<iRSQfA?
zWB{!oDT=CL108Sg!VoJE!&J*&%TdEo!&<{`!%*k}8jL`6TsY7=E=7W%fB>(_5CX*{
zC%C1Nl9^mmWDnZRfqf_e+?N5}TYif%rN{ylp{5`L+$aST@ZJqKF9Sm{q+bc^-S9Ai
zj;#`4<YKJihlCM4&QO~4pyoWN90qsSEJz3=NN25<71ihHT{f`KZ?S>>Tf7o--wWC@
zlp?r4(T7B2m>C!(Kwjek)fVuM8wX>R6q=WiQYdcUk<=MwLH8L8);LuJMJzZnzyvr(
zWSJQl6fvF6!dNAS;cRg3!59{SSBjuJVn`aRu}fhr0r#+=<NKf<7z^m8dA}<5pj6PP
z27Dv~T<oBYWPp!F0%u}u$BTdzYk@q*2aXT;5C)?FQxz}7YtYdPl-&oQ>K&BCKy+~q
z0|P?`V-`aZXjdOo3S$W~tU?E!7S_br!I;Hb<WR!a!O+ZD<WRzx#RNL|35%K#a94;m
zg{_67mMM>~ouQpEjVXm4!tY>Qz+S@yx|&CmBe4_t29zN1Ioy!)9kS*oF%NW)Ut)4b
zDy+#4xi=8h@GdDz%qvdIFUkd1ncy4*U2UwO09qkZngd=OoSCKoIzv1)1=7F*byW0<
zOOrG}%|g(L*abPT<<goY^jwsSQbDGGJ23F-7fah3R2hP<$cqPccaU0~8ZqVCnpPTm
zTK1Y&pnL60lQfEyY+?-UVvKC`V+`$(8r>ixz;kjMaD(*Veus>oYba$HTIGTlGiR3M
zq*{SyVnNzqSQ&CYe6fO(O@^TzLZOX*hM^sFd#r+jLX|Fb5(Ctj1%;6&Bo@HQM+2!M
zf*f9qI8vd?61&DkaL|J$u~7{I=PZaJ82Jm75<ywD7?hA}7*ZG|85S^fFo4oakrb#v
zX1v9g3ch%IC1a5RXkd>KbiY+W4y1$vX)QX=z`)=Q$_${PAkcwWU>|@Y3^AlwkceS5
zC?kOM7lX<RP)1n5*uemC!a~qpQDEztAeFo&sJK^VW?)#!RHOnbXuyMuAdN*JBfw7Z
zLpVW`qX=B<qP87waR*oCl_XZUg4+e)8d(@LyahTy61F}QY&gh65dW!y>;l^Wa)Bwx
z1{qL}=LW6L1XasyOyDcE{<AT$F|jf7G4nB1al*Z?$qZ@ggSV_Pf{)GQ#=3D0)Di%<
zCyGD?eG#bGgbZJTY{fl>2`aaaff^8?$m3vS5$Dt8;^pGx;^g55k7{5Hr+}(Bkn@W{
z)f>ui3OBqA0j>GtfeojCMM3NTkk|b27P*4f{Heh%7ls^L18U8J`--4Z4wP{dP|G_d
zH77GS6Ld{MQl&y+X?_Vv6=<vpGJppi6F?a|0rlY#OaI|Z%i!x`z$;EbMuC@~AvQ$h
zrzt>IeJOw!Iv^~8tQ!Ma4BJr;$+2KF6re5yNkd!@FKBcXQj3#8V_TrLCa?u$pfV9M
zc?R}QYO#(&No7GMsPL;)09~O_oRe6LbmtOyECsaK&sG6`YXPbafu;E+sUUBFrT`Oj
zAjT>brxuo`<|U^h*_Q~~5RjCbl9HMNQ3N+f0k$>)J`fTd=%Wtm6)AykJ1xlv`6RI*
zRRP(EgaoC81jHf;1p+S31>L(2I_+0MS0O1sKPNRY4|bOUDD28JQo-XX;6Md!_|H=S
zoz0BoM6dy%dsaY(K*pG0;R4<Ek8q5xLTMh@B<Rt*`0WIx7;q8<^;}?kOCWJvoB=!b
z0BT?giZ?;`Cm;ucu0m>F3OGWb@eWB6pph!l(iZHj?2J@MRKb!N{CFW0XMir9NJvmn
zu(eYtPRvbJNJOk0Qh?|OIR`m-lJoP*Qj1E$Gcrq3iwhEyQ(eJxzo4r`pi<B%PXX;{
zf~rA^42^^Y^_UXyxfLK*9+(AQAq7fsiOD6Ui8(lQLKn$`(ladhzy@QfmkWy(Y!$%4
znF6gs)s>LOry%uhVX<CuYGP4x224p#aaKy2f)aQ^U?yk`78-_13dK1oS!tm06iDPM
zfV-DDsTJ{9EUK<n*FlL*TlLyn49h`-KM(`3I-<H7*%eCQB&k$ei|LT!!W?XlPy)H3
zI2jxSw(3flo`>keYBy#8K&p2oCD3wAP${6K1W6plNFf7`3UI)p+*S}Bt&Z#yut(Hm
z5l48T$wPgLM+MjfsDt3{fjS4K&Ce|aW8o5L1`5>pC<Yz83>xj~V1ON%3)zSZTEJ3l
z0J=^sg|UPU-t1*>W@uupVFORc+SM@DvgIk&uz{z|*lO5{6Ts?OFw`@4FvN3!ju2=D
zvA96vT9OPM4DsAGY#j{oJSChpY+xDQ8m110c)l9u4u*LC8rBYmc!3)B4$y)lmZBFW
zLRrEkLRlhCAf2KqY$ZYq#5x$VI2JONh<7k#@uaXyGBks(BV;ILEV@%74mu*E;9d%Q
z8nYNkheV!D3dls!6b^hkComRCLG(^wERaFyF5v{((ae~_nawhRv8bSffrTMUB84l3
zdx0dlng*Tu!%-rIP$$8V!kWU@%nVu3CC-q-FV0}jz{C(QQNuiev8WGff&j=hHOvbc
z#bC0a#ZvpAvVve)CWI`A-@%Z@w~#SKNF3xZX{btJs0<H6ZIwoe&;pqbhAfE=hAh#A
zps*E!@Zx1V7_x-2<T@DQ<--~B^jH{56tWa2FjeY7M<!XaSW`qmYQ-23u?ZTR%wsZO
zC{Y4+iaHqLl~Y7J7_yYX?ode)>tKjiO%d;4h*twooJsgqsescbsMG{4Ne3+%N`j2#
zK~AxR6zfP$Yju=zAKK2wrUf)-U&W(ZtYL2z9j98XS{w_Rh!cPd#pJ~lfrLSG*HtVv
z8unIItePMSr6mk%GqW==Fn||tLHgyfI<<@`3?&Sp_Auyt(Hch3Zk&aTpv8Qk=|xZ~
z11&>?F6&|hb!x$Dl;Tv2WBoK)AWdc#(C`WmvUiHWbAdIWrZl)ui)cQBmRT(XHEu!O
zZ5Ae`e<F-L|En~>#TB%~h7T+u+Vt?nUqzrZhkr3@R<VP;2U;q?0b%HARxxYnX;!gl
zYN-|%iGmu_e;FAV+(I<fAp?G(h9qRb4|Jsf`dFVD$P1kC7zD3dy2S(MgBC_XPKg6M
z6cout>L4xr$i4=tVuv>1ZgHd*Lki(re9(3Pv|({e0$N>S)TH3hyv6Ao>J#GW<LT#m
zi_OJ9#L>qGGPnl{Wk|S!#|pp`tu~;uxJ98>20<p90uoC~Qj7A6z_YHP(Ms?@Dr6u<
z0u(NiAOhF8By7c%CP<Mkh|mN1lM~#O0yU$G^g)6k&leehSm2RHa3q5}FQEQKB`AJD
zD_$6w_?RIhVr-y&NK7y`X#Euzcoi0?a|2pu1zKgp!^p!Z^pA@LbRGc@qu4(VX3(gk
z0F%f+4ko65O#j(f*}!YJKz9vDfyXR482P{}IzZhc4(Lc_l_)rh(9;si2o=h*ERc(#
z%b6I!2jofBFf3pMi7aF)kV#<xFQ702-Es|@eaK>lF4Y1ro2X@ij9G%0X|WZZ0xc&6
zFZ|@-1|O4C%UZ%&!&<`C%v5wLg|UXUjG<^=4MP@p(L7Ks13Cgeg>4QCXq<Ba&q4+l
zhFB5k7$@rj-Wv8Aj)hFMtc4vl3|V}jnUMtoH4IsTDeN_@3z@+-3W01~06KzEsD>d+
z7^E6DGN{SnS9FVkf#DY;C-@eRUyMAz7<n~Welf+A6zv4v;lUJ>R>c%kRK*&TZewVt
zDN>{jicZiBeGz=|2Y4j02sC^OiFPfJ5*-kM7&Ql{0?>#m<cxT5ngI`&gL{<5AjP00
z1kNuw)^EWFBX6;l7sux&7TjVjFV4v<0dYZ{Do76*QHX$+ZS4XjGSGo242*Kn#U&g}
zY|KJTTugjSOpIXohmB2uk&l^;Q2>OQs>D!|26$u%G}Mk#N`gvTP}u}-F}RVsY|8<>
z8x%Yk2r4&g7~+uz1NFe=NeZ;*1R9-6ECTmVK@*z_s>PtTBe-LeS&{)-1_eDT7hH0I
zh5?aQKY_C+I1_@i9yk*s!Uv@IE+~9Jy>+BzPmDrLRU#;103ABiWb^ZL3-JSu8x#qE
zVhn5+m;f6M&e|Y%1c6KijSO=zvZygIGW_Rr<WdHA(lJH=SU}x>(0U{sBLL79IVprj
z06?1=6G02Tuyp=GOKMSf{ehATq@%B(m6u<l1zB(dUVi{?rxvG{fVSV}<iNJaAayxF
zYGIu^By%#;K-;Fkmp+2`1A@%~bpQ*B^2;(oU1RXV=Hkr!Jn;4`U4`P*RL~wg&=sGW
zSeI#ljX>Qlr~taE5`D`ec&}j!s1FU_YY1I^3|V_LEI0n)+4cfnW(C@g2f7v~Q5SXx
zY6@t*Kq;sb3)(eNk^#y@&?7UzQJ1KIYhwhcCNK8OFY(ONP}jleszC>8Qd2;abQ<st
z6=>%RrDW$6>*N%tWM`%66dM{T7@O!gC@Sk185)CzYr#>CrFWzb(gxZR2GI#(K{SI{
z4vNYk%E-_ddXyk|EjoCJ4`VVPR8WC%aT~@tzo5b>9=v8W9<;8QDVw24tArJF-*Xda
z-55hWTMaXKov#CUN}N59tpqg9&JJDu8wH*sX9tsPC7hszqBRWhT;SDYT;K_I(DXlB
z3QIQVMiCycZM@*-Fq<Fb1m3DNXuB4=EJ*>e#T2?I9&`0PQj}n>p$BD4$dVz@{zJq{
zdQhnip61o$gEaR*r3R$A_ZHMf;>gQ~oLX4~TI^l~UR4ZUWQ=W@J7^bu5ooPDY=+ea
zR3w6zBXfdS;I(n!auHlYf(u7bE8;Jxa8v*ld*C(0pf(Q&Gnixok)U=C7bB>ZQzeY>
zB)qkYI*kfysDp;B!Bd12KvRT>mE#QfSB`^D?5hRsrU6$y;tY_}8=IMG*=m?-K>K8p
zK#dzoh8obBd`YnN=7labOf`_z;vh8*7%N7ZP*-yofe*c9F9L@RqQL+TC2+`sS95~`
zT9X~;qU~Ftcmc&}@h#B4gPhbnY*oD&9|Hq;MJ!^4HXEY|=<X>dKF~Cn2vTSgQK_ep
zTB*muX7|9$q=P^QJ7lrJmP&(HRkGyqfbJ8>VuSFYYp+@Sig=kB7^=7w!ONLJ3)!mJ
zA#C`BAUK_Z>T9IR9UOAtaK%-*tARoUl=zS<cRofjCLX3LA*9fNRqxD*@&jCmfcEv{
ztmi>adI?I(pk@#UBa1MfB$q%DNED-vmjESpP#vFub}Ip*c?%lf2Q8EYEs;#&P2mGA
zi%bzr5lRtG5lInE5lazIkw}r8BOb+)q68jXkWG<m;f!KUQBF}vQEXvEIsrhX$PY9d
zFq4si0lax7F$Z!w38=V7tlb6I;2<Hyb~!x-1;6~F+{B!mN=UtlkOCDW;FIql3m_4@
zXVZ%kb8{1mioyHmGm8}<7G#2McLwibf=o$*7ylOL=cXbzBOvGOmKK3dH7ZI4-=~<F
zmYJNGSE8o?U9<@v#sXIj@Wm@g%>hv30?CP>3<7P_l;nd}z<|A&nqm!_W&jOngAK|A
z556nJl*AOp<S8X2=qV^T<`m~cPkMs4AE4X*A>jbsvk%!KnUDb9Q3KwzpI(}qng`m@
znph071iUg6H0=VL&VcO`2Cbe?fP@WXkx&(jO>lr+6{}5%qmx|~i;a&Ph;$ADk#25w
zRctnXP9OzBHvaA&j=u510gleD@xG2h-gZ^eHopFT?*2ZWj(+iB{^71Z@xiVEjzNwg
z{y}zCoHnk0@qwX^E?}lFl*t7W1)E`4#bx6PHP5a}#3sZe$kkOhz%@u0Au4R+<{uh_
zCMaYR>=}V3#%JT^=^h&73UQuYm9R}fsGoC4s3Yh$Lzp0sO^Ao5AA;xM=otj#3E4!s
z2KmQ_d%A>pz{J>X{2+d3v+?x>g@Le*r;Dq<dyr#*ho>`Cm8Lj&KUk3|sG<Q~zgT1r
zVwo{BFnk3K;2c^2zK`+YtOf|ZpbtzxYJl(`H8eu`O;EZSO1D7iRw&&DrQ4x&2bAuF
z(p^xx8%nQ-(2euK^y7wxUn~loyj+Na1*2gCs=~kxlS$Bq3G%pW2SYq_2g3rE6vhRt
z;A{`xF51D6#pVLu6bd@)1tgaO+A7Kbx}^&u-oX&ho&p-%<Va!b0B^_aV2I}gkEL?e
zFsHC*vlNwp$5grV*h+Z7<E|`V(Y_iM2(JUwgaMsG$3bX=BWV7$h9Oo2G(OzHkcEAV
zqbB1mE^vMX59btt_Bx_nX9eC`7|93Q;HU^z2(R|B4056LM?sMe4n<Hg3o37G7-9u#
z8A}+l7;6|M8K5I`46xgzn80P^ElzOp5nNJK3~>>tu7Fgn;MNLg6fPR(q7ZPy2~scc
zLRwFtau(8has;J5@I8Rw0jGDMAwAHEMBqhikduc%bv$Ip7N{`=Z8P0sDlaYqHwMs}
zOyDXF><CbkDGXGRfi{wYs&+O;1t!quJRWd!i33c6uF^pbFw}MuXr38YJBh#!J5ake
zi&>nZmbHYXh85mQ0xz!0W+;NSl0Xp;;xR#Y);W>aP67ucqMZb8B7wsPT-$@fP!sz~
zE%4?x&}KGB{DET<9DbltkStL6fesr6g`WT;X!9BuBOjv}BNwD;#19EOc&kX0rN{vk
zqo9#uaEyZqO~w#S?0cM?K#D;T1z9tI^GsV%f-wQP1$5yd=sZR6_zPqdhA{b(O_EOp
zoNzH(7@(vNYGf3HG9zpq0l2_mOkrx_0A1O|!Vm>oZN+?xFFpWz{vLR!03{oNItU=M
zK)4vxmH|x!)gUH<7_ykNK>NhO$9cuWj_?9yD;dyI6b?wfaDfNMO;APvorMKHp9_*3
zKwSn%-pA58s0M`&s6_>eDbV0&l{l(%;U&UKR`it{;0VAO_8>=9flLP#6&#F3AU^JJ
z1nqQ$g<}fZm1m#<N$_2ioS;@4O52O8NFUT}P6UT6c)~WN40N0gn5h8i-hoc=$j>Rw
z1z%qbIb#QOkS};yFz7s;w0y{Rhmypk(wxL1g`!mO68GZdqQrvCymUwd0%a8&$VZ?U
z1L0y&;fEG$pyk}mpdKe=?-~mvmOw6rlwP2%zt9t`Z?Pul=j7!VVTqbnP~d@wt3Z2;
zgx&K)@}0r{fJX_+32`8mAPnxBL2smFs$pyfohZhT&0G`#>N+(u)-r=mIxEtuVORj_
zf-@~-0&llt&Sofzr~!B8KpXFhB1%B#k|F7acgVDAKx>o0-7MB3kWav~5=EatDNlik
zf#DW=W-)jo9=f9nX^AIjFD!a-0lKKR6Xa9Kpr8Qw22LJE70_x`WIq=arGhWELoH`P
zl{vhe1+9>TIU6)Q4(f4cvlJ<TJPvX`bch@rAmR+5US%yS$jddXpy{Prwi?zN@Coml
zOnz0;A*mH5;8B`P(Akm&smY+FJIUbiU&#dVH>lXe-iy4&4!ZI>IX~wXTV858=+rdO
z+Ff+7gG$OtAg_Z)E*TiP7(rzu=#2a-5v0gQ6p}cLLvTg}1tfvu5R?KNK^B5CJm_LP
z9u^Kxa1O$qF+pS5I5Q@;i`_u;c!?Vs85qE;?ox|E=M5x-52z_ofE`2%>fR)lfEQ9G
zrKV@*<$*dzpu^F?*NB6AA<+F`pgspU1favyI7i_?cU>#kDyXZg$AJ4CpoI~Rj*beT
zhya_4A`03WfhnV)0Me0E3W<2Ie10C}>JgA}PGD(}R`7sdCiuP=(2OdEN_BO0h(kfz
zz#SCOAg+c_W?pJ=Nn%lnhNgnHg1V!lqq>4NXzgf;e;P<m6Lt9m$V-}5aCd{u0*}~f
zlt9mb0rOB-H-HV*QBX(t8#+`6(j5(#1$hGOYS7%7I`qtC+%*$s83!I!1DA22+#&`)
zMiP9CAZV2k$Y4!q$p=ajkdhC4CM3A6g{8pT2uhluA`Da)RSAJY1RPrM@(wlcgH*!v
zJ}8;O@;>M`ha#~WrgZTBVMy)=6?%~T4=$I%#TPRo8$+6mxNg_m3UU~zNe6Nm2V<2m
z!fD{N37V||ja}fpED96=vtfpCFtUj9uoQvBsF>|Q6=+omad{59CJS^(a9%1jw}CPv
zIH`es1j}upRD+Q$Kp_FH`as7|qg8zj3z$JGP!_O(4hmSv1nw^}gD!an1v}_UOK|5A
zwCANt1fFQ1?g1wmXp;uy9Y~S^xAH+ndlC4ybnuPOc$3jSSU`hfO9Xr^SzfAZUJ5bE
z2)r|d336^|HbapasCtlO04FGw8Ya;B11XUEw!ky7h(wjAQ3KP(ROAOyi97jeGW&sN
zKf%4!mCTR|6jYnwPlks<9)nbqpy65`CLz$UEfeVGGKdGkQAaQ_f`WDz$S6=ef@=ZR
zB9Isr6QdWXQRYKjVnnF`;Ke;SDMA*ffSDMH5R?Ex7)$$$VA%v}{=v#7kW(QE4R4~l
z1PU-vi33VhRU(iTdPJ8_;OpC%QW&$Di!?yf^$Qq4HybWw0`bwyCs?@!S$)o21g_T!
zCyr|%2ZHK#21X7h0nmkZqR5UUE@^-Q;~dB!c+y}g0*O&EX?TK?h7)l~16nS?69wK<
z36vN>m|%jyD0h&P1IT$qB!>r}K!PU+AxKCQS;oYHrcGd_1(r#ZJR794#0=DM6=#5y
zC2(<;A}?4nK~FxQauz%ZQsfQl72>MWo`5_6D@(xT2qO<82UC?W!Yjlj8Bl=T1sMiS
zGE6)yMIbSZBm)jD&}fk!+Ms+YOBy4%>kJxe0}ZjmT9s_zGYZ&)88kVH0zpIUm8h*s
zP`V(#WeFM+h72!*8b6uE;KqGHQEGB3Xs$e|5;RAPej)~Vf*w434m}hjAptbE51z_M
zNI+S+3~q~oww@FxBxvd>gybuv=9cDwHn776rxOx55)u@WQZo|EGV_Z-Z6wTn*5Gqd
zAuUeG86V&x267lB_^d?G06LOPLV^PL)PY3MkUDt0PazR<qW~yyFp5@4fvS*{3TkhI
z<2MCzcqnFD99-%`S_p)Cz@S@4P@4gu?b_gN&)_>`;vx50Gx=3X`Q?`=KpXz>mLlX7
zTi7MnpooTKK+suYw>aV94XzuZmzEa!fYLUWCggWmN(2?tT#QvhpjZcoAu+W-Xd5ah
zzhyHQS%7N(6ejQyQ{bVtVhxZ8_}VYfh^qy9zJuk*BJh=5%n%n6F1G)G91Q9Ifeyds
z`Om~8z*r@Wa5gxWpmq96?4x1jpsm8-J|L(^iF>yUC}`h-?1N@i4gpqhzM^tg4FF};
zc#^Uzw4hG}pRxy;_Q`~-{0DWfAbVgSGhv|9Yv2=4piUL+G!oDXn*1~clne?^!=NKP
zK(kSxW%_tCsRBj@1?$I^NfjX3&^0dwYxZ=_OG$v7NsF05L2Yf&swz+!0LrHXvSn%>
zWL6K}K_-+TF$WScG9+ke1ms$DW<R$o38Z`pj|))FgB^7Riqj%+5(DK*Na6;qU;t;z
zB3~T2k(-}^p%~I8;bR03E((AWHtu>7)SUxi@E8`zPDo1}G?)XP<Oc1nX31tK@_^?>
z#xjOt)V#`A##rQmu`UwY8HD6c7D$U5T!_H4D0GGZX}Ah>Fh2N1d~5?Zf*`*^Do_qa
z0nmz1NY)jE`4Bnd7Wsif2s}m(Ccq^Zc(fekNoJ5y&^*a5z*Ynj!<{Fq(5lZAF>vJx
zz2hkbv<nt=O)ls-AO_GZbs8gRp1XwudPOcb`22dvJwcEofjCpdQv^~3Tfmp)rZIx%
zz*{(?xKkv+=8B|<ws1!AfU9EOU<OUeB2Xz=73-K(TvC*nT%u51ngp4I&QDVSkI)sl
z=A?qAX(0!UC+FuTWrD|d5~0bsAiuaox1cCLIkmVLQ4cAU<Y%YmL65+8LmAlwwdz2r
z2t*fy?sfoGHjr66(8gXy22kn-pAMn~nJ%ei1dD*q>#*rySioMxxR5a&wC{l<uK_H>
z+00ZFPy-Xo0gHiF!%l+h=LYp(TNoe*#Wph*wSfbJ88o;L5vv7lu4V-9nc&FNs^Wv_
z1nshb9%{-{xeKzAA7&5aD7_TWd>>>v651hnpiyN|BdHkFNCJ(xz^2q{7)uzNnJ}l+
z;EP=~nTo_gb-+GG1_t!B3Yt^X;)l)hX@g_PwE}cR5ol!~yjCP;z7OO$(5OW*=$fh;
zhFCe!d>_PdMN%CM3z$IRoQHYbswQ(0+^I#68Nqv4!S0m<Z9WB$27z-0I75Kks||Cn
z8*JSaD9u62AFxR}AdhN+2=ECRATvP+Zx$347lB6#KznP7mVxBK=U)5-*~wf4-ZC2i
z%89>0Qs7JowjFFSsC1J9<wQ_(hJg`uTmoqEHi!m|%yKXZF$yvAFflQLMripMt0Zs*
zCDy3|aES(*5d#fMgVu3_M@B#=$S{G<GlWbOFc*Pc2fnofe41bd$erM@0TW<%f@DoV
z?gW(>pd;+q7^}q4-I7>PkeZi*(rE@IFHjBwy9CrB1$UDfKucm;K!<TMf@ZR77~(-k
zJ2JX3#PWdVmm#O`6v~0zsL4{*;960VnwJ7v(vg#zSe6Q&#sd%bCnUfZWMt+kBqbK7
zLY7}ZDsyo2G&8R(A9TA{LIS4Ve8^=9py4La9Z@+su=BW5Q;<#}D%Nwu@DeCdg3eL{
zpLvnaPy=%~!$O9MOoc4L&<v3c3Q2!Z+=D|BOn`$^l7WH27M9+sjL`!U&8bM)1az?j
zXw#gXCUX(EDg?*f9MH5J^m0;g@&?-kCcxH#<Sjw52TGz0%xsK8;Bo&dc>)%rBq~re
zf~rXnU0eiS#sJNRPN3t7vY5&ki}Ju%*??veSwY#75fsI2pr!nv>7E6krQl4Uz3!l7
zSg4h!LxSoEP+}<Z1MQ7xhh%JTP~iif06GuK(csKFAH)I$i6%7T<$_`W93<e3hX@jo
zN+(c|fP^5^AfQYq!UQ6Puq1BC!YGuK0GdaIR}rAA<4HOx!wr-bvRJd&N<b$Mav;tx
zg{+uc$>ayxT?9EX19}k>*pFxn<Peju;B71*&tsi;1!?mGc^J}sK%AW+!B{1Zo(`aE
z<xqSJig!@D2hqi#Vh~gzqRtwlWnhsK(5g%3W=7CZ<^;wf&>7s!DNK?KwM-?Tl?4o0
zpvrPV4O13-F^J><Z!ZL~IKh186owS=))CO9nJLVY4C##EmA1?&pdyT`2DBBAyM`%?
z+aI*OjvLJ9sbR|E0rPplx>!(c1G|DLi+uuPu|y417T89p7$;baAq!+H3utbxh6&6D
zyMPpXQ&>T#tAnn6ssU|k1TC*&^Mh=51Em=7_$zqt7I>|RCO>4N796*Uu=ERQD}t*X
za0I^qrQ_Ei;xmW<m(%d2xsZdEKqHB;WDid9;IxmH>_HYpfKq`CXdwY3=<p*hR#1}X
zVPyHw#KiHBiJ9du6N?NZ8>0ZD0263#kmWxM6URRmW|qG!EOJnBKBg)u^fXgkQk0sQ
z3mQ)MLn${vX$FMBRRHJ+q8i2&&{j>J8pb@PbkH%o;1I3>$8Ifnp45dQmamq%hIs)a
zq^VV?Qp2!-DV+gSZh(iHRx&U!XhJKl<)AQI3Mv6vAeHSh(0nj+Np3+AI2b?~9MV1k
zmxUnZRiF?6<y_Ey8PGCh%z71k=w4z;DoPfB)n?!<068(Zgb|hnY8j!eH-;?m-p?9F
z&~o!&22EzvV~0V8fWm{)`lAV6e`ugb1?awMtd$0IY7Cs#azF_QTwH+8r$Ju}0FrG0
z1rwyg2c7&~C4$W!ltweiU!ZUW2T&Nej>uvxasf?QxG=<;)iReb*D!+{%{(>CS*%4o
zC2U#jDU1s^QkZHOA*<@MxIi)sSyGr&SbCWl847tyxJ!7zfy@i)fPoGv(PZ`e6<cjk
zYXur51MeCtN`+j&3_AEyq1sTfs8%6APodhV7O5gvNY2m6$xKOwTu7-<Z46ZfU2KX{
z=@-d@YL_V>q6(C>_===KY_KRe%)nU_-0TDAO2m;TKS1hUf(Y=67)0H~2s$eonnb~?
z#+X3~7o0@VGAT%9D=6$i?QsV1-aya_1<*1g4n~$gOsq`5IoL5P@A%@>66n54zr@^B
zO-46OMn4eAhrWgeabz>7T~`EZ9u$EpM9AqUpfaKelue32iJ%DN8r;J>prj-Pax3Wc
zFVMUWpBM)#2PY2?4;POT7aI>NxMIfLu|!`i?G9}lrZA_nG&4uBra(@d1$8hvp&d(5
zCzB(JJw*uI#bk`)04=8moh}PnQr*H3#RXbc-NF#X4embj1T$y~7pa1Vhh&);7{H?|
zL7<yoz)O;Ia-iqR!WQwOCGi9W@NHyCsR}5UW<iE%^NUhaiy*@yh|Wzh_<X*kR0a5k
z9EGGxq!rN+^}dOfpvB9`$M->wF$ImxBqXS7t0yEV<QJqCC6?qvtpI5OH))enLG4t?
z!fN=5Pf&fj$oh0Z)+T3w2W!FpE-ozq_rbs?rGPrp+2Ex{U^y)3M_{`)2doy<Vg}{3
zc+mM$3bqP}`<OxF5Rj3nV%WKxAjMF1j(I5>(NI%0lrmG4G<Coy--6B2Py!hV5`wEp
zOixwPj71#0p$s`&CN;4*GpACayePAzBsEVVu^6#j0csK41dtsH+L)FoXe+?gfNcT$
z3nQ6=$}vzyNyLh~Dn3WhY_BWml%wF1`~sAU17r@UYy=ev;G63~Z71+e2TWPaHH?`I
zHB3tw`xqG+Qb4P?SZWwRhyO7$fa*F;Ccj^dy0C$2P&zJZ0u>yfo+D(v9XR{01eNA!
z<p@a0GEm-xl;NP|q*damu7r2Ri(FB=DPW_(6(-2Gr65y46&D91*!B>VQXjS+3gpY;
z2jEh_26X8pV+~_bA85$BjG?G6ouQT)G(gr2>gFZHFx7$%xMMA0EM+Jvt6>2RhJf0M
z5)9c4MLD38*g!jMQW(V<BpJjRvRJ{bMz$K}1)$b4TQehQ-xjDfP}oqyk-`GH=cZ5r
zBwND@7FDQW2DLIktw$S%63!AXaQ(pzsXrJQN_Ze6R-ij(Kpjx<tO0Kg!vfIJr>rUL
zk_=h=Aag+SV4gq?L%aa!Fx7ZLaGY>L&IX6H;u=9ahz+2dyWlxm!7&edBq#hVq0~I^
z?NFI{3VM2aDCq+fv>*%~g#neMupVU=`l9BQjF9z}*m{+qQH)*iR)IV?rsF|Zpv1=`
zwFc5t^FX=84!qhmL{q2;)Rr%*0i`L>tsIb+Cuorc(zt*Js6N{ON@C#p44eu<sjEl?
zqz&8<1+SO@FNp^COF^R_uw`oC3KKl~5e!OXY#?($qei#5inB8dO7i0qi_+2CA0X3L
zgHj!24;csK@I^+@sHX&@2oo0*Xfc8iqZp$QXq_StvR_d`7L+F8z1DM}Nl=C?hN5L9
zh{hVI1<DL+??X~T(XtY78#IL>1uP0quW>O<wTz%XEVzf_R%lYfT*Cxz$C%VGWib?i
z`B@C0K1vDb=w7fWhzA;YsbNfEfuv)QTF@n|p#Do1Xf~cjoWX{n&;*_u89;8RVTfla
z0i|<LKbm7910zETXbmb8c)$d#0-RpCKs{nj4(yFfa6$sjdDbw*sv$<q@>OaWvzYQ#
zKqK5)OeqYK3?<C)K|aP{&^d3QLnT0`S%4cjpxPah3~E6UjVsX|0!0+4d}Co``d_68
ziVQ?=09(=nSpx0{p~Mv^2Y^fgw~Rq;AMnVE0BA@E++$#=VT6vZfZG3%Ha#{cfkszO
z!}Ea>PUpY}Q!rcsatSyH@#e*%a8Po_<^oVoJO^`uCO0Gq!9#=KEQSbMaIhls6u9XH
z&r`7895};ZYbb)0?+1lFs4v36#Ky?M$n&3rNs5t!k%<v>fGrav-+v}1IYt3SAtumD
zct|CMh#QQPAh;PA7{DDhkUK$%7c^W0+Fb#;S|NqGmnDX&mZ_E{g$aD>0z(Q5sF0Ne
zo!4-rmaT-ThOLA-3v_0-OA2c(YoT5ZYtfl1u^Kke=p)FCh0I|6?BNWB_gEN8SSyPl
z<JF)uX22qBl}i{IYB?Ags$^0aYB=KAOIR0hfbKhPVhm@9WJqDC<*4H*ya%BT7+4re
zI4e&;%m9ssmvDiq9?-cGkcD@V42Aa$81jTLT~Nbb{Hlf>bk;<XUJXkPyE#KGOQ9ZU
zLj&j>UC{L>px(M$Q93B)gZ2o7X!1fLQUD|Zjze%k2&y29K!H|d3o0gmfrzUh!U$B*
zfwwe(`sPK^pusDwC+*(ig7jZN3Gx;v_yA>469U|Sy~PD8ts(OiMOQ$^qIGCN)2|mn
zi2yVK$G|MZ$O0NNW@KSx0%I}I9mn83xN?l3dtN}xE<iUmfpP_Wwg{!e4odu>ViV-0
zVmWAa4w?)o5&?C?K?8fBt9U>wxxoikf->Vu7RaC+d}O=`+_S(ol$^%M!0-y>UP!A1
zG|XKEE58#{QsU!L90Mv3Kp5;8(1r?Fy$+fb2aN~8M+_v8M+|D1vzUq{7#RwU3MD`_
zHp);pXs`fWi>`!r$Am!JqWOzUlY&x{oikFCvq5{@!J!W+WWXT~ZVZ96z6UuTJdz3>
zM`dHI5&{KhGDvGsYI122XqE$|Pyr<+P&EYh2B=gm0iU_q%v1zA$Al4dzYwTAE@ddP
z0*#F?V1{fzsA0%r0aXbL8O0e=*uaBOpvs9Um_d`>58V2@#aIpAB!^-fEC#_v7-alE
zmJd=3G-F&#cMp`Na1~;|VTD+g9LR^zaX~Ca`Yp!Vm8_6czrmeb@CX%nn-sYA2hVtb
zgAq)C!xA(i`3(`4T;Qw56qu^Gk!%9(#$g0yJW$KINC4ziK@b7%!Gaqp;M@mlEfj%D
zL&#cmP!cNwMHQq&i*vUKDEm$Zxd3D^2P2E102`kOj}Vt62P+3VxX*~uBLJmEaE}1A
zpbB}3dWsNqvW^9Ew@w-(xK`(gVoecF;Yi^G?I20vO5tu{h+<Cx9U8_E#gW37!Vm7a
zih%Wk=0iE7xWL_3&{6xMMW9i-#Qls64DcQ+_$Y_O6414t#U<bqH*xk{GeOtemgc4C
zDR@FI*8yF{3@S`OQ=s{IppI%ua)u6MT>yM?4syW;cvTPdV&R<py!6y!$O0eeq5<&g
zf}~W?jmIf^3ZR}TzD{YJI&@J2qC*SrZei(iDkHkK3jRgV(~Q;Q)Zu+$#0vMk(%hs}
z(EShKJ|}pcl0uw<GkE4V6>{$&L{M8nT@SS69ia}<qXe(b09^>1lv<>Rat@-Bp^>qI
zv7Vucp_u~sHdx%t-=ozHjf~Y}brho2AsQfTa|=t@QGA$F%b;`wDrAeTzy&O97!lS(
z0gYW38I-V~4k?1$eXMzGp#AmG^-V08?LScN2j_eW8ZROOu*q9F{~~xN5lg-gf%Qy5
zNfk0#3eNE0#tyh+5D01{fxDB4tPjesf&%b$8bXY0j1o*$+(=fTlxLvQ6BJk=TnuW}
zg1XP(E*%rNdCZ)}0zS+Gv<(hA<<tzh7?mB|NX9Y(OI#qWWGs3Es>E>>kJ9j9Qt&U*
zD~6ANV+klt=o)iyIDv~QP^0aZ7-&#3HMt}{F()V9F)t+^TGNBW4;+$U2Y|~@v_J$I
zB7q1*(22-mj8(iS4nf_#04hY`ExZ$q3=AoZwJa$NwXEr&`vn-XK&`l0wd_>_HSCb~
z+CrvUj&O#&G8TpsrpgpXhFVTWhAOobh8oUz<{Hi{mKv69mZE?f&RSLwua*VcLgTFC
zEEGy%sO7BV1h>#wE9XF4Xl&rt8A#U*&|p9bgwGB-C#;#JmKDOUWr<`c1YO0-25R}$
zu&04n^cM=%uuWhrnpeY?#aY6Y!UP%wfD94WFc&|mVFL{jfX;%f<*EVQ#R59ig?S-!
zFhdGkEq4uQ5^_-tQ!P&|Zw*fkH%M(Z=;~Uo8g3>AMuuR9DzO^g1>gaK8fI`Cm7|s~
zoFUH%<nsxPl}S*)YoPjl0%MUMR^PvY`QCt`hNFfjn{@(XQB@5`4PP1)#J(C1s4G~C
z-ay1_xeMRaaHp_kgHDN@SHm65P{W$SPzrM8Hqd3eHLUSGHLOjHd3>Odt6@rEhqQ1(
z%^T1OXW%{+D5r#IG8H9)Qmq|`0JU6;BAFQ&ektVT!>7v=b3o_fC6;8CfeLx(-RrRS
ztr@6&3tplGZp)qlRk&zvSy1cl7E5t{QArV~Br5_pi9xGmH2EQuFsRq!-QvtmtZ=PJ
z_Q_Aa#RFlc7L;V>=N09E>;m;|Zn5O#CmR(Rf+lY`lTwRIz=MLf*rBx#SlSS>-omix
z5XfiX;si{9n-idRupB5mfG#a#U}OP9F7Q2vpsWG9<wFXzb%9ZYk&jsbd^{QpGY=yl
z6ZjrACJrVhMlnXvDSMzBEM!0@=rQqtZbW5dVd4Vq4`iz1@h?K$(}&VZ1(hbC!U^2G
zBeKa{6bmXCv9yqHam2@GR^%7O$47&_gVaoh7LZ^$i~^D-&C8+$(4j5N3ULZ3_QCuM
zu4X7|V5Y)LP+4&4k9H>};;_p^P-rEA2yj^lj(0Etj(kvCG657?kajt|Ey;y26eYqy
zi57&x5e8~U;_OzSPDCO)6Dye@ok4IjGY;e~uxr2s*hwIXOpucx5eQmxQ6=bKq=(i^
z03{nxgA#;6Y|vmTh%N>#$OD~hP;6Jil*L?RhtwEg1@#G<8H?<|(`U>JI6xPk!lus_
zGJ_hPy-bV@SSHTcF`EmZU;xJ>Xv78Y>aUedkWL<`*<6IHN-Ts&s46JzQRk$v)Qi8S
zkv@@^n^>s;z5%HSa+yY=0%%QN4(PP@?9@EaWqzPz;y?qiNadUkXyI;JX-R1jX!lu8
zjsjFOXyzoXG$#jqs2zB5EO<>|5onWr5%LTmsJ<>r0mU?UE)Xn_sHXAH0D^0M@Jt#L
zsK7(3$w3l%prit7v4JN1Ky&dTj2z57f0<aA{;;uC31NmMXl4&|yMdb~5AOLrP#Xc#
zC&~jk9F$EU9V3vHxM%f1&Sd~O2--0c;A7`u<FW<K>~XMydnE(hF#?SQB<^6Mea9#*
zvk2PH0u9c9&OC%1i4HoC9^4lLb%nsa8E}`0aA&9nd4>*p0Rw@K5P08`8`vR`Nka7+
zY#kzHh4RFb<P30s4m>ppO3cXpy%K0W4|XnSS`J$ms)m+bC<SE&1-Hb^97P3PJB4WE
zeiNk21nO-;SkTTB+^Nb61*IjB>A&LCoYZ7c%LRFE9~@6`)o_my*Bw--0q+3-^#hB^
z>l=bR=9CILY#765;4UPJr$9kJ<a&ht@N!)ZksgWa8G`aENj<|JP{{*YM#8`d?HLMV
zu@a?00&4eyYE2NPYY(vqG!u%mGMokvGz}yl5Y<lvhZ?x}M$|iq+6Hf@a55tNKrLS}
z#wt;)wxf0qIT;uj;GIKIQy$hi1Wg0DFvRxNvQ<eS52M$z*RY2(K)N%aZW6eY1RA(k
zsNu+B26qkpYB*|HK|FZZ5HxtthctN4QaKCSHDrZ%4X1%RIH1A&X2u$}EH+R#rxto9
z5x8r}XTVU%2k9IYZK+|%Vyj_|XGiH8F@f|nF@n2B%zlt*+Eiu+(4IbUpBmg<0rzmQ
zb#6eO$8kDyI;a-S01==*OA+{h4N#W_eViE78JP)+22kWdIwPR22xvnJ2(vK4x*`HB
zpo;|An5smOqKJCq^0+%0?D6rLpgzV%kSifgRPa!|5RyBfN-%O7?YbJjm=$Vh)z#Py
z&y1=lex#twu?-Y>Xk8A}00bLO<*r9jJ}3d=>T~P|xd{@X;68^Wl4pl*-=nAi<Y!!+
zj^psC)kX3x+JZPNosXhIkg4F7JhfW-;Bp(>y2jPgKLUy%oGpDR+#VpY#a{&S8?h~Z
zkh7~n4nt}2OF&!vAX(fke$eU=l&KJ2@N@=ra~PNnTE7RH3gLqtrUhQR2bv1uPT^@`
zh~fZGdT<6aXz~|ngVyR5vm>?b6G>dAr=tKmP6v9J4`}lyxH+t+K*}mTa9fhl%!V3q
zjrrvKoP5wsMSfnYf0~9;kgJP=e~_b}yQ@N^tB;R=xPp6-tE-=alTWCtLO^IxfRC$!
zlaHgbw?epwXNaqUQ;>hSAJS!s#TkhOsqrP11)zJ%p=JgLhB^khDmZ%vIs3ROgammy
z`nmhKDg=i(1}S*BMmW0r`ziQ4hk$4#lb~zh6l}4ze<9W+mXv^;t_0>;DJf_xfLUPc
zH6Wr$1{UNO=f%UcfH+_s;LCkApq6PURVaZ^BGLg(%D@FHl{7Uqlt5aLi~|Q8+&nN3
zY#^AWp#-Lolow}KrNUK%IAFzaD?lPj&}ke{8(bMQf2H7>n4F=Y0qI!5Ca4tD)zme?
z$GIgZrxt*AkCzl>CY6?e4wlLT@7V{ZC~z8qn4|#?74S9DAU`O8Zr>|{EHh2f0j)gF
zF9J(~+yIt@9YTxfZ-7mR2OS@$U<(aoa7d~tfJ}t=OHIKaJZ_qpqXG6jSX5I1Nf=}S
zL=-VqhA>&Ls5CDmwYa2MLtR}R?tG9Jz-p`%py>!~xD_-Nf~>bvFf=gGQ7|+zz@`hD
z>_B!~DVQ2S{0q_^>I!x|NKnTDRV%~_NXiFmG%|qr+6ta}!4?}C=$N4DM0YwgO2Kn^
zC<jxK?x$#Vh#t_1^N^qbu^>(bvB239!~i=@9W>=<XkY*m&;b#KMh37cKTw$JA_BtE
z*&7~ky3jC*R>#l_SEHbyt55+BbQGaVE0ieEg@zb3+PKi7+zM76fWw!Vh(Y#0BvL`%
z0&52`Ou=474vtV)kT@bVAS%FtVSy_wLS5m0LIeexMz{)SK$s#Y0bPYkD+Q$F1P=y?
zli_-G6~Hc6Ff~958HnqlMJ_}hp7Ia{C)h^{sA(@+9ikWHV{p0!F~BB(7)Ic*K_nko
zDhA1cO#`PEh$?XSm|zbdu*pbX0P9tVR!7qbR{;$ml#B@uAf#La4<MMM;JRT!1l5kZ
zuou*u1`Q8`=wdsp6V)Zm@F{BWN)^ZyHF$y=GEL16W^;hMVl<kp<`INVR)Y(3{DTtE
zt#qJ924qkIyxb1lD+EthgI2HJ;sdRk1+^ByHCHiY5*XJ+HkTj+LouWi09ud=y2h!B
z7gVdj9fHw;0tF}tV>x{ldw^0ljg5byqA)!8l)$dWKRm$(*{%i-Kk)DbTKIuyXVAvC
zLFxoSp#<rcfL9{&quGVB6cMz>2Q(f54kOT52WSkUXcE$@T_(sBNDV_gGiav}cx^0L
ztd=E(HH8I<&sxJ$!wOzH#gf8?EK|b}&zi!HCc>7&fhNKZ-d70Pqsa!o#*aOP6SP9N
z26Tr6Ll!%1k76xI1q+PV$&k)a%aOuW%UQ!Yfw3q9be$o{4Ow89WU+}e)N-XW)N<Ew
zxiG|*)bdmb)bK3es9~&OTgX()7S50-2U^%Tfw7VgGCESjy@0ER2ec+VlA-VpXi|9r
z7if*h0?^(lo@T}x9>}qGH9R%!WegJ-i|lIH7w|%K6yB-f>0l^hD7w?ZfDkL;tKn{D
zEa9u+YG%x4D%zF8S<6|ttA>37W6`7(?gjiQJSj{q3^nYaa9+q*%L}^3v4$yyw}w}Y
zp_#dfu?BLQ178YD3kPI>S2LqILoG)-LoHtohYLfjQY}vn&jJC^iWcaUI#Vrw4c`K;
z8t~fs35<oCN(5{8N`%rGni-p!Y6WVTY6QSbFZuCIQeim-fC)5Ql*Qc4Si_ixabN*-
zU7|H;4to=5>IJm$9OrnQ1UxG!f|DnFAO=g{5hYWDCPYD_BH*RVp#CIy>9Po9%^i5{
zBnxQeHFWthXp(Rx^n3!a%Wyghw3JyA?kGt9#O5f_<OFzMIEJf0Sq|(f&`1>6RWhIj
z)maQhETF9!B}^sEX-v&b#fZh#AlGTKfEP$Y=KH`-1l@X#HQYc>l!7@C!+O#J1$Jmd
z5GcCv28s-oZL}n4qbyDvK~uKiAO`JK00*%IEaJhz%Zx2}!Rv>?Aq(~_*nVuo8=&Bo
zgIVnsQdG^zz<?3T;Bpdlf(J!&@s==as<eDFA;+YErn&NqAoDJ;?u<ez<fxTm1r60=
zO$@hyVjMI9UW}aJKpPGa*#KM`p(eN@&{YcH^tF=l7F$Vffqy{>WKb1kRuL!^Y+=sR
z6fP<Ojcw>MGBAKA;cv0$7nB%+?#knYb*qYR@qw>tMDTgRe3&P0allwbh~+MzRV_vT
zKq&!KRNP`KO3lqLONH!+0k35RjT_%$E-uY20&Qg06vVpLg$3l8TOiU1>=V$U7xt3e
zf}qsG6zKg3{-B+Mw|KHsQwzYuJ(+pww>V023qVbd;#+KKiJ3X6Dc}Xjx7c$bQBf2H
z^741k@)(}9%)G=L=vGfiAeDh6!65}2c@_iJwV?F_pt)qwq888&Z_r61Lf{21pbIAX
z7+IKD7(rJDfzHVXody89K1hNQv>O_<*+zhojR_<xz%0Q8QX$01$Hd22#fMrfqC`Gu
z4h9tY;58N0T;mK|grY{PkzpTL%BqqF`w#ar=OV((P~1U*4`~j<m!a?=8%x*G-~f<o
zKy?6UE{%(^N*L@C)Nx?wB5N*UmJuMv6LGGp1~m;Yf`$@7C(Lm$vRLr3^RRLma&Ur2
z_HYj)W}%-kB?=xogbpL7h^4Tlu(vQqv4U4q!%mq3t*C~bG6h;y&4IM4S{!t@68wZI
z;S>?j2~*&KM$o2Ui6T&srYa5VnNn8Z)1|Buz}tagXG<ke^>8V8$7&X8#|pgI5wsr?
zyuZu=a^F@7doxp!Q4PZaHpupiJU$S+gab5ZwvZ82q1Q0PbAtAj#e=Td2A!`kt%fm+
zy9RXGHe(h~4MRLn4XE|U2)aU=k)eh$i@yeR**0SqcyD73W0qhI=)!G=ETIL$HH=w8
zptdHc(+1f&Ap&XjgF+0_YXVnapxqv~xH5}jr*VPLSt<gZgi-{$Q@IFSgM)VhfUko9
z_pi|Q34$8;MWD@skhA>Lkq%7)>jrNdMC(p~Ru4yk(luzM9pum?9!4G}&|D{I3lwNV
zjfW9LaxhlOfMXDPIGAf*2I!s!c)tvF0u&S>pqv6Ozl@+;1wkt?i{wDv5BM%9#uTPr
zmSBbwrW9t-vAS8%TW~>vrODz4-7o|?Y+92A5(1!F1L+=FT&JVvfV>290O&Xx5vD3x
zY)*$a{xFJOP!kmFbkM2f;C;lPrO=F^!<1kLEP*|vR>P3RxPTe7a2nLBELsoRmc#-%
zO$Z$1IiPA4yr~%6mjg8iA(afcegR8>TnZ`TKo=B)=M9yyxfbmpBb1U4<X%vagWE2o
zoF@eKMILD07xhFT?B@yLQVsSyp7VsjNgaGB0yt2>>on2QAxO3o6cnH!0!11Z_y8~X
z8A8w_QXs7*SlYvJju0pmKp1??8S3(OP(Kgs3ndT>6rYR?VAq2-UcpY320Itj&xRy9
zaLl1O7bM#XaxP?P1!x|ci?K=$Tf8BL08pX~<UkMxCo@nBsD`12v5cWe4Ai`X9N+@l
zij8$GCFIZ-J8<G-f*k7t$}y1Qg}DfHyD-G*pmme5osXc6Sw-=nwhbtVky0T@Q8&mh
zkW>h|{2Dyjsf5ipsI?vH=`<kkfH1;KAcry(@uV|=N>x~Y9^yI3UNdl9n1G4|*!eV|
zZE<L))2w8M_y&BA2FSH5p(j!;19d{d`=HUh1X4K(<RwtG$-oG@9~|T*9vo#D)&pul
zO)yaGf_zjAI)8<v6R84fKs)V0bw@x7=s-5MEOyWxs9CJ&XHyjgf!0z$N7BG458NyO
zZx9C;_uwo8KDY?9<p6R%5w;`=(l!g^XVgQfL>MI)tE90-CA4J*n+f&P<Shc*0GhQd
z0*x9Kfp><1Y6!@(M{sck%BV%4<PTZ<2nuNeJHtSp3IjO|6iMJ?O@z4EIM{i3c-T1D
zxj4X02aJ{sDAYmAc)=$;AWw*b+cBVnra7WmQeX#7vw~Y9Y~X{YbwN{}pvBET`T5z2
z8L5dWh}#_V)4(hGAV-dXi+`kbZ;;bO5)$0<A=f24Rf5jM%TFza-uRpdyO}5>RRN?I
zeDo#sVkqbx4B(+)&>~pKEk%$WUOEbyC6FbyWvNA(X_=s10vWI~lnYXmK|(2D6CvkD
zBbFIL91gnf5pujU`dQg}3JR#s1>2vPQ=V8^3|*32tdOXX2U?K}-U|a>mkZj%2A+3=
zY?LhqpXgBxo=5{<i;@aCtTr<b99B8-P(-*3w9hTSI8{Llv|v*UbodHn{cmatWW8`Q
z=wwiZq)M=JKqrylTbo&0oT`8ba?nH}c=e}3qC!q$Qfdw)<TBGhfe7A(2Z<ceK`@C5
z>Q;z}x0J+^#CXt=x3C%5#GHbRM5Hx{5aVnW5DK-CEY?uBLb|6JG+7AVG@)Rt03Ns2
zfaum%2!@{f0#>h}jdWfM++5HN?D+-$dA49ZpgUno!1>QH8MIA9LtQ~#FDpMY5BX3R
z#HlZEo6&BAhD?S)C#O*6!k{x?r3D44MG85oX(dXUdIjJKJPn+)dC}0xDbR!pbZ!p3
z=PnsEyABeBOwNJDK$9jQA%q36c{!8{4b%n!<ysIf23@^}sChx{Z0LC`;2UR(K+>?<
z7L;Eh?O;%w7Ir>3xYR?dbU`K2Zcsr2YU+U6s#U^>goC3Y3TgwwJJO(C-JrS#(fsTM
zZJ`IBo&u?zY(bZ1v4TfVnf!`OK*v=vK`I|m!xQ^Wdbb$kA&b{Q<r`AH3K~7w4{|QZ
z4GhenyYs3<kQ@vuLsFp!gBRhvc?J|bOJSx!Z=L~(VU(EQKmm<gfwo{EmzXJ>;4%}|
z_v3;t8$pzr+(o9KGP8h%fdN!zCZ%R%=8;-x20+i@M--Z%gTIL=GC_q5xSSxf$V4i@
z!N!0KkJMs?f+Elv{U!Mz^A)fboG4C)6q;ZYAY~brf>Q^w6edj}5p?BKX-)~G=mgz`
z1uZy12c^Mo3xHHI$c1KR2}mi#_|z0=nHZ2*l$e`Zl3G-31)Xu$1$#*WLP7QyLpKta
z7MDP(1RTCgEGmXnAqol#Ir+(npyCGXB?Vnjbx@R=SfZeda_NCzeqL%qf+k2bGp|Hb
zAvduiGq*HX0lMfrKMirA0^~S%1qDzE4XPBN$pm{igIt1e0@w|nkh&L1D<W(_;R3s`
zSVzGpvm~`BF-J$iJGBy2po4BW02={0US1);NCA9-gI|7$XCAobRY-(g6$n0g4s@zD
zXrvYD8OW9Jph_zha!M_zhAv74?Jz9?)w_`J2e|>1W?^HQdJ6s}8L36(nZ>C(@X*Tz
zML`lIkU^_UAa!?1KKSG_&@J>(E3t(iEa1Q=hAE^K<>!Ju1#%2LeS*Uce#si>;;}>p
zq!0rqZfL^6y3rxbNw>J9GAC7`EU_pPbeRRTaxc#;$xr~Vaw;fFP0OrEg~ul7?5_B-
zM9{h<M265%QU<Rpf?r!5pPZkYo1dqbnUb1U0`fHE#zoM=4A81fO#LbZ^@Ba{2U_wC
zYUhD5sOkU}V<5U1bifdL6#}~Ra3KTeenaqNCFp=J))dG|_#hJ0#AYl3oek~<IlH8m
z3Do$GXU_`*4ex;VaDnD$iqdKrvv}chR$w{45`M5;PYq+1K#5>Ba}k&YS0w^gCDhDR
zv>=5UCJGv}h!;*_0Zr&Z4=EJ^yGOK!Axmt5IB54+3;d`}O?JN!H}FwWRRW-thJ1Gk
zMmT^fE$~DLs5xH4w1A<65mZGrGr`XZ(PS!e0}U^jfrx{kk#@8SXbuAd!%z5dtSTaU
z;dLd_R9sGCZc<93ou&k2bP7}>Kx$=hO$=`OgX-rZ@aPj4s2d3$wwe#J7kn-Yc$CTz
z#JvaVmidENpb8gpg)jI9(Oc}$oCmpi0JKD)2z(+dXu<&2R|VVI53&SH6W|G`HUtgK
zfSLf1fhsme(6&-g&lNOi1v;FK19WB&BWV2qNJW(}7SDrY0(IC5)Ln$H+kXNbwkom#
zMROKoHt4D!Ch#0ALl!f5-WGI#2%`i;E$D1smIa`@C|MRV#W2;f*0SX-03A3|!q&_n
z&QQx<!&t(e0@_B+ki{s$(9BfB1Ue<FmIE~13O1d&nYos;gd>HigcHnX1YK3u48E|e
znaPDA)~}YUN~VT=0c#CM30DnAGh+>x1Ov>jaE3e$7KRe;$_tDPwcLyhRRT5KwVcom
z<lJ@Kg&ipjwcK^w1`Gxaj0}Z$3Oi~zn?SB%1GRJ@S1Rxnfg=?h=-}1-;B$7s5dmuY
zfUg890^hl814?g*D~3S_^=R^7o4qLlUoqSVibl}l{#%@&`w+pcYS5w(NarZNI43hX
z^%iGNB6OE>Q32=x8RmkdR7g__oTkB}WuW%dZ&2KWrUpT?F`yH5xfn&5c^D-a`55IG
znV4i4`52{`*qB%tt3;4u9I2({r^y6~cib&5P|`mEvIo>|<6vZw<`V}ukT6<YpkfMC
zZWV(DIFVai;Pw`*kID%y1VCf$pu;x7W9=*qQJ_naxQZ-5?XI27kaicOuUe9?kdj%P
z2<qiP>UvN&6H<I<q=KuNJW!ogoC<CwK$-`zo~vJeiDMq=y;e{Y30xXesR@>X=re;W
zEZBuX@LCSqY1UIvaLg&r*HK7FKyf+PEn0c`C0YugL+unm^M;^9TEHj%m1ks@q!t$>
zCa3Bl>w~o4K=pKKQ68jn!_x7^f4qu%9bzjW?n>6t&qYVUKS)Qx&p$-LRv|aBK*Ko^
zw2!X17~Wn{a`Xc&O9m-X(km{=$t=-8?(Hcnlq6=SDkOszwt^}G&}PESVz5{?q{#z1
zZl*{9QQJa%1gdVqVhXkjbs8W$Y83o~6ly^BfR+J+Ph~;x_9o@$=cFd)#h0WO<$}%^
zg{^t@^A7>(0h<SHc`7I<C@Yku7F8-F7nP=@DnPX&r8EUyP%8#>_Gx|*xb2jhSCWxh
zoLQ`pUX)*2Pz+j^3ywaJQ<b47&1B~1DP&}(79|!XXH@Ed7Yb+QrDaz5<(D8eQ56(m
z_JNBC1zR{5>~d{|sMMl-|03V~qErpI-$6crx)SU`XonYKJ9M#fF{Jej3T)(yh?Mk{
zz+)bX$t9(UIXRUIX*v0cB}f6CSCX2JekhK%LLI2-siC9?T`G;c3v7To6~zdi1Ol~K
zn87UsmK0{lbQHARzz!P0)nxH=3#k%w%P-AKQ7FwTPs{^dS_~e#(NTb%dIBmmAXPKC
z@&wn);PdLig*CX??gf>(SgKAfA^15l0!*OFv5Fs(^WZH4)cO$A7y~s#z$3bl<w98u
zu;WaM<PfzNWRDp93N7epI@m$xpw<AQM!_{>V+e8@sKf<b{3XCxB>;68yzIu9qyZJb
zV26QP9yrec(@SA00o|C*0t)98X3)a1cu=(sI`@kOa_(0ZQ(ZN9G8*&LEkwA2hg`vx
z5tsniNT4BCGmyI>Bj=DQY7wR?KB(K_Bdj4s0-zWH>jV?vxB;61icMjV8KALd4n`I+
z9(FEPaK(U8-+*ERT;G63RN?gv54^VFjDj9@7R8dn3+v^l@PXw)bGzU}pP_XR|1G|F
z-_o3t%z~U$@UjWimN>{NQ22syF=z)ndP^MKu4b-bs%0)=sbK~m)TsxWMy+992)?0w
z0Xv8VId&H^+ygzcXDTQlKqEPjg`nU@BxvpvJl}bXt+)g<at6D39GrlrF*7jSVol9U
zNiD*5vZ(_o@IVbWP;-!tkp*%chd8S5;OQG{eg&r@(69+;?ghNG2KjV8&?E+9kx~sK
zKSLf9cv_eldCCaQ2b_8NCGlX#LNACfnhx?YIM%@gIMzXa@&Gv;6zh=bE)m8mQ8Y(G
z0s}Qmf_%yeJ6UoMw27L<2yTKx&XHsWO{&zg)vy(*fF`-JSZdj8*ous5*g;L#W+q04
z8Ws?%2E5uBdIlv&RTyZ(f`@^Jp_a3TttbIWHD^&l4XA0$)XY@NmB&)URLcc6fvbkO
z88m#xRLfn%T|A+NdjZ=*hN2+QX*{6Ci-keq40&QK3?=L(9BE9In;?rXA$KU%Fx7B?
znw~3}p>w>NoQP4jBG4uDMKeI523}4CzLx}a;3H(-7j$|K_V(s2{^Hb}G;r+^4=y%t
ziGT$_jfi;gTp_4OTzrcgJc$K~q+7ftMV0aJI4d#$EehhxNG$eD&&w}L1ur5h(gO){
zmgE+IOX6Z|4O2f*WI{S69N<&tSr|E3Kxt6~bbKfih{eLl!^FZUz{mr-YmAYNsY(JZ
zy1{M+4G5xcXb0s*P%;7M#WZlOlEqjQ0$M1V4!S3cA&V)6F`c2ASsZlc6zF0ASdNsb
zVa{SJk||-&;z(gyz?s5a!w5dU8MK&zIg4!}3+QA-(CH?HG9^6Vi#C`R@PX0>_+kJy
zzasEb?hsH+fKTg3?Cax4I>R5FNpFKX1>mee>_PtEf&jd^FBD_}xI{!`5RgPRC`>^o
zsel^$QjA#6?UzFfL9|_p;4}L}KoeXT_b!4<AW$xZOl^Uz!+nGY$f@=q$AF@NgOQJe
zgN;kJ2qcP8MuSGdLF=`^m)OF~XvQdJ&{32v3{fm8EWr$#tVN(Tiiue)ppAJ2sU?}9
zkvh;36Ub`>Q6{SpV`b2mDe|}>sJR0jFN9K%egUN610J)2G{ljOFUib>jRNT^KuQ|W
zFknh*T4HHV3Fxv##NZ&pcE|*e0;oxrnU`1s>YNmVhJ^A`bKvbh1qBW0i86(ynMI&;
zJ|IJXFog=``K3823i(ATnR$stpyTHut^<vP6{W(01Iajq_0aYmma#AR?8|^p{}46d
z1G=(U!BzpX=?}hD3^dhZrGS`dL7C@Kf`<sf*&>kXh)Ez&s~&PvND*i@6teS1T_Ld;
zJQb#pnO9r_63<Ul$V;s#flj+Y4iy2<I)NsCAd^H8_kgB<;BHX{x96eh2Q+yF-rEOG
zCU9qh`V5I>`I#vSAP0cbOb&Qz4>AM*a!5g9Q3)vhgOUI!CgH||Oazzcw4I0p=O6_I
zq}e>U#i;XeXd$bt;Dmfq30iPLPAUOKDkumM(FzeqpKFUn?u8|Tvk2^t3dHpc@PN^P
zJ5WJOLBmi-6Q4W5x@gychAb*&snyfdE1Ci-%yBiACxZ%6w8pX^JelZ0+sl5MtXNkf
zfSTJ#buXf_02QW{Afv%mB_oR@xOl}Vn?bVR_A{u>jZ!vqf!oNi88U7#541v(6M2Os
zwB^iG1X^UC2)d6BwtrLsQEGt_aaC$jK4_96H@_$q#0Mp6^w}UvN^unPheI*0P@I{Y
znUh!qDkos8Md7IeatAMJ_XN}w0>vhXE(Wb!gmq7{z~i$ijG#shxSI{0Z`Ne?Tgg}i
zs_jEyv(BJ6gmj`o{b!VMXOKE<9gXF%6vn_P!dNAY7><B<E>K(QAP0h4>R?BLj;5^=
zgE<p)(<bBu_i%<_(7Ef(B`j%7l_rojGNc>L#t_L6%wPb%xCFAYixo074|Y0eFci@q
zE&}(e(V9>oC96Sh2DMrk7$HY8R*4|F8{XigVbM^<$iVQ6C6-{(uo2`^w4y->$*s_`
z0n((y-JJ#n&K!_YAWw5JvT*US@Uek&EJkqvZ>oXDlM%%MXscEfb1HKb_}Z)%&{e#w
z!3>&gx47c{N^^2TKquN^gcoSB7`PV+iu4r5V1^>lQcy@?g{?63Vq{?019B$F5e$q~
z!U(hV;^RRhTJiBjSaKRP$pS71u~`BtFZUx^B7|ZIXx=W~Pm>M3s0BH#Xe+2W57H0u
z0@w;L0q(snVrF324Kf%sUc<r2!NkH?1QNptVo+#+OI*+p0wRc`Ko?RmM6sr_rZIxc
zTF_WIXB1lsY^<CeJbHnAlm%B2Xn#+lJ2L|VywnA^8bPfI8nl#gm$A?WvVsO|I}B*{
zyeu)N6m(=F%37$*G|<Sp0!$t9FluJ80%+hDd=VD3D!|gFRaOWM2CeQXNd#S|ngSXz
z&I8$ys9>s_l9`@aqEMAtprcTbQ(BC$#RMu<SelrFI#XMfS)gExc_f{VLTW`~a*3@e
zXfPEPxEkuZpd%%~Bg&wozhR0@G&K>YEL3F{;64OFS)rsTF$LVSNz74*@(fT&&QF2N
zoWojMhDOFFrifM#NLU%9QriU7euPYqg9Jg?(8$ohP}jh~zz|(SW*&I`CP*W=odZ%0
z!j=~1W~RC*Lh9=3&>jSMeH6+82L#*;aVyAN5C$K&XJV?3(q@bD3_y1|lB+@5Kp3PI
z<`q=^*gS&86AE!~Ke;)2`dEREVo6N~4HQFfeh0Nt6*Lk{z-u=YOf_{BG(cBLS{Z^5
z&#*FsL?FhDGbpoy>nh|^!9f)&XjeL@LWPVb)iA`ffTk$pS;4!}A$QP&*6QD6Vqge?
z-8T=)t&sW^JUjs2nveu4R4}UB7?3Dh)dlLEzXTO9pi&%E-Gc9)7lb8F92G8Tq#9J=
zf(v5ME$dY>sH?p|n+?EMrm%!F<b{CFSp#j@tSo?5y9`;Nd0f^~&>mxkEQTz$qB!t<
zvMlMK8@NDnEHxmKA&bq1p)dzDznjij%aX^E&Hy?~Esx0nw0evMG_X}P6SS(A18GnT
zJOU0HyD9<&!!6l(m}lbSVFiR=ehGLeHZ`RPd=VmORXC1I?Los-NJTTaR0h@e??HhE
zIS+}6Q3gEN1m1zh#KpwLSS19r6Y1z>P|XD@qCptM2BiRS08%=tUIeQ7i)ul!i?>hk
z7vyBLieCWkP<XW;qKSP^6{y}RS`6xRfD#R4GzVO9;oMUNN}7jYmU1w%sIV~!uyOH$
zD;V507-)DHxdwx-s$)rE1>I4Rf^AhD=q#tiADj#f;5GxONCVGj7J#d)veY64&{<5S
zd9bx(;A~r(SCW|nt~S868+0u$VgLlRN(s5vz&#99l30|UT7q2Z<R%t@E-3_?4l61$
zQXzu?CHbI=1vFAx0JT#=S0OVmIR`Wkh`MIXEitDUyl5;lO(CSHG!?wCN&(Zl%wh#_
z{}tTIgsdqBm46Bf8lVml)G7tAuM_i9uowWEv4gFa0}T=+Dj4ZP_sfD8GHXKSy+IBI
z57y!szA7zFO#$^RAmOZ#UX+-dn^;t=pixp;keLjg`YSBW2bG_Y@d(sOOa%qd(x=qC
zl44Eha9U=1MhWO@jgrL7JcTq+U_d77LF>99%MCHY0#ab>Du6bl`sd+rC)9n2xJH_|
z1T_}GYXTr%fv!M<1Sd3>Qb1=iqlRp8iM2vz8uYr&q|`J}e-xww!+r2nr2}y(*kF*#
z;OxwTkbICd*aZ-eLMmV^?Uka`0?@RutpfU~LjI*C#U+W5EBic)i%V0B6@nmYbrlR1
zyb|*ij0_A6Am)PYh7igMH44G0pjGoFl?pWqE~&-IMVa9FYlu8fvPMC{1+)g<zW}=8
z52jKV1hhc}1S2sa0(eMdwMfCFprBxAV5m@|;9Qhh0!mK`H42`2-~m$5m6|0A#g)Y+
zsksWtMTx~3Fn7S|8aPYA4AoEtOB0Zx`Ng@ZC7H>fkSIva$pMue;7hGQOHF<9(=+oF
zG}LqQ(`)k7HQ`1f3^g=CGt}Htp+><sGcUggq`F2S7~;6%ocwZy@{H6xg`(2DJdh<N
z`JfYy^D04O8~H^g#R>>RP0UdYMUHIflsjw;7SwWtv^GGt1-k|)*di^UuR&UH4;e;;
zCbyD&(1<`mP9-G0DS(ndWl09eS)~OEh$0d^Tp8>d0C$cuqAWno(mD#opsbl#qL8Qn
zI`KI<Be5tkxg@m+H2RsDlB$rXfTBSGyoLpo=E21<iUr{EOd%1xm>+x}tOBSIQ2@^k
zf$lBIEYQ$Y04?221)YWl)(_6L*{OLt3YmJTdXNG$1t~Qr<)=V4OMrq2QVPX`hCxBW
z1<rvQ!L9*13g9`cR9lEkgG-7s^U@Kai=<7jI2C2b0oZB2i3J+PCE%M?G7FFz@g<qb
z*{P5lA{1;D5GTulwxXuS=auGyS8@g;g)+#I2&}DuWV41+acUW98bIMdPzN+!X(**6
zRu;$S7o_GXAup%_g?34H3AhAAcn9?oB1qw+iMZbu<OOgyK%peNL@%W@w*b$633WpQ
zL(m{DER%!SICD8j(o8)To@#Uz;Lf%}%I3NXAirDTE-jD@fX4>t95X{CiQ?2UD|pcZ
z7mrrAGy%E78Cra(>nJD%6DmKHbQIJLO>nszsVIRtoS=zt_vk7hdB74;DCsId+z)jo
zTz#~<xh2T`;F1c&AiA6aDK;_3<q4#s3+@SGOF+2eP&{L9i6jp84A{+JK{vl-P@e?U
zv<6`i8`Qi8;bPEb-N?g%pyfd|%<yH+EGeJ`&8*;#78{riTHMS6Ufk?f!?1v>hGijW
zF%fqj8>mkb&z-^yy4gL87qrZ!h9RC0x|}G)txDJrRFan@XFwYQpv<Dl4;f1YHBrIc
zv|C(|!UZ(p4LPm`w9xk!543Rs?w4R+u>on*K=vhq`+A@iNU&~8E@&|)JJb-!z39t8
zZFMaDJqKY1hGIz91$1)^Xmt_@b20KUu`yQhL#hTGJwHAM1_pS~Pl=I%p@ylJ1+<u>
znGt-oCSxrdXtQh<6Zm8)@B)b<9Y}W;w4|dJbm|iLf}kQN&@zZDHn1osc&P(d4Qn=I
z(YYE9(6Wl6v>MRKQe4eUMQMfiYB<4S)2jGtIBOVdxIhae!WjzlK#LwKCqa6Zkqm{?
zA{h$v3>XUYszkucD!5X>H|F-TFfu@|?&K)pOk;vwy;;MR!feh^%N5B`=w-lAc(2e4
zwDcU560$&dFS9f;)^OE=#<^LbtBAQvxIyPn)$-IZWbsU3ERq7-!USI6!2(_20lKP*
z*PNl2r-rG92h>B=Wc72?WGdnUt<K^G5#Y;>(m^|(cp;~>fFl#U_7@yw;B{O}K#>Pt
zl>u7zi!=ZYigfTnE=5a0JzqYo>wyn|I)lm}%RpvBZsUZm)Q|wL)PSU=_~gVq@P;|R
z)QXZ@5E(@3j4vsw1j~XCgvrTIzQqCROMv<jkV}w@Qj1G-N{YUL>;aEif(dvR*%y?~
zK*RB%qr^dLH8>c>7{$N`vv4qRF)}f6Ff%dofo?ZqVqz3w6ky_GW?>OvW?|%E<Y3}p
z6k+6GsuF;vMsQOAv|>Y(+0D;SlQ9JMs$x)1V*^<Y88c<E<l`*@iQ(>X=AobAAqE~R
zh0RidjsXS@PD57}qaOmCBA&vV!q>tW#hJpNBGAGBx(hLl5qydVM-+F81lTN*6wwyW
zC?4?cS>9j<P01oX(28WxE^)W~qVmL|6or)3<ebDJ@H$P<TvlQpa*whE+-rn%Tv8Nr
z5<v|r$cS4hsM7^1X^J3sc$THYJ6<{p#ihv^;0|3*dTLTpVrH@ecs(d+NEB=lq+b^f
zYL0?BA&4Fks3Ve{mtPKQNP#y~B^DQFrssj1SKw|fXge&}-OyVS;oD#!XVQX9Q@62E
zhb~ObFM^J}`sJ6TS|KgU1-FDDW`i1?CHdfeworpX&II)*LCcbJ^7FI7MLl#cM_w{`
z#t(M(Z86mRV8}LKP&=_w2iyS7NCa&#%gHZKEmA<zTauBOrvP#xyuoS(+ZLvvppaIc
z0xF*sY-|(~6>1ccK<B$dI!&OBxS%E}WF>1-szPd6Voqrys8gGWGRmoeY=$PPA)xI}
zsY#WfrPgI2Zzq9P^C~1O<d>F!VhfzuK`W>fkZuAh)>BaM1V=?tDx{;F0*VdL{^rX3
zQgG0uRutr9CTEu9R6-UBgCh#$Jn#v?#i>OgS7zoxx9TCqAP%o<!2J##%XQArD@!c`
zuSF@z2QNo}#<MLVqCxF^@G1vLNP!n4lw@Rr_6g=E<)r4qA}Tdi0X72(E@Yr5LqRvx
zCV<=Z;5?9+TaW{eYtUvu@HMq%kil(mFcm2zgLd1cra-UVMDi6RaigA`0Gb7Y55Iy|
zJi%H9$iuIo8olTSsDNgMRNkPx3a-41u$`y@8V;KdDsVuCGcZ;OKyx&_3dOw?5_EbH
zsP@EM3JGqXFo1`E8M2tOSV8ALg6mPX8ishb8ioa+lN*_{IKZtLkP6WGj+|f>Tr~{w
zpmP?v7l7(1<}7ZAnqUUV<R&lVd_4G4P{`0J_yhz{O9av;!FJ#cczGb`tQ$xufD3yt
z0V?rtamB~y6lY|nmBh!-0tE)>P&deWOGx7avWEn8*hrNSB7k68FoFmamf+D*(7-h4
z#11<Ks0SdUvEYaR+YTncPT-D@&x9Gc9OMR&A)q-wgne*%j5$A$TCjzn5mNA?TgZ7O
z;OWKLpehdA%pYjG)+&%yphN{)Jy#_Tvkd(h8PJ$7sBsFyAU51W(2;YX;qzhzn6+7u
zm9Pq+rWDfADd5fA%tc>7l{=_jhnx<9%~_yhBi4bO1@a8YS)hGepmAxK<A^yc#S66N
z7331w!6Kk@Qy7bEu%48{0B)e!fc$~yfRUnZP_w27M1Z3WOn~C92z0!~R*;K9Ellu1
zB1|0Mo2q$`G8B0FDX}CKCGtSw2udX2$g2ad+N@znVZ^wlnz0BJo=m|EDWC>FQwnn}
zW0eIc!+>4xRRWrDU~UHO{bK=d8Dq?2Nnx#J3<n)Z#G1thzR8*qvZ_5#1k!j#7Bc{;
z1Fdz3-f>;UYNep3r&n~2iGd;W1!!e83uu{N6_b^MCOi6_)8N<yFM)@jKLTCUe2cRv
zwFEK(0ZI6XAiK-Jz_1?_WT0{kl+{3y%*M>d47x>~i&2D$jY)&CiXRr`&;fpoumg3H
zKp1=j5h(t^;UQ7NSOU6`h6!}&66oBhX7JH6H4NThIv8oS1oXhD^PoHeE-7<B3A7VL
zp!GgL5|=?Ph9pZ!kAs7;iU;P#<otq4H;nl*&{36O7lPJ%mM~;77U_Z3<fbr`G8E~R
zFlVu(FfIV?PGu|sUAx1W#l8@Hye?=at%Re5vxcFWX#p2}wJob(RZz7-t(8J?Y6-Y1
zgEV8ITg<Bs6pLy>Lw?nUwI~fRP(=%BOXTIlhNQtepbLs1D?p1ti(`;(-s3I;-?s-A
z1;;M_tM<U*23{MB>jIA3pm2lq+CcHl!N|nO#K-}=Y7buOU|X2$2U?iRhrav(apufA
zP<~twB0$9%q*MXrN62wAphznMI}PVV56Ja3F!ymVvPkhUbMSI7bFgr*b8&Hq@Nj@z
zySN+RO6U!6R&b*k+5iVPn!zhWihLOu7^=d-jUB=#;DK6jkjR0bfd_BCfZGnBRg$0{
zOfjUTfSK?>i4KGbow5O{BVg;DKu(0T6~I%mU7%n^%LbqZ!z)m5K`IRa#wu~}#1*u8
zm5R8#T9eVO=oTnnfpa~W0GkCaGC?*ygBb%l?gtz^xI-Cq9}3FE8e}mZbYcx0;-IB?
zpc_v>SHB}~pyV#n1a()gGBGf~9SLfgC+FuSCzhn<C6=Uu=h(nwu%H$#cp$VGqy&D=
zC1mgt64XwWpi6y0%by`bv~Ya|iJ<G~K-av3_Wy%twIG+Ymt>}w=9d<O2OcvZ?LXvA
zl-3I1HfC~S9%yzAw68NMCp86hb`9k4fXd9gba1jsNKj8q$x2L4%`345&#!?lLxG;a
zlboMdTvAk;TmtW|V4ZqN%t0A-SHQfg9c&YP)KjA<H8BS=5ezBFHDEWcYicSegRkCG
zHwKNS>46ByZGvzUlpzD(;E(`KN93jEmlngv>p{(L$W}X;|M1(Y05%<uwQzeuZpOBT
z1+;X9(9QH9y@dP=y<iY-pEBs8XK*rr%#MJ&NZ@UQpb_b!yu=)ZV$fbx#I`~3h%(l&
zMfIg?1?V=E%=|p0^&8<<8U}_&#(H{skYW8I(8-6GiwZ$`AB2l7z|9K8efQuNHFJ>+
z<d_6T2Jm<yOA2V55H^wsVuQCDqHM|nWg|%G04i#4alq0d_$0$yT%gm6AZY}Ayd=u*
ztj(a3WD|%07XjeH09+1$iW3GA28Lot(@6k4!UAe^voTf)K<|>o-4_9sL0~_Ejt~G<
z|3xAtj0>1RP40zEj0|}KC7_LGpemFJa=H*=OBQPp*g4>RDB#n|z)b+K7s1VQG<SlO
zaDm(jYOR49rF={Rj8%Lv7eWS}P)^hbjpKqUe{j<dbTn`c^8$v2pi=;#XV%*?)Ubfg
z*I&R?!@K~z`EViQLdJB^IdH5gOubCzAhn?NB_1^_3)mMj6nWIJq%#IH)UZGrFq+JM
z;HcMREK&xYD9KTj18TN_)`Jv*&rYrbals+~9mE2!76I*$f(^SOZVXokZCwH#xe$_{
zjj?e_gNcDb5ae~xrZQ0LmWxpdbo3`vl_1Rf1^LC0sU%G%u#-YGIdIq5pr9-Q8H#%=
z4JaDkfoca(Xmc>K2=a09u!D<nj2Z$I{h(e6_+kg-8UkD=fR+q`j(`Kz6AV#^!;IL9
zKpSrpnbGS6$U*|}*aJ8}gGMPpOF4@{LmP?U^#lsKpuvN*(i~7PA6x`LG$GX-`DyUs
z0mRzW1n@WsY}f#?a2ctgRtz0qz*2I9H(<kxZuHIDd8ME|+wfI*kYWK;n1be)6>K3p
z#1(2l=k<Uc43bJK%}a($X(KK<N=ePh%*`xGP4USrF3|uPfHVsTDYigbQHn^Vv^<4G
z9fc$v(3M3>nwp@kB%qxk>S=kPS|JfcB!LLf?K?<|;Xno<xdC#78f;OI1~!)<yhfH&
zqSevd0-1fo=)i*#6$le*JApg3ERb;)P=bP#j^MTv&dt@JoCGSj7#IZ@tN6fvMig*h
z2~cuoU|;~TL49p-0RkEiu3-jcfAByEq&uaC+PVT4sGy9c2eJdywPawd;)mD(&!H>X
zapz2sUfh`y<UwhW$so6IFtYIRuz+(B)v_dLV`QQ|8(K3BlDojCX+bu9l_4K$fykGT
zbGJZk4R9I<kDR7tg6H28iz@ZN7u6`h76yUZS|FvM23JvPT53^hUNU?b4%{#SUH%L<
z2;3TkHr<f&D#+r@l46DI)Ji>t(Bf2RfuK;5m{bbdqyU*n2AfcvT$Bi2&IKMYhMNxB
zCRLi7rvP$GQYxrWNdXy}sE`R-2m&$}GHQ#ZGyu)|4~|m|X|Rng2fTDD3A|J~wE}c|
zyp=*yX;DsM0b*|(Vq24~0*wz{R8{~NH3}dr!MoPLbwNQ6Xk8cNI16wjgUVE}LJfG)
zj@W#KZPyiKDFJkF8l+npKKh)WrhqU6G_Rql13k?JGC|>znOuTo4LFBufYoV&mYIX3
zp)K#yl6+mr3<czfFSt{Sz|&s}whAD{7-oU|3f@nriEYCe+z^O=Ax1%$Mxgj75pu*Q
z=xomvg|y7noD^`_fpVonYF<fEW@<6$)Hcx60qCxA&{o6D<PxmL!%m`%MXv#%wkH;Y
zJpx<q0d^V6lm^TI9R+pBE=5p%gk{s6jskS&qmF_)A|-+pgXRuPi&8;MNODA4K7i|_
zOe_|FPs@bw>O-;uEP=%mNF4=AA@JMn5W3)j1-sX+6n?-bk`#EyA#DFBk~q{hSpI^`
zKtc%4t%e4P6?%|>y=SGMj<6III#5&9trXOu0i~k=x#bTe1TkB^7E-tcr=~*gI!Ubn
z&y^H|jsb!-l91<C62S9{-~<I~X+cv{5@_Waco+nnz9AiSs#NEo%7}>SJOWf9f@*4T
zb<PV)gxG6yP)io14qThR19!=4n41}07-BEPFx9fuvX(H`ur@QMfUbs;E99tQO<|N|
zsAVf*s$nZ(Ze}WSC}Dw!H8U<?T?mqasAtM%DvBuq-TcPV%v8f%16p*>0X2&yo2jU)
zgsFx#g-MbDbfH0UR|y-0SA(RwhIIkQLeTMJ>?w@43?+;;?9GfROxeuE+e(;f*g^V=
zj@7U);9SU1bgYD}h8<Zih!1ipvRDm67FW?TNNc5r8QNK4^#h-%RRmr@0P3+8O=DnS
z(Bv-q1KOPgJ{xW>h&2;LfJc)bgIL0#o(s531Mb{_x-Z~m@0uLwYX?Amm?AdNN)qOh
z{OnsSnc1n8w>Uv%O&Mt04Wz|{=y-zKIx(Qg1I=K7B98|&B*_Sx<KbZxV3cAMVFFG2
z%P|TtiGU8lVXEQ-M=rb}RkRh<odp{RCcqs=a1#uabPPd8LmNtJJS;^ZF^q;1sEGy|
z7A{8JTZViLKniOMX!;&>Xf=D0H)tFy8l}$ynmh-0K0%oR)U<$<hsEIB0;x1okXkLc
zI~c|JrA5i0>ur@FE%{`f6hw7fo`S3EQJxYHx(Ulr!B(L>MFHjbC3Wz1v*ju1B{ob8
zN*4lRJ*@Z!6?V!B`DrDf#gMRmKoQbP=Tb<6E2R{)x)JP6kpDqT!LvYPZ;&xDc=@HQ
zP@Y(+keF7I3Z9&Y^x)u2OhE&EpnHKpy}n#fT?7g{P*6h0S@TOv3Q7^R64d!dSbU5)
z^;t(9G}eUE??!n1j;-nf_gcVLSc1DzU{*4ys0Fi9kSijj9u8OqND>?n8la*U+~$Q9
zudsjxcl8pWqe&=Z7@z_R-UR`1(orWeadkktL8%{<x)~U&gkYhf2hTbv(>NgWK^R;x
zg6x2g(Lk~+wkg6{ObiTtNOlOq?EoD*2Ab8tvSkrGX8_9fMIh}E!@)ThOn`GPD1()P
z%!TG$Q4VHsro)|cK?6_7qYj7zJYYFDg}sF#iY<jBm_d`X2(+T8$|bxg5nM}yGA}rh
zffi+C=I0gbfYM@WUU6wrDkwEpg2xcSr(}Q@g`}n^<mV-);;7_6!3_>W&^!xhULJfg
zC}Rp}ERPAiDgZpv&s=l@T&{vfeApnS!e;BZa#Kq(@>84>b8?VE2OKb<VY;cHfB{7i
zXu7US&_6Gy(jVlU_;}FWo$>J~DF-zA1;St#fu~p)vKWfxYM|$Wf$k@)g^W3Z$Fm@3
zgrzWn&dUV3Rg>8-1U!<Y$y@|F`LIYB)YS#;j)Dzdtq1wy5Qvx!B0$%4p*wme69dBx
zkfR|pc5IBGLq1s;QJfA60W6zn;eiR#3JyZZoFO;}86i%>k}z+v7Nr)amdpcL3NnI$
zv5F5KPGBiNO+5W?kb{eMqgE@3#0g3}lRzeeni3q0EKD5C9Bkkeg_55@_JUM^$1fmb
zza0$CjGYYN0WroDrWTG`#wwl;2GIHD@r>aNc|xE)Zk0x`m5AUSYK*}Qn#_rX%nS@J
zsmb|8i6!|(pz$t+l+>is^mI^Ri;{4m^$L737P2I0ITk3GQ&T|mC7H#b#bQts!OLvG
z1s=GFN=Q($vjg=EQo+SKBsuDWx(|@8i8j!)A>$#nMLcM~qMeR{4cNAL*jd&f5$NDu
zJh<~-Y^SM|kO0Xx*j)&^$T26i1k@b?75pi1FJn5;#zrXtw7>^+^d@AI2BZTrNRgVN
z0B&o5J2i=Ul?th_;d{uYAdpJ1TcP<~p(ru47=Fe#mVQ2Fy$cQ}Q1$3gQk0mS3T`1o
zZVZ6Sq@<=PK<?3tPbmd0s!A+LjR$RIDAs@k2iod(h}#v^A@>bv6z7AMT4@xgmT16)
zpxQv2df~Q|rxb(EiOfrd9=2GXf-w|;-4U40fnt=}P^ma4J0+`Fp*SZ6gi{oXQ*zQk
zL{^#-tbG7ZGAP|UJG)fSZW>U+#BMDl1u3ZGHeFpu!9YhrBO0m%RJ|7Gq(CVMosyFV
z=BMOjrGbuTsjfvD9JR3lt(w8@0tJnt)DkNN^^~-%?3`kxT`kctAxKXTrLqCdAb`ps
zanPCl+ZY%aIvBD*ix?PE7*iNPOFd$kYnf`9Ye83wGJu=yEJYSI3@OZ#3|UNB3@I$)
z3^k1647H4)r3MRFQ&?+23k{fSn82L{mNXVI@WIod@}P#HkD-<|oFUH&yfS$XBSS44
zBSV!ER3{tguG};xi25c5=()jcb!>TDDGar2b!?z>gQ03chsd$Q)YgEezd8Jhj)R)=
z;KRW{)%`6-y(%T7SW_*A#gJ;Tx{iWsijIP6ktSD_EFxG{ixo8BIm${wwOEs@N*q-h
z9Ks-dun7oo#{#@AWf21d1L)*H&;fx(dqLGn2B_iyU7@4Nev7Rj(XlAK_!b9fD%Pzu
zFS!V<f&raPT*L&rERC^fEl4-KV7|pzwHs6{Lsqh|F$yvAFp7W<8U~-?2D({Cgt1B*
zJ-Z?f)vnTn*2&;|b*_VYMNAMY4#KN~10WW-CT?b6U|0yUjt?|UEXl#h!^;F(hRn#u
zSOk*$#i)a_1_e}M!z*IQc7hsELSYnVfHV@s89;|fgHFZ-Z3+OLeOb#~!&Kx1nlJ=c
z%M9WSAem;y1<at+8iN^X7)qE*SU?xy)j;K7GLU1-5<$y`JW_K&H;sS}Do#zy%meM6
zg10vz^C<agNF9@6(3!CrsR}SPkdxz~rzn8u;?;H3^%T(O-a&m2*q|<WM<&96V$i@U
zxVXwlEK3C)V4qr4mI~grhBzHq2RtbQS&~{(3>iWOr2vp#1?c`s&<ft7%#@VWJkXSU
z0cbcaFI^!aAvr%cDKjtC7PPxHAptf*j64so;F$(?09-9dSutqs4yc`%kO0vMsufcq
zd)PpQ2c)nCwfw+(A*FLFbZEFZGcP>{bc959Y94e)l@8=?15n)p4?NIP1MsHY6l<^{
z`JfqT$Q=bBb>P|&)h_6n$S`}r;R-r113dW!+3yKIUK+_7SaTa+B?eOt?q+C!XQ`kQ
zSg6CIN{NX&Nl7}%$x85*1&QE}PZGG(lbnpy&B0=3Mrs9kBcTo?3D~Mzse?{3K*SN6
zZH|ssPEJ<N&Q>liR<5oHJ5j}<c2+SdL>GZZZHg8$GcbUTo&pb1faWQ|$Ho*ffQkfA
z_W^nZ;Vo9M6K}CYQ^_s1lpMdrT#Vz&6B!s7E`qW%sL95_ufoW}D8*C+5=9xs0yXA9
zxfnzjLl)jPGk}_O?Tl$mppzF`I6#{{QkY8_iVQ%j-$1z)bZ#T)UV&Q1JdPSh(0vG?
z3)U8}rm%sR05E2;)i8mMPywwqt6}V55NBAxn!;Ja-oXgU?<rj33=2WcK<-34W(Ec<
z`8hei6nye9EU|z_pdo9PU=x`kptaK(kdgqh{vWiS9lA~i*3C}KFUmz;#0^?A0Xk9{
zWE{AJ026w8&^BgyMk=It1X_U(KI|K&p(HgYr&u8)zg!^~()cPU0&9i3NddCh1kw%+
z$$(}##0)Par-23;QWX-5iV`b94g@;_mL)-s2YXf*)H?&`ten(Dup7W(0omONYVTs?
z3(qu#goMnz641IXXej_$?GI`dXO<`wXMm4#O9GXX@cT57To1Oa1hkH?peR43G#PZ=
zS01=f0|gbh)d>wBEX_!;<5E)`L7u{s0o9EZ5|b2?QxsCuK-+|&t9ue5xeq>$0BU@K
zrYazdmcY%~B1jPi3kz6$fL#R&4al)(nRyCHprafsA;k&A9Cbqjb%o5lluXb)G<oTe
zcCrzq84bB@3^JAji4kxpfHXo3at5t=O3W*P4Nj>W7^-8mLLpaHD3n-%LQA70+8|a(
z!3e3@hBI(<KpH^tWs7PXYB{2AXh0y;K<>p_C4=g7$ih`7&=6`Za|c5WbCCjQReuL)
z9SE}sLo;JDV}V);LkUweqa6by19<#J3bfjT89et|qzY=oq=4ECEa)wk4kiYMl}xud
z!D$)f56EJ9M7u>4>~%NLybMx5;vc9q0*!xwmU<{LR%wG(K~oQ+)dChp*XxJU69qN%
zKm``~f)dc;5l|xo<kM!*(N|z!FcyKwdqEfSqW9kCFfcGMi!v}2fyOhc<iPe}xWWb!
zyLPuYz`pcJ%?nw{SoDjLfuV{`BPTUaQvtk&Srf8|vj}|MNHHkLmVk&HP>U2?a!Y`U
zZ%~o03Ash`7CSVr7M%dKyue|048#J(Sy3zl1H&^=FoAAeVGw6y<YVCgj~9dX34mo$
z!T}Tppu!tG76Mwx2)^kObPTUXEmH|Y4HI|=g<1{c0?;AkOwHg!;0wV;b`AJ$Vh}qR
zx&wk0vI9a3<aF?Uh9Z#DA=jeZV)TLBF$Nk2M-NYsIxbNLhGI}mKz6lpF$ys8FcyJi
zP#g>zLI61!<nUsUgG(47wM`m$OCo3h0kpcmhB1XXg#}c5bTBMnN?`?^pbn}zK($K;
z1L!ogM9|%6m^BCL?l4fHmI-RHq+}MQCWAHrL8^)r)Z34sg)q470y-@=PazSsC#ozH
zw6YRZOhbx!P*Ic!+G+&8P!Y8A3Vcffxa3GwPzRmCm{_6?D%!DX*Hch%%Li2(;MpkT
zYAFr0A^=v>fLj`1GeNn#I5jyx4>Uv$c3ePFD%erb3#v508WFu-uo_TyRIpV5ODSk8
zC|M~fXe&UBfy|462Ohvm6%rDZ46O{65)vTIQ_yh(U?C&WpoW5iQ)+S|=ypU<vlZ+j
zur5&jfC!!(*j-s*W5I*KU{#=M3|5VT^@0rs*#&COLO2FsYryw%fno`ABw0#oG3d-*
z@HGu!jj%Cgu(7ZZ0QoXOPr)T0dN(G>nc!ArL1J=tQ6l(i2vCa_Y(i=tXxCT@q<Y3E
zFG1ZHP~IyBucQNYPZ(;LVAEwC3^h!kDK1b6S?E*3Si=O`c+$)WDp5<o%jsJfYM5QX
zr71{F9#;oL2}?5rhz%ZXWc7p0OMyx(jGO?@1)%OXXjf1TLo8n{Bc$gP2D&DP31k3x
zO^zlb_zv!sOhus1`YooC67(#%nt_2q3tptTpoA4PwICO;1(o2H)gk#osRgN^U6Tk&
zoAlH?P@1>XWQA<Q1?Ax)(4J;UjQ~1_NE5wAxW!tMmXlbrlJOREQECCiaiB20B@EiS
zfM%C6a#6v<$OpPVhpEbtWH*NtonmHS_{FYKP?TDxsi4UMUQS;GE^xs`FSyi&UY~dg
zRK$V{+Y2BT$Z<sl3=9myAjg1)K^XYi7<st(7=;+Y;wW(iiYIuf1-jiBQfh&QoEI|G
zGIlW3FnWXA%<xhSe8WQx6H+P0oWcs)OM_O5g)m`j|Bj4O43viltO!d24WYtzsT6~H
zx;Z(}vILwEk;^YcISDRKGV`DUpz;f}!XA0m7^G#1*!>DFhaqDDB^l7efIwryiAA91
zc`;~XuM(tGECwC)Q~(l(bh|-iB*+HTQV#3_Y$crnk)<4Hx){_lSiratee9mOgE0%V
zYad$mf{GtaR@8%UL4_p<gYr)?Xnq@ER4sE2a|c5<sF?}wH>NNmO}T()T)@-xn#|x<
z0i;9$PrG0gCfuMaeNw@tM)69<TioCXfpC$E77@_7^5AnJLNZc|p~_uB*%{Kr<YDAs
ztnvZtMXojUY(S&=ImLE*Sc)cuBsRk#1rCY_K#e_&(y-_{sE7fVGgm<@P+%2-3Ls}>
z*YU7a>5=9-i2X&EK?fYLLJB)@I}@$MgSIo7QjNftLV^tJ8n8q185kH0K@I^A^YMc&
ztm9zhVF#CdAUTwh57b@*1t++H37RHK0j(<$sb#ETSin%jSi%Sz0$#{e%TUMy5&_Lo
zf_PvyOA0H94c;#Y>g}`nRk6mz=|;yEeE~I*cY<1%rl9b#0C|YHXcK4{l|4SGI47|<
z1ALx`CKIIRu^*%!TzG>Cus4`Mqa`43fD3Q%u1Fq69>yY&ILdq>=srEr5D2IcF9vNA
z1y!-&cCkbWQx^CVk`!i8Q?rJ#$O<yBQOlCT2AX88WvyW@GAUunV=7_oWXO{N-S^$X
zP|K3S0hbLbVasDGVee!}2Q8cd4Pb({SmxC*fET{7<*9&rCg4+3njlwS)UxFXfbHch
z;RXd)FEb-U4O{V?5}sy;V1^pz35>;hDO|PeHS8t4HEhj{Dclka*$fjvoBP;m*d-Zi
zIZF6y*lO5QxWyS#ctGRy;H5r(F-*0b;EPc}xAQR-{Q{|};S^^8sj~$&CzcgnsbQ_*
z0G$$2bOlwmhHU|V4SNk2XlDZ>Lm@~ddkVKXLoIvZvKqz-jK!D0?z&XNG=Z_`QdJJb
zWhJ~RybA<s*cLK2GiHNiT1o^{_&{Qi6CY~WK<%Q1jA9JUj0=QP1R-h{GJ=krE)h%-
zS|E@joFdS|08@vlDx4utg@vI+cmgBnW<k&_A~@tk5FrP-&ZR^IJOe43BGAGCF%8wM
zU<OUG#AX)cs<yB+GdVj4yx$5kgj}2oz5oE}XaU$gu*Hz#J2x>q6|&6+GKrqAkdm*E
zlb@HKT3n(FF6I?L_X~msKVhqJi&8;j6p5gnk!d-Z$t95CiK5i>#G;g()MD^b8qlaI
zWXo25QA%nNq$Lg=Faj6$iSQNw;KI%g)L8&c6Ba2Xr52Yc6r>h`hPe_!^W~5RKJt-_
zU=tKT_iGe^#=&8C+=4nO#RZAUsk-2?M9`vq1!zkivThRO=A4{V@ET`@e8^a{f&z40
z7_Jm%dNTC>IkbZX!5hgSxBEiwx&@s#3A08a5fYdR3JNgoFyl&#Q-e~|Q!CJngN$i|
zmZ5@HVCN}-jxEj2tOB3d0ja<t1}G?iny^LS&36hAgYuKIQj<%p6_7@&!TlAOLYPME
zVGYr(ppgk0X@fZyHaMSOq>zx12)lX@Dhi&a&4dRV_$&rc!a$f0c2@#qnie#@fSAyQ
z_UCjJ;D#cHLqY;lsHWzn<%5=1c|$JkgI>K0u2ev_<>!G~F)+Wu{F;I^_E!u^F<1xo
zatlD`oE0h9D&*&-`lo3q*(lg5*eTf9D%ja7DB42rp96JLA-C@$55L3g1nmn+Lc7Bb
zE(h8HqF@WUDHyVWBq<d#H3Kpd(nQKE&d&oc7FMtY-}s`S4Q?Yr+@%c`f|~}OxYa<@
zhk62=l9Ph1f}xRuf}^9Yk+Fi4jjf}jf}^9Ip%I?x-{@#{C(z8SEr>8Q0?o}vt2;V^
zcwiwTV~7w~kqubL(Gem9QDp~G3epIfgRP1O-5>}Wjm!fDEG$bU7NwWwrsjb<uEn6E
zYfAD#vi@nH<=Mr>3dtGync$JxVg=}4q5LAq&Of9a4B1KwUj0~9#l*mXGR_aG$w5^h
zc*qPix&*4D7c$f^g0_xjGr<Od7>k~R2ltBdLF*kElOU}JM70YVJFA9wG{wP51JP=N
z4Vq!t3~DoiZ3dYHv2y{q4Y3eB69DPuGJ)+b0(FLqZh;yGAjJ>|fUA6v-8C?~F{}W2
z5NrjgvIp(cgL?{M1TGWnaheDZE>IH#<meiNV~a#VZ4z8&Ho(lRGV_F<4i1lCM9ijE
z6hO|+hD03b$`0^oN>WZLxTy>tIe_fMD-vdAV8CdZfgA`Lb1Vi08UFDDP_qa&e!yH@
znF|RMZ~%kD7Bqmc818Bb^mqjo9u);ec16XYE;nNhhEqTh40Z}=uDXUHRsb}V0lKMi
zAtU-=22;^wP}s46V)zb-0J{QAz@4%b?i6$QMpej>HlTtHTzG;P4T0SWsxvclz>_72
zDiXtmpujRl9c%%0+?&ze2MHOF!&Wlh5(LjexaOpS@}_f6Vli|NBix~@VGh+4g$$p9
z50F8eY5=;lvPd1|U+~q`phK;THh{RGG*tv1Yi$5Egv~)>;3Wm%Rm&jPL$+GFgCxMi
z8KCt9MW8WLP3~JP#U(|>MbAJ>?Koi7Wf3FjI1Tp9;?%;@#GG5KxrxQu#kbgtD|3_b
zbBc>VBe%DhLF=5HK_k4Nlkp&4y$^~5u!l+*7#PApZR!Zn3IGMrq32BhK?i4WFmf>R
zF@Z?X6>?nQD-OAs*ce&<gYG(JV*;rWV&q_yVFZm+gAQT<9bm@B#Kk1U#Kb7UsKulO
zSt9qJhouN)3r6k*4X=PZ8K5zF&^!gG+W_iZfaWPcqxzbRi7#1^TX3m~#h|OZKu0$x
z=cFbUAvfkgYqK-+^Ad|HK@;m}d)+}TuA)?sU`b|KsseP*5ImL(sxLwNuE2Bm;7KMu
z1%(h$!w+&<F0>^C9z_NvM37Oi@k!7c?gSlpV-0D0Cb<0wuBc#Y!TV|wAd`Ba@oBKV
z1x27^yFk~Hr51s#%}5111?oPqe$a+4=wXJCx#&#rQ60I7McJuE#h?PDpfnG3pDgG;
zHyzNPFHi#&M3-cwg4cY4jX}&Ig2uE{i;xf90(l8^rdeiMW-@33EIYMQ0krJ`>LPHU
zfDM7V3%s5I<|fdBI{5Js@FT>)zJqxk983yD;7vl179g^xAO?U3<e}SoaL+x0T%|zt
z6=sNyEnx4I7Nx@WrXUuh!#5{^4x-ITOiImB(1tJO)=;+sFTF<WpMvj|(}CV!XA9PY
zF;A$j09gQsG&Klmtssno+l)E|2=byP=Kd$JYOq}jwvg-6z%c@9IDw_Wkpw!sx3mB}
z#6<<CLmG-88<at3Bg1Y>0>vh%_$>hm7UZNBLCzuu_ec;6+aa;7V5<Pim;Pyx-D_a?
z>wq`E#e*G;#p`fyLBb1S4m><St^r|WN!VsAT)Vlz`<1}kh@q`|P=J9q-zh-%l$GZf
zWrLOl<zu&;@OChm6A=5s!27SjJDPM*b~J&-ht`HI$Q~<r(BRy^1rBGVO<6h$>fit%
zVoO&o*mO;1@Xi+SO={o?X-%f0L{P=$0wTbz1uy}wxRMwc7}kO+E>I(oLA40PN2y{!
zV_2Xj3b=}i1MiV)W>^53b7WY^Sjz;N*r{bsVXk40XRcvNVF4|27iXwpPGJR&+1Ikv
zFcvwauz_x8s%6dN0IhCmVW?%TVOhXf!wQ<01YO5b!xGN|Iz&N}GjTe~a08@64=xDv
zi!#$Q^AdA(KnIC~7C~iJfmVuuZaxI9+D}vfuW0~>0caiuGWV#b0NV*%k`F38OJGOo
zgWD(YEs*(X3W<3N9wELy3dJRfMUWg=l9&!!ZvZ-fJXN76v0MQp04iA&GD|?Go`O58
zU}Hh27%CK}7J$y%gf0au1`kGqT?1Ntfw|62At^CA8?@*QRB^!khFEh38QK8Z23leV
zHV3-&P6xU$4770*e3Uq7m;`jE0jy$$8wT|w*bqoL1fDZY1&;vagU&z!^}vI{h9o2?
zz+2j&(-jlJy(#Ee1HAJLuJ*vaW2hq_%R&?~AvF@Bn+{&R06l{-0oj3|Wk8VP2y#Le
zXmL*>B)rQ(tB7EZhn-0S8tn%)Rp96TK<c>U{5))428R>49}iC&Mfthl<O2y%NRL5J
zK_NIFbi)ED>=B7Y0ko13q!Cht!D?QZlR{D}O5E~`;NB@l9uNRWw*t6<1HFd>#g{q?
zmHDL#puutQT0@j@hn!Lhx{o3u0puvy`J13y<Ut7pR26|1N-C6O<QJ!cQgLZc2_*C&
z!4F&8g=ILRxF{J^)q`fDK|^Ywfi?x3Bs+zq{G1d8n@l@U+OW~jv{SIrPqI_U%P-1J
z%mLT)3W(Yrl)FGlKQm83Ln%o~M?oo532nhT=wNry7+i8reld910yO9c%1$AP>BSl)
ziAcxYgDalI63_}Ew1Cxsm;!1#K+evGm<HOm1!aMw7i0hkLuxNjYYKI=qPQqoGuj{)
zy6qXPsu+3IK(so}0Dvwn1eqSKjubjjag-@=P`3y)ISuYQgNn!+&=Q)Jpk4>4eAQ%z
z48flP34r&*fJ7l32XN5~>Xd(kb%LrC(ZT|AXu$0je>_Z4Jh+g$#fuO~%}c>>9ms`X
z*Fi=tYM8PZYM8PZK||lLQ46M`=b%mu=sdxqgCLh;apX6cBQY!h^*z8AfI4e63^hy(
z7*ZG)g68@eQkWKkElOvsVM<{Dt&6t-Z`T2xkOQ|;ld&iPR4HMx`4)F-1!#SC2`JP3
zfY(rrRVuJB07<yz7a;-)NrNV95oo%-2sFzCIfCaW$R5y%qnd0*p!4%?aU>Q)3cg#M
zIr+)H;Eup8p47Y)1dkJ3kbq`ei(Z042`y|o7#J9?fLsRZc`?X>Zn<V-6an31&jdP;
znuD<jqyp3-1$7F+7?fT>Nd;V+f{X)Aax^m{>Qm4bpQ>!c@|@DVlzavF;zM=NMjh}i
z&yWLoK?Qz(nu22<%FrZauspRaH4jvnfQF8fN=rb4VhW(mn0fhmx~aJZC6&-s9Uv!x
z-NwMc0Ahn00^m4>j0S<$h6OVefmVh=(k`xbVN7DMbzzdFdEi4B5HSNA-O^+NA1Mc3
zX`smnjt7XLpr9xM=Za1S28Ms2Kn1yjfu#t<M+riZI6MeJqXM8M1&9EwWdtpdPhkc%
zLO@Ls&|VABk&~dMwvYx1xKGTMxDjmu0eD9hXsKsWYDsAk<Ya2lif-_fG3ZngaFzpw
zIH)#C1z(8+E{;I6qM%+QygQ0g(LkzQ<VClMDJh^jFI54u_7!9zN=*SfHd<F9CqFq4
zlG8!Gm3+{0%=|piab`t`g|bMMS5j(vW*(#-R)A^-T^3~vG6y`?k6UYMUJ6_zxJv;V
zH_k`}?TIQ)%mHuaO@(()AzpF<U20eaK4S%XT_VKapb7<6-xn(+B-n&FI@u*8fUmRz
zU))j*t_s0Hmz!9r0ITFc+tJ`-0N~a`5p?tjvK1*jvm_%VF{wBKVm+3s4s&M~s2m4j
zPz46g%b+Dx;P^@fpU15M*&&r!l$-%63pA8+vWipE42_I)vWru)vLLMNtSmz#BO~-W
z4_vcofX&5S*F+nD4y^zgs;;A88Vec92DvFZ+5#j4u|{1-!4Or_5F(qMm8GtuU}Ox{
zh*1KAax6Hvg0ci^1%$Iamxbq4S){PQ%&oV$5DBmd)OonY0TxKjOF=1LL5C1Q3R%z@
zbefQLL$}z$X6F~7XYg*&F-l?#48<T9Ge`<B7J)>HK<j0TK&$ABGC|c)6NqR8ozBS@
z6CJCorKh4DXRo1Ir?8T-hzm5L3#!{-#TJMSDi*+{DrhNX4S4Y`X!%(%Ly<M8<Odfp
zSgM&KP%W$h3lK1`N+c%6z&^SnA~xDU*D_Hz%~97aRvRPaL3JP4LeRJ^Xxt5A=>jHD
z&6mR5%mglHSRh9%R58aGR201htqEqn#a5b^nVeAsS!TNrG=_=GVVW?9RdL3|7(^TB
zn&Wc_=;SMeLsFPPm98WMx>LYo<1aylyCzf7Cs4HpUha#_30iO`FvY|cg@M$AuLpb&
zT64gbmzthfl6s2;bPW>t#z2&!8k9Ie7J=fY7<8&1cvl2NCqtD|3iATU=2y@ua2${W
z0v9r7ffocqCc0S|N?0oGKvUO@43P{e%-|c9!DlWca-j4Op~IPwmN#rxs3;LMy$l}d
z2CZ<+%u@i(vVjX7_->%g{5(Acr~IO#{PJRj;>x^|#0v28R)r$a9BP4rdUUKhig{q|
zV0*xqqoOn_i@`Q(D1p*UtP<!(FI_tYCD5UeCZ=ZQ7M6(CG+bq(ZWTghVp4KSYFc_m
zW>$7iZeD&tVNr2OX<2ziWfgXvD)At_AUkmDREbxD6qcZ!6_C;y(*1$-LqL}e<bfO3
z;2Y?oW7VM(_MlD?ycUG$0DC<XQg5YJ6eQ+>E(-u{U<DWH;4Tg5tV!@9;F5d=cxMfw
zTTdYbdd4caaw%3wMY0!U8^~@2P;HQuim3kJhQRFsyFx)1)KyO{PEIUHO+i#Ekp5R9
zZ0RhxcMV<;qo4u1wIU%QMi+X$gn|NS%r_w+CN?1fF>jow05ditwF0-%2?^>k73v6+
zG!hbGDvS(4tAWciGLthv9j!!#gama(&|$D}*J~<(6dF`0D<ibRu37{QEa!tZ`GS)y
zXk-9%hX-_JTS;b8W=>{FB{qlVCxh=8hTn<?Zmu9g0pwHzG^ZMv5Oyj&q!qyF8no;I
z)Nu!GKLa%jlJd(^b>IUY;B#>k6;eRg<Y|Bo#MP}*Pe_0?LlqPhQcIGd2U&olt`amA
z4cfi|YBYfi1|@(*kcpu1QBO?G%rC7()(<h!Q8&s!*D_uOB!grm)&d7yBZ6+O1~soi
zE0&7+KqpwFFoH_w6y_EN$Qh(5ERqb(jG)D(DXbt?3adCnGZSR(4QQ!6WCjt%22eEv
zF3wQr!$2#eFy_NnGD6DNeW1DwTmgXza5EP)Yv>6tTD2i%0%jGABm$pE1eL1bLR=HN
z?*M!h5BPLZ8_?7<bAC~ZCgUwe=xSnwouH}?VW$KxJHaasv3i>5NkC2LdTW+~#G;aw
zjJG&JYZ1U@2Bb9r4+3v^5J+M;2j*eW&OVUuZt=wzr8*TQCTFLDw`>)qfvV20pc)B0
z!N&(;fqnZ6!~)yVz`($u4{B_HCJh;+K!=<wf!4Z##Ibr29JiqEGI(7S^kfE5yGoO}
zDj(V{gPef?&Zv;eATJ%#LIyRLK}Uvw)+m%H6r~oHX2M$PpjJL~lq*pIG=m13C4!wc
zm<btBgOt#q_A|6=267B?8wb?n0C}qzbiO$#$$?Iy2d^BJ1MLj1VN7A{U=U+~uO4Oc
ztC9mZPr*Z4pw0|vqe5Z{%wE-$A`i$4!tJ1h!vbpE6&(UKm)b!=3l2+=eYZG4H+iO2
zI_KvEg8~!Wa%1FUtWpG<?w^-a=~&{NpQ8s~AqrOyj&Dt-BGAUCqJN-x0h<aoA7pe9
z=&mGxxS=dO%wQ3exB(@2P*8v{c&7{^Zb04TM9`J@m{9}TK%Ae4En<o@b3r#$LTWg0
zK?hnHQj%Jfm;)J3(^F7z1;-KiidpEnM&PAs;LDLfMJ!kwY<#e!C^4@XG;;&#MA)GA
zUeILi5)?EvanH@6pBsyQBP3*V6=(vq7`l5dKf4$-+6Ao~6ciNl5)n&}{PZ0a{2Y}q
zX4Z;Q3vv>ZQ$d|7P!A?UFE23<X_gJT!YB`PVNYIZE~FI!>a`#y-atxFC!UmyjZ74b
zj7=0kmKqtG!1wPO8<~LmFeW+*d5L*o7Ni@5(WVB)G$>URgJvB%7}8M&)QUh&)Rm04
z*g<X&E`fF|K+3_*_EdOLA`4Og^&BEe!p0!LDYEE4JSl=%U{h)t7#JczNfA`YGw>FH
z_!v$EB|>nsA5=&{n*5-}sE{!=O_oGa#IOQ*^c`9zfJ+PTDHx!V0CW#1q(=^#fG&o#
zI>E{zw=IL@Q&XUAPdtOW%AiSl_^bd(7qY3K(H`jhGPr>Uu>dxF3{JtIC<SRtO@Sm`
zNLL%e)=*OS%P$ADWk3~lICv5RR9)wn7Ad%77J~-hQ}asH;jv7la-_3{Ay>zOLnSp3
zbdfV?_7Lpr0`R4-$eu|94dWBz1GF1dkxfTr5vuu_h!9eOBzDBYq@wBY1_3BZLlPvo
zSOh1-Y6b>|bfjbm;-i#@pyC(Qtpc4xQtZRPz|hWsyyd(~qJ*J?F@+gSvNSVgF*Y;T
zGKVwdNrBH4a)5NHN|-@g%4?Y+>ws&RYnb90Ye3h{uqOJTtQG-RaiDQAaNxs|a}wx=
z-vaOnx`_&)Go!(cIZ(?#CkLFepr`tRSL!AzfJ;Q^Y!LXQ2|Wc*(2QH9LSjk^xHFZQ
z1Dbw<YyyGI!a&-Ou;mw^3<PQtgR3&|d=7ZF4`DZGX)B6Z;8lT;Q7!N>b6`y+pm{^^
z`i{&zusahHGEytzL5Ul*Y1<auP1Jy$TYz5pf^~zg<IT(~(NQoo)6|4Db0O`1@Y2}i
zeDJLxVC%qPmIA-1JrS`z9CB)GQettcf}t5|b)W!Uj0rw(Od%(+xCAr_1U-xsG=c@I
zcfg?vA0<PpXA+R7JfMC=Jst?uBZhkwqlUorD>%GBB?iniy`s{*kksOmVh!Y*q(LeS
z3=|9v6^x7&5)&2N+!PEF6%0}o3=`odfYhj~t3!v)K)h1W>1*ZrMW8L4V244^qre#j
zpc|3Fnvkk3MC}BY0U4)>+mX4I3fY-?=_&cSpv0w+sF0CgR1CQa1mq$RMs*{`03%+<
zm1LIWq+)d(WYiIII=>@$rML!sr3-H7<{=8>a!`6Lf)&Oo@WNOjH!&quAw4I*2)qNg
zxHLC6wFp#4fT#b8OY=ZlD)WmVHy?sL2*L<Yf=4t_hBXL9Bxrck&|F8s*hELc(A+>r
z!N}AUbmY8_f}ydFf{__gX-^=yqt$&QK?{DpJ^kEW{Cz=8H~%0I1zs}j;U5(2s*YqF
zO@bpDT;+KdgT^ZqpjDoKnu0${m8akf3T1a#C<jAA*{M<iJjx$jny28OrVyE5l#OfF
z5Y&bM74_gtbCC=08gS<m)Tl+>wGV2Lz#IQEp!$KKh9Op@ma&7ehB2M7gJBV45JMls
zM5aQPU<O2e0`G>E<Y(utWGXrjs&|fp+V_asMv{SnVK%(!1UZe&H?aWGZYoGbux&sm
zZGcva+d(V=S6@sl3{X2kekwZ7z`!sIUVSlEiNFdHgfRt)kn`?AXFzGP6x{~72z<~I
zxF0tkG)l@+1a>Fb#UK-l?tv76oej1RY*ilv149|eDv&sX3Li5QBO4>ve-0)d(3(l6
zB9J^v%?WB>g2EEqfCCK_gT@Cy({Br5XK1cu0`H%Ktf$5`)wK*3UgQ~mixqr(Xb~>s
zSHX-g>IHeakCA}^WnUJk?gwE|GAagLC<5{YXq2N!u7;tL0kZy+harWrm#LN^4|IPr
zb0<RyO9^WU8|YZ6W+w2GoW2rv&`zrboF!ZfL3b@Pflep`E!ZjHF5xNRtzjwQgU+9U
zMnxDwt4YNfO88S)Q`piOQ`mc%QaG9!7jQyuuU!bb$c|Z@p_VN#r$hi@ZV5|?U<!8%
zPcM@bXvq(T9Sb;1gcdTE@I&mX0ow#R+6t#_yeV9u<8wgEi$J!O2$zVY@PX#~Ap5ma
z*i!g=L3c&7Ef7r+0Ck4J3yjznKyKg_OyO$b0E@7v2&D)w5bt1EAdw=HBD#=if#gDl
z1yZ0z^&tBfh^B}^bl0+XFx0TcOLs8Tu*XZ6$kebmGc+^Su*J)Qc7lQLV-~Lp@&p}p
z2U<@9Jy@p%e5o7c@+Z)hwcsPJK=X#6;Z{%&0JNL}F?Cn016jMIkO*F41X{~k^oEIn
zp^7<P*XkB?Nn-jhM%!PE`fe*3i()`&0yJBK(KP|3Z1BhzC}qRCCZM(aE14m)5JjMY
zbEKRL$~F)#I6HyHhxWnJUX^q_XbA^s`3556!uwF5G+Fcmv{M3<2$9Dqa5|!h3tmou
ziw!K6AA?z5)DJpNg%NxmP!)@fYOx(gP6J&U4svxdXj?95M+RtaVF4rf)C=YmmWAMZ
z20@d);H1d_I-h$XxOwYW^bs_;0Xpvb7o!#U04YtjA}dg+f<~Djn<-hrl{aL)Ie4ci
zD6c~Lp2gtU0lOY#Ke+FC2JUb{P`?snb`dwoyP)H#s#tCGRg3L3<%+<EX@i%!gO{``
zg6sqze-a8Rm_tBBJct0>2wu7XYWqW0^96w<z%y;26RnD@LEI`3Q4S(N=M#eO;<?2X
z?*lpb3cR-!?xP|ekaNK6=h;9k576`tM@eFOJZS1hlj9a!Nn(0%NzpClirk!A+@RrT
z(2>3IJ|RdP_mErMC5h>dB_&0EiMgq_c%Ymx&|%)U*g>mzLK4$&aexweYDi)_ByI76
z>;nbWElzlnS_dk%L2h7R;bLTA6kuXw;$viC<YQ!FWc$y=B=wJpSqgd;p%he%kCE>`
z$3G?(sXt7tOut#!B$)V^gcx-gK^If;FcwL&pl$O2mGz*+2`=kF!+)Ss5_FAcFoPyj
zqBqL%S@0<#V)81uu?Sk)1nHnax*>>+tET|oN|9O&%F5t10jZgwquvz2O;XUT1Gw}D
z@7;r#0AEN8SuzMdHNP0N#}Kr=Ed?^K0qL-UbeHBq*^sFe)UE?^n;$fgs9>w0Zc~zC
z2i`fAnU|IiI?5l^owrF;$S6upvsKC{DJdwn($`PVEXgQM(o4?I)rT)PL1L9>W@jqd
z!DVdp6YUg0VhRO`>8UpQB`J35@W#Ee0;uEwg%GIpfUXlPMyz5%Sv3cmng=-ulz2b|
zV`3g;2n5tHRaO9{B#>xHVmfHGqe7yBk#0$8K@Osoo~Wac7!O(IfNZOVk|WYSyPV9t
zY|s!iXir|Eg0@01WO*4_qo#%uSQ->uN}#1?U{S<~7s!Di1)z=>hz6U3y5J0?6>UA7
zGI)75czHB94S>98<7fv;6ABtRnc1ldN}%vpQYg;IFV9l|ou8%&TAl+BM2P>v$HG9C
zS7#>Wq=NP%fQlc)QVftX7zVfAK__-*>wz5#a+Z#Qx-MuR9Y{bAWFxf81y+mF(uc>b
zg07tc38@0?Vo=2d%7H5xiv&U09b7zu2~fr_%3)w&xD3kjpxS{!49v$U(Q#(hs@>4h
zT~cdRa88Zz^?_tF0vQ#2q&IXV9-<VSVf7KY6)mfQ7Vg7V^TT@N$Vo5(95NwAQlJ2l
z1`*%@0TbX*$z@<*cnuE~wjvN8RFK1}QwC6ofH0_S48Ah3hM`CZbQf_7cxhcH1NaO<
zhJ_5B44^T{7KRQ6(Bu{948k-<@P>TQ351|pk1f%h19=M&cwa4OPzQPgGANIM$0`&O
z!TnLtfCKFQBhYZS0(kKg*hAo~2+<EMn~*&p;p+p+^a%?2MPSv)a<CF10em@=LP7$_
zWKd-S&L#<<T|Ek*4Op3Jm0-P~J=clQ+u;+_A>|<G&UWy$N(v%_K?d!?=d>q+uZK?q
zEu{q;0iK^oEmp|S15G;Sg7)<$rWY$9CWLK5TtJJHz<ZHxTs*_<K!;L;wK{_q&SAO{
z<Yv(Hb}Hzm98h-}UV1~yZO{fNuzqOqtPl)7Q?L>|90ck<f%K$h=9HusA$$N?%L^&)
zA^H>&ixCsy*^phzpaC+-pcZrhOCcdaBQYm4J<nFD2y{V{5@<LI7V@CER*;FH(l#eE
zIkN=3hXfLe2?<(S2??Oe4t$EZ4rpOm9%xn_?isKbz;g+?kgfPR#rX<}3IUZR8Tomj
zA!N{c<P-(a2n)h7T3Xdg$)K%%N>)nFrNt%rxv52<)xuymDp^4tSqq!})`joLO#_FW
zF4*e|;PM@`5&>LrCM0NRDCHF!LJ|_lG`Pu{Itm~uBP)pcItow=K%;Vy@*8w)7~D%>
zJD^o;B7_5~WI-o#rDaxt7o|bgMSvEJfXZv=*<YaI6*Re{r=S2&tPt&>0vobmAH43N
zI5n?06TCC7Bp*`SV-_BsX$s)mFhJ|DL75IzyCful11%vzK?9t+@{7Q+lwVq+faFe1
z%!9o^s=-?;6QD&?NWKDO<_$6f3GxKO`>7R~#jx{qK{`R^gJ-$YK$qDnBto+hIOahk
zu;>|7&(SY3KFrZ4)HNXiR1twp2gexHax5$IGD>nmciW<m4%(z-mf3;r0fj9H2j}Oe
zf>)iRh=SB9lvEa^+A5_NWu_?E87i147$_Jj7})4z7=fZVu^>aq&QQl#!AQqg!BEE#
zhk85kxES;nZjeRT)IqF*I}F(~DVb$DDVb$h+aD>JWlGS>7UV-^1#kreE|3&bGRwd%
zfsDj5P$EbKdlFF`fTJH09SRVi!)*uI1_}%CmasAnj8R)q#KKdl2FOd$utOS%1nCF2
zVjzaZgZPL>5y)*dAQyssrKzC=>K`CAr9cT5q#-^dH8CZ%2-GS9b3vV1)K(EF^3hsF
z;8uqQSUp6$9>{c*P(n1t6Cqg(5*VPxCm@%B`pq~(4YVx={d^E``a}u5#JtLQP_RJ!
zPE-J*gef8yAcZI>RzLv&F*F`-2fU>Tayo%P1(^W}6i}Fgcpwvr3{sGCh-Tyv1qU}u
zBM+W|Amt+{VIqV;JP=08H{hT{9g74tNI)}C;E@K<+Q)RzSfoG<Q!QvS7-J1n8WZ|B
zWKkQarweZQfC+Hx2Q=`gFAiHXu811Q@P!135l58a4$xpIXb22sQgIac2!0oa*nk-D
zvHPIOtTM(T@Bu=gH4!z;;@~wApsRhen6jCRSZbJRm?ar%SU_x0x3GpW1$0jrR5Xnl
zvWB9N1$>YfvtN~1UOpr-f^%z0NfEfkqEMxcC|%W6i`5lCB?&mmDS)^-km@8U70lCQ
zE&?6eRn!LRd2_<cQcYIKHjzW1ZoC0_TRO;4aQ~VU!~%D&S2EsW1#yr!(SwFX4aDKs
zG=om<5?~Z#<Y46aUnPknI13Ur8H?;egDcG7(coJgAX7nmQNiQ3kPf>%sI3YLS+H9_
zgIcJd5hVr-7VuVfK1LpPunfvRK~S;)#R|B)4O*X4!&t<V!dSy7#*oL9!UQ^0HH{&Y
zp@yl3A(L?lV;|^TE9S(L%nS^{pye2uX_=s#I#P>@GxNc-6p;Gf3ayO@Zm570CAc63
zMMpm9&{0tS0#~96x{x`Ll+3iW%;eIX5``q_S)7Pk7QR;vbo)zDSt_I%1Il%f<_&G@
zGq5wEg)-p^4X&D`8ci*y#5yIjOf9{{8k{Ec@)f`aQN4Nt6&D~3Dt|!5I-~%^UaEpy
zDjJab40dS<NH0j=Agzu--hvnApiS5~YFvodQ1cujha;99fXoAx>X2X>ZuLYJhiWk-
z+umXYCpS$-a5<sLe2Wvz2Mt}^;slZ4;Vq~rs04x(Jc!Dnhk=2?3RJd%Y8nP*0mdSb
z$S+2XA`Q^uf3PUDn+(zfS_uIzcs4LGFt~&6VPR@vNMR~rXa?WH(hQn=02Mu~ka+_q
z(1~+Qpvy8`7$z{q7R4~tve$CdaDXn_0Ck%|i+N&LK&Qgha@X?IaHX(iGZZDHu-9;k
zG32qOaDeDqUa&Y*(Ucm_6qZtk;+7KT8qQ|M6wYksqMj0#6s~5*CdL}h7^YgjTK*Eo
zW`+f<HM|QMYXxe!OW3m5!RNk})NrM6XEPODs$r>NtKkIAJd|+Mu$6FvOak%58EOUd
z7SwR1aDvrqf$d_Pz*xis(^10)QU}uo;ekZJI%UABkX5jOW_UojRxr;4;)4l{MOk2V
zeBuls{Wbg$x|tDbDj%vS+;ol-mJ}Y4FZ14j{lt~cG=Zro0^+9$j77UjxNA5|c$%3e
zFc!}%;Q{%nma~SXhBJ$|MgU|=2}cblgavl(9H>8;iiF_)`~r3vr#J&d9n?i|T~MDu
z{0TD?6n+9A84#`&%yWVIlc~rLY#PX)0^$r{f5P?DV2Fa<gzzJX#S8Ln4bKFoqMj1&
z8lDoq68<!%W{|I&Y6P<cYIyn>7#Z@oYCtFU@qp)<1Zo5!@m|B`#Nf?PD^Md)%T}mY
z!&<}U4N8@udwBQ~bGYDxGf0a|;Z0#sHJ4tLn46mjI;sTqiWcyUe`x{is5#I<D4>hM
zia}j-(CP+IwFW*_J2^E4bfLCFMrLXeXv0&bo`QmZK`M9vpcuOLUZE6p@(Z|r%`bx8
z44{ycnpUC<8hQo~GJx(b&QH!v1a)-v6d)^m6d<EU;Oku!z+;xsds-4pN)nSZAZvDD
zP6G`{faVrJD`mkO1K_95r9f6|g1WysIbd_ZPAN)F&QH(Ftb(kE0rk%F(?BXy^T5ZQ
zf)|ZJFN6W@Y=?LW)UAhl8L|dQqc|0G+${JEafPJRocwawDonrpl2j|uR!PtfZTNDh
zl+@G$_y`Gj%@TBoAhA*bWE9fzfnZl=78jSM7K0lo3XsJ;nR#iM6@K|8;AL!j3c;z6
zQENyMX_bJwdIxd{Z2;sDZpbNxi3+)?$r*`xnZ>!F@wkHglGMDCOwgKCh=sWYMfqi^
zpnc^<px^-QyGC*pv=xJVrXi@dRnS!cEjj{iYE{rhiV6kL@zbfrARE9}K7g(OE-nG7
z%}iE+F6L4Ib^c1AJ2^muL#f3j(7o;ox(fLPKAFWOpq+;x3ba!IG*AyZ6)_LA*Re<;
zH8D8@5uyb}snGaQ$Vn|rg{&G=PynS@(8vO)nuMI-pa4z!)(`{0!$Y7|i69#?z$WK{
z2Ey_SKz@P@^@7}1nj4Z@lv}K$08X_&sc9vS#l`u_pkv{Ric=lI!<^vpGVtXku)#J3
zutz{9fvf;I1Tij-<RoZ7z<py4&Oo4)4~`meK!fiMf$V<)4X|Y<XFx6hPf7)Cj|80<
z0m&DMu;VhVL1{1#>TZNNnZ*jmItmc)fgF_x86g9WBbJosBSm4c4lIHcO3EQ87=RrD
z%Xr1G4I7~H1mrbi@Iio(?4bbiIm~j9H6R6frMaL(2tgqY3QMT*nZ<B_D`<dEG)PKS
zFocJ^f`SqFU<_k;yGIu-4q(PZ?-&7%cV(o4=g2^o!ki0I1&%vJP~;bZ3nPU@P)tIK
zAke57%s=p`(uL&W6i`4Hmn7zu!2PJ8kdTmH08R;dL7wg&A)v9Wyc8r+A6K^!&>%24
z=s<x29v6qC7m$-cP6P`<3q4TQ1VuH}Nub_DW=RIZ&4^S3DrHNOGa#--4n%|!1r2oL
z5e7jLer_r_N+5fs6!LR3OG;8xG{H#+T`S17pn*JC76thTo_LDDMH(m(!B%gAZaM|s
z4U}1|0NS}wmY4%NRS`7jl9-c|nU{`mNkRhJB3rGrJWbfBF31)Q>}4FPF2ug8oPxw6
z)WQgqzu-MQaQy>1-y2%q!yKXkUHNRQkdOeoY*s^ELtPVTOIHzoqrvG*muRy!A!dUe
zfMvK7e85vd4x*aLPg6+CFD=rA1+hY6QD#X-ZfZ$pGGtgQGp__RMvpw@S(aFo3A%Lw
zGQ<qF3KXQ7c_pck6{_%59uL{#pa(j1EHwqTh83=(EU^gG)K;)X%)G*MWTt@1`LxW`
zBE&cl*lDnS7)sTp0kgXXbmS<=Or*T7pr8;9w-V$~4Ru}6Ze~!4g_O-SQMG7*j~~=f
z*HX||*VF+Q7|=`!%6>Q$Yb)pyRt!7#1LPEhmvFDDG}SiNGDG!%skX5unwYMUuCAdW
ziZXR|bsdGY(wrQZ(%b@D@Y%A^flSO{H&jcaqfK=b)V0-h6rzoF6x6lUbrj5EW096N
zYM{9w8ll5D7NG+XcWBOwj*bRLf)PkDC^jHmLqm`)pnyS{Wd!x3K%+O{ThBq~VZ!fD
zW(ChGGDb0j?+|3Gl0r!qh-E?XZcZU6E7U;!GY|%k5rT}YVaS5sG7LH?yM`&90km=o
zc6cf1JdPqW(5f6&5CQ7ZK{|xOph2;Zpd+f_eL+S(#wr!u?tpAy@XRg9@zZ1sDSC`*
z9@u1%p|_ah-JI5d3<b?db1)XEgT}l-XSetj@q(7{fbPVsVplB&*N|15s>M(y_>9;p
zhs-q40llCtFvYfr${AJ{Vku<NYHINQy(%+!RR_}vZhtFi7;5T3Ti*&AMw;N-v?R3%
z)HYYpFxIRxLe&SYMpGfREU2LlDlw5NNzm3&!6IEyV1llFE&?Bv2|hBj2NXWwGcrp-
z!;&nZ+y_20419XnEmm+930b!UUU3ADscw)a@By5lHA<R7w>V%e%3ExZM&K<LP?3I%
z1yuS%f);dD=PeG<T6R#|3UZ_-Xu(jCOKKWO7fAFLD=5QO-r@t7%J3E&cx3Vx2Pm+?
zqoVAPrjQ|M!4XKC5#)kU5VPnlDDJ?q3?@KPUDU<Ez>orpYS2xa3?2fkY>WboLW~lO
z5{w*-B8*IoO#fM!IKcOHaxlt)Pv}%*0?}fOQvcbQxfppExtKtstDrMFxfo$`Vjwvt
z4n~k^JWO1SLX4mb0l>CZnJ8)4TSdny#pJ~l#l*zcXxLjRDQSYJm>953MQlw4Xs0;r
zbOB9GO|4&yN>$*^FL~(-$or#H@=HNWKftSgimOc2!3L-!8Lh5P*l2aEMuRT;$w>w8
zwMi|m(gIrn-3bKk!$4K!7b&1P;}&CSl^Ez4gZz|Kn46*JlcN*_pb=sC;LJQm1_sFS
z!bJil3@MD@&NNdBQz__>el5@r#u89xnz2X;bUOl^%?!R9l{uTKXhjJ#XwW7F%&uWh
zVJc-TY62~6tzqV8C}9JcEzVHFp2Z=~0J%Q~G{^v6q{^DY23j^+%ao^5!nJ^VA)0Ei
z8g_^pafVu^yb7r4Z{Vi$fLy`PAkI+219AhH#Rjqq%_a_rDYZ;_CLp~fP<;e+al&<R
zlrTVsj!Jl&8ERP|?wG(>lmc3iTfz@=MTtNSa}A3VLk*J?_!ig_evpeme)VRkWyw=P
zQOSZ`RSnAm!4z&#h{3M}W(j7{<Vl>)iEStX+@1zCT=T$PK5*L+br(PS`YqVXE!Z*n
zMa2plN*YR_<q-->no8iQb5Mg7+J=Mm#j$i(K_;hy+J_(p$PMrf_2B+Uq5_heU^O&y
z(@;r6DIr1A8hqR;sE4KiYON#ML`WSdh;Ci*sxz>SFi((bBj|2((rnDn19k2(8^M_+
zskx9f3(%!WNS=jvYLI>Fm!Fr4)c(y(&&w}L1(l6h%m&GU0u&aoNDGu9L7@OUD;IP|
zF2WXA>mIqhNPsqez}vcz!W7gA0qr^lja6iV4vhdc?LiR_-9HFl)B-+P5Ns{fi%7j9
z$iAw?f|AmrR0Ytw9K>zGNT;|%O$3{flv+}rnwp2~e$WOnaKZ(3df;a@f~V_XTP#D1
zA!AGl35ak5br4}k%p-12MmP?1CPrcjsQ(YP803h=Owb(*kb8~ui@?bV6wL5c1l0n)
zUlbHNNvR6piypvt{esPb#R+!(pg;r#Q)XVe4tzBea&*8}0fDZg$jt?H<Pa_f9exO1
zl$2YVQ<4ekv49R41WmpbLreZd$o@E3T>BS+)^x!SXacWsh1{qC8N-9-W7t8EFm1?g
zf?k#fYCE9}TR_T!d{DlG1bYfNEkNuCbzl_|5+KPMoZ-Q1Heg3pLPxo<bjHAE3`1x7
zA-xSH@Zzw{Jn+q~MJ3=XNWh1DD5T}&Cze2KIHa`>DXGah@yO;lL#~(BK!|B8_!oe-
zJ|^ZsE^$@YQrARU7y#~Q!7eC->}b<gk5|`G0JA|i7J|6&ff7)o5;Wj~rOO5xiUB7L
zPzye>C|$u;0el*^2AVUq6~MM44D|_c4AM~u3UCZkuvN%SEYN^;mUR@AG&GSHsU+v8
zq=FZOE7(FyRZz*Hp<WHzhE=PsqX3B?kf5ywa?~o+C?p4$ROX~Q=Yvxl^88+MJiPmB
ztAOTM4JA+vAq6?eZwL(aiiQ%X(}_nF$cG9@Q30!TAlF+b7Nu+IC`89<YA7WZr5A%2
z`GP_N9+(IVK`hW!8PH&Wt$sm-CBid$kg(7|^*5qVR-9j2l$;t53R2K2Y<0x?XpkkK
zRG3*DpP!Nf>Rl^TXev}=I0te-fr3Vbs*xt-&Tx=U5Uxd71LA@VOG!<RFUgP3NUhKS
zl`{$%AQGFYnQ00dU`fzzB<cq03TkQ)#h?pH)GgJq=>b^+b4`9x3PiuAE{LgapstDL
zI*{sGh18tlR4kqXNy3aWG|&ba0d@`4G)L^Fp@a?Om}8JZ$ZN4cMItDnfd-I~VyQS4
zG}!^&(T)@+SXU+~scL{ynr5+rhAMdRlxDFesDdiCQc%?Zr5(*;B?VOlkTsfIkT}5X
z>_ehe0Tiz=&C${7nRz9kOjMx`J;@E^d_<g~s|H0LNI5uYU|Op5V3h(=MGb9zgQs3#
zHAzOQLUCelD)a))kDwV-&~6A&M<0YiY*4os+&c%Y>;Nq(mSg~3X97LxaV2BXV^D7q
zwCe@Z6GwEX<}ffYSWCdx?Z|*?A;@8Ri17f}HX)29-uP`TvI2F&aoOnrvy-Z(y3@o|
zADF3C{@9`nR(Tb}7YIS735vlJ0N|}-;MO3b$_BNfz>CtW#2^8#03MM*D9{ut0{7(+
zTa3W{dreR*T7n1-5CJ-at>`{zF&3!j4mooVyx9nJjwa+@Jj50w@Qx$U*nlQ0sE3}K
zms)g-4b&n|ExN@HYUZTol@u)jb+|#Dd-P;d$iTqx9^UJA1l@qa1?_WlFtRW*{byog
z`Nzb>^pE8~2P@leHg+zk7#lO&Uk+A~dXE20OdS81n0fwku(17MW8+~2iSYd6U}pQv
z#tQ0rb1`Z$sempX1=)tOKn!$u9q14d(7;x)8Y2VfL<C0IviWw%c?nD@%q<+9Ozn*D
z#q!KxHd_jN3r8&rn9Y&G*}_rF3OZJ=8FZmC*Fr|nX`-N;YE!s-nQGZeSeqF@cmZ1t
z3uvp^0`?T1g^acAP%-9(j0@OPK=b|_P!U$J2;V}+TFx4#qBA8NC7ht!>T1}<8A=#x
zI7&D`T|99Hh^RRDPF#>p;tY`W0kvFtdN4i2sjuN$z}3!_#t6P!4zl}^VF755Cu1{%
zI0JZ=nri`jir_-fk}RRbXB>DtfZ&xINR95yJkVG&c#2aYDJMTUyBIRk3tM6jIkFmj
zZVsaL3|6R6T#{G<z8(g=&>OP$N&!+tD}bs^Xxk3CO9-h4bRjkc!}NpNBdFaQcz+do
ztY3Z_!Zz^QXox`ypnL_nei}M&1MOu&e3hC4u?V7AR{<g#Tmm|`T^G`ofNg|Gss!KP
zkXi(q4$4i;OH5CNDu)D3F-Q}{90ky%8MN6A4+79ZJf7g7OighD1tU@y3f}*N9f$`r
z2Rbnd+Cx;DlcG?Z0Xp#o(&EntoiqW88L(@i?H8C2Ky$$P`8lcJ<0w)xLFdZmrGsX!
z!E<ns$bpSWLi`L0iPXw`#NI4$53aPR2-LFxPv2UD&j2jRR{)QMgB$7)gYwhBb9TD9
z`Nfb^-odxw!DAlLt4v6M-ctvuSRFwNpfjN{04XRzg$}51l~@8g<*yiWrg1_7*dBOd
z0L|Tj0|-Z-0Ie~WlA5OAs8NN|9B@P)=?7nZW?%p|5>#m`D7Y)wDmWS;37~R};WAEe
z7RVMSCyhj%B%NdwtDKyW?Sd$C)Id?9ppcZ5h^z`MfNVcl0AZ~&+*%hn3uJO}L1L~(
zg-#`!>7X;~6;jjFi_t;>;#u&K_;6!D4K7IZfMg+Q1DwJXY!#vnAqU-nWQt32LFc=>
z<rjg@Y|(&@4S;08eG|}XPtaaGq=P<?x<t^_s-OUFXt|^&gZ2<;D5a#Pfo^0+GC&*J
z0RoLH;cWdQ)N6uv_bF+D+y6>dNZkogdk)s^f%plU2{l0e(1B)Tus_k=mIm*IfeZn=
zRU7PVuz5)SE&>lUDA<CovWJEVC^$eEq|+HRssZcJA)E}lhh78ZYj`gcwQB=0749*3
zJVC@2Y-|)X;HK9=`h}3NuYnwN1L}bybypLML34@V;R5V#u?4vWVmKlsK!F6e$|W^T
zp$0VfkeQwbHVD~Tr0~eiPbtlTcQ*a=QvHiSn^eIej-(7c(;iZknhNT=BD6rJd7!O&
zP;VUJ8n_O<0&v?LmiWLNl*RDT(dsFwY3h*r3KS6v3hIt1+-P+TP%FF&L};qVqNub&
zRT-`BXb8T%5arfG0|WI~&|Njr>h2&jAeS5(LB!M@VRs@LtH;J78xFcR5gwHaSX}Ak
zglaj&nTa4Pl0ZZ<h#=@-CnuPT!NH)Q?&JhIY6a?Pkah)iE6^-uv^uB+0{afcf;u}X
zDG}^&G`Bk=J5AjMnTN$EpfU+ri2~I23Xl&fK?KMhh`<252#E`t>V&!;RD^+C3keK(
zoPl*HL`SQGMv_1Q9SfTU^~0D31<hH4=8TF#hr4xv+Kfmy7l3Cg5zSmprdvFqb6QIa
zKu5GEXW!z66dmAV0-_9L)Gh9!)Z)|<h?-Rr3=GAfP7niQl@dfbw4_0Fo{*HIv}i$Y
z17VP%#eNJ7pi86~KyAfr)*=DWMg`EM3Ftsb$aUhNbNjQIi@ZQri-XxLMRt&rK~k7N
z2Sh^I%pf*Mw<e1p_*}9o{>+@5)bzw01yDyLGcUbL0MxBaR47PIEm8nA`71S<i@===
z(7p@so`#he7m>3imliqa=d5HbvIq6);JwFN{K*-q$=Ly^sYQ_1&RS52fcl^ei~@|H
zsW#A6)KzLY!Ujz<?(i`JUsP1Xh!!3!MM@o@d1z)(t2d7a8V2C-0EYoHGz|D4UM?<8
zf_WJ1*YBV{6nGPdBgj|IAOhhvKCtV8OOqfz+Y0g-Xpag5#9vHRs`z{b*N59vUU(zD
zgP}+b6xn4A#YRw%f$xzAiGfZ+&t@oc>tFzNUKn8)aa8ex{h6mwng?+jI0b-C<N<jU
z>}9ZT!FP0E^D-~k%b`%+dq6(Mh)WfS(W#JTEh3$xXsu%6R47^ix`mO=)6d1#F9duD
z?JbT_KL{6PQW2C3Kw}u-oB-<NbufT#07v9cO&0JatVOp$om21?=<=XrP8o|FP+|;x
zbjL+_S6v>5Lt&#CReUf7kY0f%FL;u?2$a@}<}xub6wLw=o}jQpTs{KoKtpEK!4v4x
zASLrb#7&TsxNixewq8M98AzU)4C<!4fE?@!BHTd4a*&ui3j@O~mH=1Rpj&LA;J~`Y
zR-6mg2uh5a%tdw}wcv~g_An@%irN_%7{Wmj1adAzAP*BCGY<z3I}e8xqXeT6qYxtt
zBL}z#F7uCxnF-tjm-!FspR+LwF$yq(^;aoJ#~4&38|cOuRHT@J2n!H14a7`?Fw<hI
z#6gM@4M8$VX&^=BF$NWB=CM^w@m5vrppASbiRo1m=_Lv|B?^hT1qyjd#gOwJ6%q^b
zi>uh|Y}6E#)T?;ZH0%RxKns;hD(#ByF*7h!F=<*?2|-ppLGJ2;$YP8LfqMPm{Q#iU
zSOUuN3|UOz{w-rw5cDtsa66$0X%Sx$<VaN5Msd(?bx?ViS&|7_)|*+90ouZy3A#Ku
zH90de2Rw6-m|T)tRIJH-i!VN-Bsa%3uOzdi(l@c7=pSe~1slY9SPy!tVPIgm4T=wN
zb-+{v;#Z02$7q44_qAecKrBUlO--#TCN2FcerJVZ(D*vob*XtJRs1%Jy1LOZ#WBIL
zTK2lSc2zuJ2ZI6!B+aC!RmD>Ty5=0z|H{lutrFDN*RZ#WiHXUpiH?iOi`CSs;?mcL
zn<wb3t&L^{v$CF6l?bd~j%+*l=$~Iq3Y@n%K^7)@mZatuae`7^Gy?+zMzsoB0pI{S
zFna|P0|R_@5n~i{DoZMBGh-B6DoZMRGh-A-DrYKJGvfko&=m>`cv9IGGDh*Ha;EZu
z#Xv(TJRlt@EX_;{8Kd}91wa?NEZ|OITgV7iEto3U%&>qbm17}e3cEN1f+x<ffIEd_
zA!C$Ks?Y*q*r8R745>n?f~g{@A}QR>j0;2;GNcND=F!C&oIvV%7BWVOrHU;OP8A1L
z7^wm&ykM8`f$amCCXp(T!VeY`fQw0{N~TIUF{BDQfe)05l1>#!5d^Cdf~%29<xG`L
z5f*1il>?E@ObfVEL>4ke$)^gWh=SFMEo6*RNEJvC2lFHrGDaz;DyB%LDvC3tNQp3j
z{Ug1QF-j>_1THQE5^rWqkrija6b0*$TgVutoT|J)B}E=`kQO6DibARaSWa;vW0Y#D
zTB=g2suM%1GB^a37BYhES6avzrJgE~q73G#EM$z*NYzZSO;JlxZ((d^jM7TgOtDMR
zOwj`Kv{MCAw81KM7BWWZqza_yf_Zui8KZPl1yc0EJcEUdQF^KR;7~UJkxmRzhN+q<
zhABoZ49$#DMyYD4#;GPL#?6fU45_Bg44^d^shp{1DaI)#y-Z*~nx~jTjtT>jpyRt1
zaHp6pWQ?*%wM-RBwOU}kkRjE=i6O;2#iEx9Y^&u$#weRq%~X~YD^Li4^hMc%`POj0
zU5ZUGgQk5^KLZ0pqC7WfJPb7NT$HL%4BDp-O7i)63OV`Zy5OM?l%blE49H|KXf_ji
zay0a$(X7(k0$uPq8lcHwXz`N*TKb+}0O~1OK|9vEpjp7wqReE_AWCkr0(>zobQxx`
z4U}PrbZKr;YGO{Y4T!W$fOk`1ld#3fnV^y=Ei+jm54s(}rZ_n>9-<uDb<zbF1^IdK
zDc*vjeDDAh$hC+bX|WB0Z3j8xL_t>}FSP`8`zPo$SJ2juR3umXIy&3rCML%xrlf$R
zusF{%pv=T3v!KibNe$c;o&jZMAW1WXB;3KC!TuIz28M98DTyVi#WtD6`5;ly#BHiw
z0%*YrtiJ#Y50JW&%-mEIr62)>hhR!WLp@z=N=q|SFr`4rAW;{#kRSy-9%us=jE4)x
zgHHUgOMt{Ic*6&@!a+LS17;QU+}MzOPsmbVc;I3va05+O<Cb<wEJ?*L3-T+53eX%x
z0jLrQNlY)skS#4pPApCh0Ue)<DVdUAo`)<A4sa~vZx~CLA+y@JSLZ4#fZ7Y7`OW+y
z1yFJY<&C7&BG6uc=q+7|pw$$q3W)`vTcC?F6H8LTrzwD)0O`~#C>WxQ-zg~Qq6=uF
z3mEGeni!f|qL^Z)XJC|SgcxT7nQoY>Ylu1&hd50YB#+_aH0pR6ykY^xb?81AKtDpy
z2L`QI#}~C3sTI)Zgs)@*1sO(cxw)Zulu!T{K{lh|vpEf_2F+f5)R@#Y);A%==G@E*
z#4>z*)`Jx);BW+rjfRArWJth~nYjh|MI{QL5)5uIMw$f4;ylV2ED0(Gk;VzJn}G8)
zXk}FUL6K}|WDLF+Nf*S>1>KN@V1a}{B5((TG$3Lfb0Cijr37;Bi8eGaKw6EDl98f8
zJS0h!f&)z>dKnT86+qICUZg~W1+<Nfk<_3TG0|Wyk~DFiM=dYVeXEDxzbMieK1Pv+
zdJ!IVwDL2yvIE6eMyAMTPa_o}(MG1GD8YxB50P_Sw1FP7a+K^At!toXjx4LJfGcYw
z=5IjLB=F!N+a}a}A8m;44p6Q|*g{HXiw5O&4Ru&1L}W_@3nr(o37PS^#SU$eR&j&k
z1<C<mcUQ#`t*sktACsb8#Rr;O03VbE-pK?$jP@1>Ec9{r;Xz}ukQFL544{E5X$J5C
z*^v7b5LYSSS~s#p61G-F5~J9H4eb<x?zO8@g1H5>g#r?hP_O91WU9o$-T`%_Q?z6B
zVp6nfK%};26*p4rq{;zF6{tU->KY3ciAm9hEY(NVjIP99vq}ZYILKBpERFaoS(vFY
zdiF6XS{l*F7TMoohc-5f`amOVT!@BymA8hGX|#c^X>5&Aw1KV(_@=|y8bf=~o`l$H
zLmi`9O^p~m!iqGjjccoTKn-|U)4xgpWCnC!L$#rfN$o9AqJZsA10Rd~5;P!CB?#I)
zr2uN*!}Mx0K_c}MBWSG0%Bo7JI0ICBA*;ciPC)yNK-&sH7tPmz4?=8aOkvIjr4|;{
zBaA>pE}%igV$hg`9B5RPAy%xGv4kOuaRE~e<3h$FrWA%S21bTLrWDW>G+mGbb3om}
zTU_y(1!ZROpo^`FazNvFXF-FEpn*5Un12!IcCRDwbf<$e-62LpZD6-u6@3Pc3o;hf
zfsDnKrV(bdTUn*0rKMR_2|*Gpa!`RI#tas?RaVFmV^pgVZKbChtBEFPZxv&RDx_I$
zQd`CC>*x$K=og1-q^@eNu4)QOTz~=<H0}n%;Q158ElstIkQ=lT?=mtlz)L0QI2>q$
zX;CVu*`5g5#SZNufqK87{kx!z(x5IVxWf#-N&~**q$D49AR(+rrw3v{dRw4I19<63
zv4Sq#P6b_swA>O93A*SUe6L1QDtL-JH3hVC1Ed|)InpaGDJlRlKnqsE7cPS~nJU3N
z4%$$Fumwv;2V^<OEZBZZj1+*}N!3fvFR0Xj_G&>o6%;@>hNOZuqqoa2OoDeCLESzL
zq(&OZByd{^v|Jf#7&s82)22#>mX?;fhDN%^hDylmb-{X2CQ3mjMT5Kp3K4J+Yk>6X
zC>R>)C>R?;YXOidjL8eo!ONiW=i&g+U9Mu_u~_istQ`ysnHDfDWC&*nW?*3`VXpLI
zWT<6kWT=t>-N#qMSi)Mv+zg(;2nSvN$xzE&$DGHN0;UZZ48T(u;9IFR*@{3(?iL3u
z%5JfMoLU544hNpT09`16IYq@(mb#Mh7IRu|2_oa(VoNS7iBHSBC&|E244J!OViW^y
zIn=`+?ud*GF#v4jN~WSX(3ogEhya%mu^<*GIBxNxMB5pVeV`JFL5PR7N)EqWzeHfk
zFhteEO4Zj&HCRtIjpV#2j<~3bv@8hEOrT%}r3mN}R8anb4i>{?z-a}f1d&;2l_inG
zg1GEi0?uDpw?`w5Ac0(uHG@L5la@U}hT+JfP~&i9&=4bID^p7=Q%gNdOG}b-E7)4(
z91FUGO-I4h5`rx)Ee#9|h|0yF+or07P;)Uf2QyW=!E-P(Xk%Fk3$Zzv6`X^MB0;$W
zHQN?NgT%nu2AqLFd8Y`JpT2`~3@nEVfpVx3{#*kJ1FX5UC;?;z*mSTxAS-SOqGV5y
z-lrf7;aOCPuw_-|py{j1)WjmYn3QUhT1^dmD_xLKZhl@#hFwfbObT2mC9x7BplPpZ
zU&R9(*92vwsy2`wBxBIc0Q2DnM29HEf;430mxAn#Nzt?dadR{CN=s59c4&Y_Acxz6
zMKnN7SS^s%n)V>YB~^A&HK3Ly$c<L^AX3x5N&wkapb)77H63C1V^>?$YUm<29879K
zZ9^0xL!;VTETG;6N-Y5@yg}g#p05M7^`Xr$a4i9zvtvpWV`5-H9z6vWHIR$lAk%>0
zGpWHh#FeKefsdqzh!=zRU?2(~95uBvxCASJ=mDLSUJSXBFAvm6$iY097Id(>!a$s?
z52|8IK)a(-K!>w}mP93Hr^1G8HIzbJkQTLp)q)O^h=)42Bn5HEYYEr@jMHN=QZ>q$
zF#IrB1#Jb00r08-WEr^Kpiu(15@n4R$PJpvXOn_-1QdbJzd*jT03-@p2Bv^~R{`8r
zh#Lps7K1wsn#|y-8t5c!JlN3%sYOLgK{p98qn)n_u9_hPIIHu5mBRv&LkhM+M*vGb
zjH0yY5U7a`x&)=jA5??{fC%u_AE24gDiQEh0PM(}RLJ}QN-Ygq!vJbEgHt|arW&-K
zX8|MpHliYCkeRr80m@R)o-L`SvfwjS4Q8sJCSy?q3j>2DV^I=_vWHyS1j?dCf}lkX
zuR#RpjwSF-_O}G!WhQh2;}$D;)ae!<Tmn3CQ3Ss71l0F}TvP(yiVz5LQYy&6P!P)<
zG<^;oFo1U*gFrIiYfZpQDL|_&Zt;S<J#ZzUUehfWP~Z6$2W*C`C=qn3DjQ_ny(k!D
z2;#n#5YS=@9^}cVqHvIqP&}x23hC=XXRdAu$Ai10D1t?jAj5^@q0Rtx4WY^**Rg<%
zhEHAH;zpVXE8+z$=12rN2ei8777ucl;FbU~4^-OTVgU{56h(l7C>%tjf^?>V2=M+6
z@D2{p+KwXdg)pE6Vz+p~=e;Brrxt*=5f>$bw1Mx80qyy?1xcW2b5%vHAVr`Vd`K1n
z*Nb2Rlv%*p>>p^=LKy=C0|z5ZJ%b<zD+j9xvlO!kvl0^@lM)jblL)g2s{peIvjj6A
zGasWEqY!vqiO@e5W~RR^EPRZ7j55riySjKJm>78^_&}<d1sItaxdeH@x4&@xV`Ap|
z%L7&o-W9^g^q&K?Q-oE3S%4Aj29N_mTbbY(l#jqm3_!P|A(j|`#sZ?4L0j}&7@}BG
zK&S1o-4cq=Nvx^_pGXOsGfFKgsYE%-7GxF(gY%^nXn26Jh9RDzhA|67GuAL>G1V}{
zGl5o&f!7>qG8Y{Mg&H_NfbME2k^&73fI|&TfP?N50|SFLsB{6XSYiMl7EvXQ=@Py8
z_{_Y_lK6O(N)l8-g3eL^RhGq|+cY{DQW#1ZK<6mbFg7!GGL$fOfKF6kDzYkJ0(ZQ@
zn_D^<vY1m?QW!u7T7qtdXl5*O$YkhXh-ax`$YRZ6gDe%yVku)RN~&R4z}msEkg<ay
zi=~Fyh5<rLf`(66{cf>?vsh6cN>Kv}B#>{6LE|V2pnzhCm8b=ozyMl|n8J|G(9B$l
zG?JppR8-Bvz~Bd^!8gCbE~(=xE-gqc0>?_x6HwMb1RZEN#TXQHpkM&)9jemB8gS{U
zCGqiyMjm2JWeunzU@v+Jilso1*~>upU9-o>=N9G1$AjGji9%59X|fbu04ZDsA})gp
zBJd%}ppAi$JOOqcC{Ay&$H#;1GypkH1e6#VK^vFE7<vA4FoBK(;bIhEtdhd*SkT?(
zAUlf?r79?$6xD<BH8=ne1jxpsDi#I?Es$-Xpx|KSU<Hd{WCu_>0cQtLw;PciqL|Ye
zqF7QP=lX!wSg@tCgAP0eueabxWlsTZeFBMdrn0ASq;P`8xl-9vxKg;mZ0;1EU<OUz
zqKTlD5!Yd(Iga4HANgqtp?R60jXOw7qaa7p<s{~%mnNpC>O$@t$V>(|xbo7AL4!Qt
zx;!BPyd%0eAwfqWApx{39l`>O!nmMqj|mCjb_S@GQ4HGZ0ctTgf)+4>ERHWuEdg!m
z0dM~S?OCZrx?-XzF)uw8ywwP_c?H9%U}qGkmVlP~D<neBOGY}9KOrF=VgSfp(9KQA
zEf=UPXdi@zL4|>Vk%5i^h&E5v)KLJ7Btk{f(lm9T6A*BRg99)*F%Nv`C1~jg%m<K@
zB;niiGxIW1i!w_R^O93Rrx@geH|&%`L%le)1ZCI;oR<`wy}UJ?Gcxm1i&J$Jyb=o%
zAuR9wqSVAZw5=eZCDPz<K*{Fdq{hI&04@(ft3uNmY8gQ%I=L{!TGTStFqJTtGJwWn
z3SDZLvY1>LVijtcYZw<WgL;6Vwa1`COe7gVr|W_iZZR?xDim@-k{#$yLQnzL%m^x;
zf*CZ~pf}Zl$Mr$k7R4o?0te(8@Xl3GegmI9&jT8|1(||;?)*1U<7^)&3!~*A(7E#=
zur^MWDKzjvDMt^SnL%4`i{sPsi=Z)zRGxqqbAWHZ)MPKJ1?5msHn_zORale`Dp_nm
z#1atk8&v496oE>RBG3-WTTIExx0s5c_m+cQ1<KO5M6p`y1Ipxlpdy8dg^`O9v}clw
zQGu~ak)VT7LJZW#1QpTXxC4!lr!X#HC}AvN%3`iz09}s<iV@I_XjR&v9VmJEdAj8p
znI);<ZGK4k7__SzeDDG|6M$FeYO)rAua^T2<`>Nag|s^;%$q?011=)LUIY^$e}da3
zVIW_DVv&Ivetr-*=n<KkOy{eEoDVK7lEBC7fua$zIup0kZ?Qox;sLw<7JFtfSbq^t
zAAp*T(MUcJLXHct-eNLcuLW{_UTH3P*;h(tdS(f6Vc!A@Y*5&PTo2ZV+x4IpcLI{@
z1(012Dq=C*4vHvn!U1(oKpDP<A&XHQ)FNQ4(ge8}>}Qy>afP@hQxPcOia_=w)$E9b
z0lN4w70F?u$PR;9QS7J5gS7+F01ARPpyUURH&6u$PHIS&f-Hbk-C#?>1UN~8@~;iZ
zX3#wr9E>cyEKE#{T%1gdTr3C-uIw;sSWu<{*RUTLP}j7kFr~6&v8FMlGe)twGeDZ2
zDWLVO%uyWf44~^%TNqN<QrVlCqd46eQrJ^CS{PC|z<e%u2FS|P6fQ8I+noV)d1?zo
z3J;ji<Ia%6o5I(^kirM%^SU#DH}x{42!Q!~?hGk{DMBp_DMDaAzdJ*UaEeF^LyAZ$
zZz^9Ze=}>8fICBqXo^@1Ly8z!ji5V2ig=1d3qy(om@nkckRq8P)xwY>1?CI8Go(nT
z$h0t|$bk7GDYC%~nsP-GK;!w4g*lFpqbk9dDM9KS&{+)N8VodX1L_BZmP<n00LXQ9
zu^za#c?oJeVuUa#^?^ee6gkLk7|^MN=}b{9;8O`%t0ds#1M$#=qvw-Yl9^{%r4Os*
zLCpe?o513_hVXWZb4DU)B~WUSLJ+8NpvhF!&ceX(vJO;oGre5Ez`*eGKLZ1U-%3{8
zNe`Tw5CkY)-C_e<WLOAFTA=z0RC*WnfNrP+73jzqR6c_}2`ZaWJ(<oJ#gf7t%%I7F
z(~FL{yy%GAi!T`%85lC_85tP-in>902jO-w3&{hHr6?ZgqrL~6aCyK9w+AvCKpyaC
zBEkbsl_(zQ$L0Z?$t;~Ag=rBY4#Y8&nR`)cYIc<#dMX18<8ptorl2NMW&tw;L*{?b
zOfOR=gFFL6rl>pvgC<j^1c)sQVJm>xt`N2di0unu2Y}e&AU0!WB!r5FP_ZD2DKj3V
zpccYz0I|0~*xNwtBM|m65c@KOeGSCE4PoB}vEM`3pFr#{5cW3^`=31CFlPmOycQ+M
zCtwS5;u5_SW`H|a7G>t-WF}V`pock323N3aGG#KbfWjQq{luN_Ibi0rqWEGWHecXO
zIB4aQBo==_+T)msAKFmI?TeQTejs1WXJA;#l*wSgz>sNgfHzXup+<J1cxVbX4}nT5
za9IR8CIq=G0(BbQp;t_%FsHIMGlQ!(mK4?&h7?vXpWU4S(s@i_2lF{nID#28IjgWl
zBCHQmm4F_JFd1Cl*8we2Ps#*ertO`WmzAlb;E`FBn4Xvix&<~bMZr6<Br!WNFHr&9
zN-ZY4N<o|s2(MCLZqox>T&0WdcCaumhiftwO#-F9{qq?ZiYDVvf~;VZCZa^wRBX{j
zTrN_^Onq>#zyc35JHcdddnnTZl=$Z3PkbCObEcwrXBut11B?ACL(Is5rVBj&Spf3S
ze**r2SuqpEKhr@ms>zAFjR0zA7J(wM2;}u5ka}$G(OVp_sObfn4_Z3`YB{hl39tyT
z6wSaEYB&oawAu?xBMCABfLVP(#Bqic8>lE<!@!Wa{yMnIVh{usNP=LtfguA!X1^hr
zov;$r%vcF#Z@3OpbDePFXM<Qi7vz0VaRl;y(M)U}ho^qf$Qg2Bl>)l&mbpq4Gu=CT
zc~^y?Cyivtk$x!(&~g%aj07~^1aXjphO?KqCay5?E8+un_`%I51OaYHF*|#CFGTUp
zENs5P8I5Rli5RA@LNXFFt8~!41ro*OTur7-Mm`3HOe;Qc<k*AQ(R_Go5f+enOHuqW
zn<Re_PL7U6iAkBsn8^_$j?*v9pybHLz>q1;2KJ2{i2WbJW?%;;L3X@8V}qE#62)(G
zu=x$1;z(_(d!!~6rIus*3?h!xXH1zBSV7r_6~Fr-rmRJA|6FYDCpL}AV5Tvb)H2YK
zMu|n4RYvG34IzieCk&jRnBWA*(1R5qU#-CFD=vho8&P~V4_wrWVl8SHfyU~&auX|{
z-M}L7&;YpX1@*m(K>e2@P#>TO)G93kHR_5$4IyyJ3NB@eK$)`$l(LIJNuUT6jzu6V
zv6a@~E^s!;b)Y4r9E>c?Jm7*_fJJ}<RA37T2(XB-fLSbHwWXlpyc^4Jw%pixW8;k#
zH@j}EECmfCJlV1K*|hdjP|0y&*M%Jy8!qg)u=~R93p*~hUD!|xD&NjcJ-7SZ?sMDE
z?LD{i+^%zLz$RT^bZyJ^iPu+L+j4#8^;M;u3=9m<rZ0UqXU&UM^T6gl+q3BD+UcdB
z!JEfTs~<P*2a(NP5P`-`kDEFlH}*VkglK&`b<V4;Yu`-U0ygNu&Xxx|ra#!Rs1(%s
zez0WOgQe{cmTY~nWW|Fe`yMQr{$R<52TL0;+E?&t2hjd^<U$$IdTeHjVsU4HjQ*yu
zHZw)BrmzJwXtLkpLnJ%U<;Yc#!;?U>F3_<^(8bcA`2xt$d@AUi+SIht9MJGyc~NEw
zXsDqyFSA4eq#Lra2g7~vEMS2#Xp_PWo*@LcX+dsEVQ*oGVuMVAL_sG&qBtPaA606o
zZq<XF*?|xQ9aNQCQIc4}jI`d>IX@4y3PJ&LIvDt%F!&Yg8L4>+n4SQiRHl%dpOTqY
ziD;677R9Dzrh|^hDori60*|18W<eBm6$&8NM}gPTqTJY`3p(T}5p*3U*3n(aFbvcX
z*h#*yTgMUOddOBmPkV<><R~PTmgMU~=J`Q~2t(osS$%wbN@ikud^~8T0~A-qn5%LS
z$`uqKYu<5$s|MP%1<2vb;CP3G7}Rax6arq>3%^NCArW?)lmhsyw9=CN+{BX1WYDEr
z3dN-b;6sp+@5=!htpL5{tjIM7d|aJgW?oKaUaC)KNorAIPH`ycjC}Z+x=3diLG^;K
zkU%{HSW^M{{3R5BgEXZV<(C$~50+BbPzNozNiE8a*3;9ARnS&Y*Hp)1jWX!erPQJl
zNEm?TxYRW?)se@ML0$%(_>q~HoKp%qi#sz9bfy6~xq#O{XQ$>tat_E9FkGCPlctwg
zT%1}|0$zjVn3v)VI>f~%v$(iK1MF7NLBfei$qI%>#-N0zsidP2t)7^a3_8EZ(8w4>
zfez_GzMBPPy0SuIS_$Y>nF>hug=QOA4$)D7M<mGQkknNIb|~!1ER?O+iRp>Zt=1sJ
zagSz$+SQp1pecRC6h7lE-uU9gGSGRw;9OdCA2gy2Dv}{ZKd3QR1e%(C3M%kH<p={~
zl|CZJg9;s7#Q<VTAJl|^jsAhypz;ztz@7#^uLiWfAd4x5(T1UfISVvJ&y>Ps!%)JI
z#ahFV#gxJfX0w6WEMPV}n9XVf?R%GSWO0J#(ZHe{HVi48C0tqDnV`8krW7t4h8ob&
zJ-6R2A!rtlM-&FPL}6mkY#$HG_QkhEpiux`RF#(=4<6sW#SblL;vu)zrQG6$34qtH
zq69rCtU$FKc+L(~n}C8oRsggo0CcKm4P!IYWTrxvU<PnNYchcs1r$kxhhU4uL9w8S
z+PDTq#VszIl+5H3@MPQvSd6eSR@oC7BcP~8n%IMz1-7>+1vHPP0&)RQkqgKL;3HEP
zf(A<sLENXH<sFYfu8IS(1V9AH!MC{L6LWIn!F5&<NI%3REJ^7W3&;g8KrWX7B?!>%
zBg`!SKx-SAm_bJ%u`#mz=V4*{&&6D&O@g0LLLQX5K#NAeDXaq}g-J4GGZ!h8Ff3pO
zrxiv?$T^^(RK_I9P{I<=TEegZlG2!w<X9vb7O*d5aAAlQf!y~EK8cjEhN+pEk)hBF
zY!<5|LkUAX7nsckW^;qt?2-&6Jn_7sET_rgSF{Kenu|fi5)c6jzM`cd)-n(Q3Or3d
z^uT`v3UWjYJOyz<ms#IpFHS81Un2`P1`#PBW598s$qZT30ZvLTAbqG=`xZOstd#ts
z)E}TI0Zm6RFtdP;oBhwk0-{-%c|Zr`{AXbX?FIlvP!-aS0KAzWYA{O7fbu>lUw~r<
zw2HX~cKR~t3L;I$qLrXPz?N<}<Kt8FN>YpB<GH0_D-{{542Vo3aLp*L0l5T(L5uE+
zvAJe7$TinMsT?iTIO5||D?p2t_>de!e5nZ0>xX0H1XS8W0s?IR8jvH_f(V2oz${@<
zvtJxXQ{fyaK0z&D4n`I+4rUGk4q*=FqIKB%N1*Wr@bD+-oGs+WYYHED77sKPzz-he
zWQ<}>5db$08Kc-z1i`Cg7^B!zIZ`=On9`V1cv5)5=b&(b$0CF<nu{T+#gM8rD7CmW
zr=-{sT)7rkWy4znj-ZXCnR$?A6lk?`VhZ$fRD~jl9%y9`x-A`YWi0p_)I7+FWl%d9
zoG3vyIVTpULJUfU&bNW8N55oH(EuuYKp4aZVQ_-90j=a>N?|NzERq4w`ZCopf)=IL
zu%s~cGBYyNFoWeRz;d949!v`vU~-`Sa+=Il2jD&d*%b<FmLoYDwC5y07j*NULL%f6
zS!iG=<R@jNCYL}OfQg`sG$8jYfU5e`<dW1B@R=I$GfqI}gU<K>4Glv~%c}&nK{E4F
zQ{Z6*E|Kw=2rB=P+Q1453VtgYi;jV60OniVkhYI&VQFGckrJrvXaVg9WQCL{r$FmJ
zc~dJ25N^AL;DQVWn**-gAOtwQN<a(+H>jW<2U}1q3d%{KOvu2_!6?GWfmx@4;uKjQ
zH1!}i(NIhbNd{HFpjZZB&}t2MOoP^o)-Yx<)G(zmrZ9nyv#wz+k}F}XVFPW=YG!0)
zsA0%ru3-b+H<ZE*ihJms>pqnDb<WQ#OU=s!UoTu<lvq%ZS_F-0P|^h@L<Q*Hz9RTl
zvY@fG%)Elq5@-)X2ONozPyx4KQEULUW+4e5)XhWoy<TE5=-OEgP0+fpR8Sm&?aTmO
z!iW?nsIePTw2cWg7E!bjRGxt1*>5FFQ5vX(+XIT=r66K63j>2DJ0zAt_nzJ22KfZq
z5JKp@#a@<Ll$2kbS_Dc8kSInfmmod@yBMkAT%w4GW<Ew1Mjpm0JG3&Kh-gMOaJWaZ
zOJ;HjzDNe;G#rt<2_DHsThQXPXe&q#uApceh)Zldf}EsF&3FVE2wDpc%BNrq8ZhF7
zt-J#jJvEFmOtmbvte^~A3c3fL2{b_50y;UKwT7vg3Do+pWvgLxVTipJ!wkCBzLv9u
z5i;6R1MVB7Fg7#Qa+NTquz_apki@uaxWUExGEi%+hP#HVprD31g}s-lUyhNXgt>;J
zgr%9OsI7*hi7}iZg^`7Ug#py+%M&nUD4u1&zzBwspiR?SC5$N?Xr}X&Fs5*#iSgF(
z)bOS;rEq047kvUPNUq@kiPUfvysBYN;qGN&WGK`sVN2mzz+S@+I*1I!uVKjIr~zGz
z#t8PmSPgR?6KGLPFB2mJxbopo3}8YUbph26q1fx6)Uw2!QqacZ{L&IoL6n~csfghH
zeE5MTntBSLd#%7nJi%^S2N?{)phbbYpwy=TzM!`lR1Sf!YEXclOa!kRz<r~5NHJCn
zx>lqVbnF-8t|L%Cyf{?>)X%NTEGR%5f+&ZcJ_x#`8?+%FY7^uh705bQm|MZcD9mRm
z3Xt`qNQDqe)qt8|+%oe(;~+ZFvKw@+QX*(HAyol%yE<sS7t9h3P0*!N$*IM~kWna*
zpFxMWLr?4n1q%pU6(klV<|-7G=EZ}G&f@r@RM2TOR*;a=NXpO8(NTy7dq$(Uq(}!6
z{7@Hy4q<SuNKOS`ucR5PsQ~vac%v80DJazh)IuB~u8|KmD=|mY3dL4X4C*L=qEJTx
z$wm~DQ4bJ+^{l{sS|tVs2JkvmDM+8FhB1XflA(qXyz-SPjTyQswGdRNfGP$}W^lLm
z7IRTS$t@0;ThS_xBG58b4^ZI(YL>DwvHh>|C#ix6D$N7cAke@>>g$4h3+^{#^Z`IN
zffnf%gSw<O46!1Rb+sjo%}hm1HH^>$5g39QAiExzAoqfTcULn(y#%_D1ms7EZ$K>_
z@L33f($JksResd*1njf~+<s64HDVcJ<&gbQ!c@ap!i?QFED+y-w+M8C`u`h1@wFRN
zA7JrN2q<Pi%_<fqCPtBenoPHZU=bOg3QM%$h97Phk`&6|>sE2OCK(pIRI*GLpV!l1
zmKC*u+EC1pmJqxOtrE-22NepLDUgdVK+Eo`6^m-C_|p<Ib3ko!NWv^GTF=73pvhUZ
z5j3JQ7qlOP2U1K0C1w_<7DJ)~90{O?SP{5g_5;+_<ANvyl{cDv;O5ya0rVo~mKZ!b
zP)c2JlpvJH7ndf3N--o6Xz_fDEjP6&Jv9Z=KmfN0c7gVVae#agpIe+>v=@{#!0kt{
z-%%6EEfI(#QFEasDAj<rP&4pwFmW-mF>(B3W8q_AV&wbJ!py|T2HxYu^oxZ9H0{mt
zpM#l;QH2R63sM6bgkWL>LAE~}90JTNj6(mbtSQJ+D4UExr5dQ`0h%@`2F;LwJ9vzs
zwni^gzZmG)Xiymt&XB@@Qu}Km*Z$z~9VS0W>@pVZ14S})@Z|_7ra_HuNa+9$F;Ee4
zO9~oT;D`q|mEpy31t`cs1rr040ArOSX<o%*o+h)OpPwd^UkDWYX>wzoO9ZF6?Vu>$
z0V0lp2vB|ppLbq#9K;2?A3=b9A`U8Z!9IW%ywJ{>Ajlh_d1DSn78Zv8T)arwo{6#O
z1bAAL4XaZ?gB4%}NWliS7Gz`50u}~_lb}Hkkn2FE^ErdXZgIrN=O$+6#mC=bD^ATx
zO)j~`0;)KRo`8Efprwb5MMpsA0<kCO=alB=6&JBGF)&22fj96LgKl`r%}vZpN%Tf;
zO(}z}D+e`fAbKDTB2ZT@CBFnbG7s9916~dcuRS4_D`-KsR0l@}>qSIHMMWZ}f0PwK
zM@Qy>8WXvRCCM2I`FRRT!LB~8&LK*WUSV=#aY?ZP=&*fI-%bf)q7vK&h+3EpVAFLJ
z9G#qztpL?}pdB+%cY_B6Acli?Zi1bl05u3Y0*){r9DE9njyg_GI?m2ek5m@xrIaS-
zAX@_8rUMB>3<Go&oOBe>^y?^ufWpiO*__P0vc#Os6g2lJ=)x}g0hK{;!y}-s!)7?D
zp`cnnC$%IMG*kkLS{w!jgAGL03ULoo;NjJ)5EmB*3Z)8#V2n_zf*ctJY91n=*9JOP
z5AG$DBj(UglmnlThja=j_&hwg)+z-!6WMsA^WUn>5GqJH7fqAN&rOpNeE+*96L{~p
zn<k^5CbL_Jn<it3CL?4|3}c9f0I2o^?*&x^6?mZLVUaS3wFgvtv6rVNW*4QV6)}N?
z%t2~FyK##^ix-OOKzVaANJ0YC1PKOlSAdk90TE6hE~t>c#R0njz6ew_-r@w!M3&^|
z=M>-K1YP$6W)^`)d2Vq*=hSjClZrqkL=kBG=N7jo_*h8SqN4nwB2bZki#@(1qbM~o
zr3lpByu}IOWag#c;!n=c0hJz^`FX{9iAl*tpxLt`(DiCXpkdV_UXW{jK_v%weo;zl
zQECdPAzcLOxgt%0fXC%Q4W1%dkb2O9i6VIr>mSHt>p>n{0V-2LBk#9_A+t*0xs>w6
zBG7WrV$fDg(A-LV5$N{$TRdf{MWA`+c+fckMW;cAw1b)u?74{*#hF#9MQ1@qf|{m9
z`XF)U<cy-CPoOZJ2eNeqhyd*shg@U<+OBnrqbL<*XlhCkxUB`+y;TI-CR!u{GKvGF
zmlH(XVg!|vxrr5-c_p{lD!?mEi$J@+ZgI!QCzWRAlz<A|q79(PW=#VXG)3ThBW{Bn
zc^zaixQ(d;;_d(`;!iA2&diK21r3{lO2S)Eft>vE)FO}o(oPoe4tel)7SQzp;Qd#(
zIN^JzAp2e>f$RV`oNPfX@DWIkAQotFx5y2|k_A~V3?iIBF5oCiP0uVYNi8Y@?d~he
z1}Vt^5&J<(4ugmzAfgB)b^=6zXT@qk0Rw8z6oHm|6q$o0z}wItfF$@q@d=(J1JBr~
zgJeOC@}gc43w#CuJ19IseW)VP)I*UgNCJFMA!zq{kqbyxA0!6aUktfs0W>sU1ioP*
z5F`QG-C6`1voBHwaX|yuMP?wDHi)nT5xOA46hwepG(}TEhJrWDgReJS1mc2E6Yu~j
z(E|~_AOd`GBKR&uEfCimL|B1{W)K11NgoShfwFN?0f?0kBA7ttm4H}DAObY$R@4b%
zb%O}-T@WcCRu+iJ1QAUjq7g)Z&Ox}v6Q5d~oLG>W5>T3#e2X8(^GK}#?Nvbt_$QZu
z1-Rous}FKg!5l8|q%C+WOA!kw4*r0g(*QC&4@A_0h-wf4KDD70!~!+;iX=gC1=?0#
zlnWAT0}(PHu^tes6hvr%xSAlM3&aKO|1XLMvFbqt_*8)w5UUVGfG(RT3Ink!Km_8@
z0&vd)+~W5I85IsnRWTqXpz9BcB0((BRCv)Gkn2I)aEcN@VsRiM9Yj=u2+)BJMHL_e
zK-Ud`4+H>jg9h)^0xz|KEa?KTxCJi)LoB;p1=0py+y!3x1zrROUJeFc>jheB3R(X(
z52Oy%xB|DyqPQWA4)FQcQJkQL6qtF76?~{-6c?mw^h?Z5jp9SFK_k;Jx!{7-<S0&X
z%K)s57tRE$;w;Y0Eyzg?4)iHH1M++x$bQIS6(CkQh)4ku;HDpf05t+{ao9kv)3O7V
zv&CLa3=B;FnLJn+Sr}QEI2d`ro6<oW(-9ang$a`3VPawuVB}#GVq#(xVB`bQOgxMt
zjC@QyjABqRh>QS~C&J9e$i~ga#Ky?R&&CLYB1{~tY|I>DLX13MF|gf?EX*>@Y#=v?
zvoLZn@h~!hOlA~d5@X`v0`+Ae?h#|=;SsPGh!tQJ5EbAO;1Z~3fI$x~CJsIh9u6)J
zW-yfIaY2%WsRGg30*V400$c)o0_p;6ER1YS0)7JG0=xpQ0`&|EVDWkeUV(ZB2?1{b
zHvx75DFJx_5dnSyK><+#ae+#KT!CtVFoAjoHUWPDWdUyi9RVu=WdV5sb^#ZGGJz}s
z4gp;OF##6=Spj|y10GQx6%I}gISyG44xVrhbsjAaHV!#Zn1V4A<VF<<MiE8>CJqG-
zP7Zz!kS-P;RyIbqe_W~@5*!>Ht{hA}YM?^`IGDuh8JJjD#2CdGc^J9=voSLLXJL|J
z63Y;%<6`7uQeYHg)L`Ucm0=cQ7Go4*R$yjf7Gefnm&Ea(iIMF;%YPmwmVYeFN*p4f
zkkAto64Mv+;s8xwGjaUmU}a+zK!PHSAP5#=7O7`21I08ClMs^(qXZ)#h-A`X7LX9)
N65<qM<zbXy1ONcGO?LnQ

diff --git a/env/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/__pycache__/six.cpython-39.pyc
deleted file mode 100644
index fb7259e9dd481e461f0478555689e5f713599bca..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/appdirs.py b/env/Lib/site-packages/pip/_vendor/appdirs.py
deleted file mode 100644
index 33a3b774..00000000
--- a/env/Lib/site-packages/pip/_vendor/appdirs.py
+++ /dev/null
@@ -1,633 +0,0 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-# Copyright (c) 2005-2010 ActiveState Software Inc.
-# Copyright (c) 2013 Eddy Petrișor
-
-"""Utilities for determining application-specific dirs.
-
-See <http://github.com/ActiveState/appdirs> for details and usage.
-"""
-# Dev Notes:
-# - MSDN on where to store app data files:
-#   http://support.microsoft.com/default.aspx?scid=kb;en-us;310294#XSLTH3194121123120121120120
-# - Mac OS X: http://developer.apple.com/documentation/MacOSX/Conceptual/BPFileSystem/index.html
-# - XDG spec for Un*x: http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html
-
-__version__ = "1.4.4"
-__version_info__ = tuple(int(segment) for segment in __version__.split("."))
-
-
-import sys
-import os
-
-PY3 = sys.version_info[0] == 3
-
-if PY3:
-    unicode = str
-
-if sys.platform.startswith('java'):
-    import platform
-    os_name = platform.java_ver()[3][0]
-    if os_name.startswith('Windows'): # "Windows XP", "Windows 7", etc.
-        system = 'win32'
-    elif os_name.startswith('Mac'): # "Mac OS X", etc.
-        system = 'darwin'
-    else: # "Linux", "SunOS", "FreeBSD", etc.
-        # Setting this to "linux2" is not ideal, but only Windows or Mac
-        # are actually checked for and the rest of the module expects
-        # *sys.platform* style strings.
-        system = 'linux2'
-elif sys.platform == 'cli' and os.name == 'nt':
-    # Detect Windows in IronPython to match pip._internal.utils.compat.WINDOWS
-    # Discussion: <https://github.com/pypa/pip/pull/7501>
-    system = 'win32'
-else:
-    system = sys.platform
-
-
-
-def user_data_dir(appname=None, appauthor=None, version=None, roaming=False):
-    r"""Return full path to the user-specific data dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "roaming" (boolean, default False) can be set True to use the Windows
-            roaming appdata directory. That means that for users on a Windows
-            network setup for roaming profiles, this user data will be
-            sync'd on login. See
-            <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx>
-            for a discussion of issues.
-
-    Typical user data directories are:
-        Mac OS X:               ~/Library/Application Support/<AppName>  # or ~/.config/<AppName>, if the other does not exist
-        Unix:                   ~/.local/share/<AppName>    # or in $XDG_DATA_HOME, if defined
-        Win XP (not roaming):   C:\Documents and Settings\<username>\Application Data\<AppAuthor>\<AppName>
-        Win XP (roaming):       C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>
-        Win 7  (not roaming):   C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>
-        Win 7  (roaming):       C:\Users\<username>\AppData\Roaming\<AppAuthor>\<AppName>
-
-    For Unix, we follow the XDG spec and support $XDG_DATA_HOME.
-    That means, by default "~/.local/share/<AppName>".
-    """
-    if system == "win32":
-        if appauthor is None:
-            appauthor = appname
-        const = roaming and "CSIDL_APPDATA" or "CSIDL_LOCAL_APPDATA"
-        path = os.path.normpath(_get_win_folder(const))
-        if appname:
-            if appauthor is not False:
-                path = os.path.join(path, appauthor, appname)
-            else:
-                path = os.path.join(path, appname)
-    elif system == 'darwin':
-        path = os.path.expanduser('~/Library/Application Support/')
-        if appname:
-            path = os.path.join(path, appname)
-    else:
-        path = os.getenv('XDG_DATA_HOME', os.path.expanduser("~/.local/share"))
-        if appname:
-            path = os.path.join(path, appname)
-    if appname and version:
-        path = os.path.join(path, version)
-    return path
-
-
-def site_data_dir(appname=None, appauthor=None, version=None, multipath=False):
-    r"""Return full path to the user-shared data dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "multipath" is an optional parameter only applicable to *nix
-            which indicates that the entire list of data dirs should be
-            returned. By default, the first item from XDG_DATA_DIRS is
-            returned, or '/usr/local/share/<AppName>',
-            if XDG_DATA_DIRS is not set
-
-    Typical site data directories are:
-        Mac OS X:   /Library/Application Support/<AppName>
-        Unix:       /usr/local/share/<AppName> or /usr/share/<AppName>
-        Win XP:     C:\Documents and Settings\All Users\Application Data\<AppAuthor>\<AppName>
-        Vista:      (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.)
-        Win 7:      C:\ProgramData\<AppAuthor>\<AppName>   # Hidden, but writeable on Win 7.
-
-    For Unix, this is using the $XDG_DATA_DIRS[0] default.
-
-    WARNING: Do not use this on Windows. See the Vista-Fail note above for why.
-    """
-    if system == "win32":
-        if appauthor is None:
-            appauthor = appname
-        path = os.path.normpath(_get_win_folder("CSIDL_COMMON_APPDATA"))
-        if appname:
-            if appauthor is not False:
-                path = os.path.join(path, appauthor, appname)
-            else:
-                path = os.path.join(path, appname)
-    elif system == 'darwin':
-        path = os.path.expanduser('/Library/Application Support')
-        if appname:
-            path = os.path.join(path, appname)
-    else:
-        # XDG default for $XDG_DATA_DIRS
-        # only first, if multipath is False
-        path = os.getenv('XDG_DATA_DIRS',
-                         os.pathsep.join(['/usr/local/share', '/usr/share']))
-        pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep)]
-        if appname:
-            if version:
-                appname = os.path.join(appname, version)
-            pathlist = [os.path.join(x, appname) for x in pathlist]
-
-        if multipath:
-            path = os.pathsep.join(pathlist)
-        else:
-            path = pathlist[0]
-        return path
-
-    if appname and version:
-        path = os.path.join(path, version)
-    return path
-
-
-def user_config_dir(appname=None, appauthor=None, version=None, roaming=False):
-    r"""Return full path to the user-specific config dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "roaming" (boolean, default False) can be set True to use the Windows
-            roaming appdata directory. That means that for users on a Windows
-            network setup for roaming profiles, this user data will be
-            sync'd on login. See
-            <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx>
-            for a discussion of issues.
-
-    Typical user config directories are:
-        Mac OS X:               same as user_data_dir
-        Unix:                   ~/.config/<AppName>     # or in $XDG_CONFIG_HOME, if defined
-        Win *:                  same as user_data_dir
-
-    For Unix, we follow the XDG spec and support $XDG_CONFIG_HOME.
-    That means, by default "~/.config/<AppName>".
-    """
-    if system in ["win32", "darwin"]:
-        path = user_data_dir(appname, appauthor, None, roaming)
-    else:
-        path = os.getenv('XDG_CONFIG_HOME', os.path.expanduser("~/.config"))
-        if appname:
-            path = os.path.join(path, appname)
-    if appname and version:
-        path = os.path.join(path, version)
-    return path
-
-
-# for the discussion regarding site_config_dir locations
-# see <https://github.com/pypa/pip/issues/1733>
-def site_config_dir(appname=None, appauthor=None, version=None, multipath=False):
-    r"""Return full path to the user-shared data dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "multipath" is an optional parameter only applicable to *nix
-            which indicates that the entire list of config dirs should be
-            returned. By default, the first item from XDG_CONFIG_DIRS is
-            returned, or '/etc/xdg/<AppName>', if XDG_CONFIG_DIRS is not set
-
-    Typical site config directories are:
-        Mac OS X:   same as site_data_dir
-        Unix:       /etc/xdg/<AppName> or $XDG_CONFIG_DIRS[i]/<AppName> for each value in
-                    $XDG_CONFIG_DIRS
-        Win *:      same as site_data_dir
-        Vista:      (Fail! "C:\ProgramData" is a hidden *system* directory on Vista.)
-
-    For Unix, this is using the $XDG_CONFIG_DIRS[0] default, if multipath=False
-
-    WARNING: Do not use this on Windows. See the Vista-Fail note above for why.
-    """
-    if system in ["win32", "darwin"]:
-        path = site_data_dir(appname, appauthor)
-        if appname and version:
-            path = os.path.join(path, version)
-    else:
-        # XDG default for $XDG_CONFIG_DIRS (missing or empty)
-        # see <https://github.com/pypa/pip/pull/7501#discussion_r360624829>
-        # only first, if multipath is False
-        path = os.getenv('XDG_CONFIG_DIRS') or '/etc/xdg'
-        pathlist = [os.path.expanduser(x.rstrip(os.sep)) for x in path.split(os.pathsep) if x]
-        if appname:
-            if version:
-                appname = os.path.join(appname, version)
-            pathlist = [os.path.join(x, appname) for x in pathlist]
-
-        if multipath:
-            path = os.pathsep.join(pathlist)
-        else:
-            path = pathlist[0]
-    return path
-
-
-def user_cache_dir(appname=None, appauthor=None, version=None, opinion=True):
-    r"""Return full path to the user-specific cache dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "opinion" (boolean) can be False to disable the appending of
-            "Cache" to the base app data dir for Windows. See
-            discussion below.
-
-    Typical user cache directories are:
-        Mac OS X:   ~/Library/Caches/<AppName>
-        Unix:       ~/.cache/<AppName> (XDG default)
-        Win XP:     C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Cache
-        Vista:      C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Cache
-
-    On Windows the only suggestion in the MSDN docs is that local settings go in
-    the `CSIDL_LOCAL_APPDATA` directory. This is identical to the non-roaming
-    app data dir (the default returned by `user_data_dir` above). Apps typically
-    put cache data somewhere *under* the given dir here. Some examples:
-        ...\Mozilla\Firefox\Profiles\<ProfileName>\Cache
-        ...\Acme\SuperApp\Cache\1.0
-    OPINION: This function appends "Cache" to the `CSIDL_LOCAL_APPDATA` value.
-    This can be disabled with the `opinion=False` option.
-    """
-    if system == "win32":
-        if appauthor is None:
-            appauthor = appname
-        path = os.path.normpath(_get_win_folder("CSIDL_LOCAL_APPDATA"))
-        # When using Python 2, return paths as bytes on Windows like we do on
-        # other operating systems. See helper function docs for more details.
-        if not PY3 and isinstance(path, unicode):
-            path = _win_path_to_bytes(path)
-        if appname:
-            if appauthor is not False:
-                path = os.path.join(path, appauthor, appname)
-            else:
-                path = os.path.join(path, appname)
-            if opinion:
-                path = os.path.join(path, "Cache")
-    elif system == 'darwin':
-        path = os.path.expanduser('~/Library/Caches')
-        if appname:
-            path = os.path.join(path, appname)
-    else:
-        path = os.getenv('XDG_CACHE_HOME', os.path.expanduser('~/.cache'))
-        if appname:
-            path = os.path.join(path, appname)
-    if appname and version:
-        path = os.path.join(path, version)
-    return path
-
-
-def user_state_dir(appname=None, appauthor=None, version=None, roaming=False):
-    r"""Return full path to the user-specific state dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "roaming" (boolean, default False) can be set True to use the Windows
-            roaming appdata directory. That means that for users on a Windows
-            network setup for roaming profiles, this user data will be
-            sync'd on login. See
-            <http://technet.microsoft.com/en-us/library/cc766489(WS.10).aspx>
-            for a discussion of issues.
-
-    Typical user state directories are:
-        Mac OS X:  same as user_data_dir
-        Unix:      ~/.local/state/<AppName>   # or in $XDG_STATE_HOME, if defined
-        Win *:     same as user_data_dir
-
-    For Unix, we follow this Debian proposal <https://wiki.debian.org/XDGBaseDirectorySpecification#state>
-    to extend the XDG spec and support $XDG_STATE_HOME.
-
-    That means, by default "~/.local/state/<AppName>".
-    """
-    if system in ["win32", "darwin"]:
-        path = user_data_dir(appname, appauthor, None, roaming)
-    else:
-        path = os.getenv('XDG_STATE_HOME', os.path.expanduser("~/.local/state"))
-        if appname:
-            path = os.path.join(path, appname)
-    if appname and version:
-        path = os.path.join(path, version)
-    return path
-
-
-def user_log_dir(appname=None, appauthor=None, version=None, opinion=True):
-    r"""Return full path to the user-specific log dir for this application.
-
-        "appname" is the name of application.
-            If None, just the system directory is returned.
-        "appauthor" (only used on Windows) is the name of the
-            appauthor or distributing body for this application. Typically
-            it is the owning company name. This falls back to appname. You may
-            pass False to disable it.
-        "version" is an optional version path element to append to the
-            path. You might want to use this if you want multiple versions
-            of your app to be able to run independently. If used, this
-            would typically be "<major>.<minor>".
-            Only applied when appname is present.
-        "opinion" (boolean) can be False to disable the appending of
-            "Logs" to the base app data dir for Windows, and "log" to the
-            base cache dir for Unix. See discussion below.
-
-    Typical user log directories are:
-        Mac OS X:   ~/Library/Logs/<AppName>
-        Unix:       ~/.cache/<AppName>/log  # or under $XDG_CACHE_HOME if defined
-        Win XP:     C:\Documents and Settings\<username>\Local Settings\Application Data\<AppAuthor>\<AppName>\Logs
-        Vista:      C:\Users\<username>\AppData\Local\<AppAuthor>\<AppName>\Logs
-
-    On Windows the only suggestion in the MSDN docs is that local settings
-    go in the `CSIDL_LOCAL_APPDATA` directory. (Note: I'm interested in
-    examples of what some windows apps use for a logs dir.)
-
-    OPINION: This function appends "Logs" to the `CSIDL_LOCAL_APPDATA`
-    value for Windows and appends "log" to the user cache dir for Unix.
-    This can be disabled with the `opinion=False` option.
-    """
-    if system == "darwin":
-        path = os.path.join(
-            os.path.expanduser('~/Library/Logs'),
-            appname)
-    elif system == "win32":
-        path = user_data_dir(appname, appauthor, version)
-        version = False
-        if opinion:
-            path = os.path.join(path, "Logs")
-    else:
-        path = user_cache_dir(appname, appauthor, version)
-        version = False
-        if opinion:
-            path = os.path.join(path, "log")
-    if appname and version:
-        path = os.path.join(path, version)
-    return path
-
-
-class AppDirs(object):
-    """Convenience wrapper for getting application dirs."""
-    def __init__(self, appname=None, appauthor=None, version=None,
-            roaming=False, multipath=False):
-        self.appname = appname
-        self.appauthor = appauthor
-        self.version = version
-        self.roaming = roaming
-        self.multipath = multipath
-
-    @property
-    def user_data_dir(self):
-        return user_data_dir(self.appname, self.appauthor,
-                             version=self.version, roaming=self.roaming)
-
-    @property
-    def site_data_dir(self):
-        return site_data_dir(self.appname, self.appauthor,
-                             version=self.version, multipath=self.multipath)
-
-    @property
-    def user_config_dir(self):
-        return user_config_dir(self.appname, self.appauthor,
-                               version=self.version, roaming=self.roaming)
-
-    @property
-    def site_config_dir(self):
-        return site_config_dir(self.appname, self.appauthor,
-                             version=self.version, multipath=self.multipath)
-
-    @property
-    def user_cache_dir(self):
-        return user_cache_dir(self.appname, self.appauthor,
-                              version=self.version)
-
-    @property
-    def user_state_dir(self):
-        return user_state_dir(self.appname, self.appauthor,
-                              version=self.version)
-
-    @property
-    def user_log_dir(self):
-        return user_log_dir(self.appname, self.appauthor,
-                            version=self.version)
-
-
-#---- internal support stuff
-
-def _get_win_folder_from_registry(csidl_name):
-    """This is a fallback technique at best. I'm not sure if using the
-    registry for this guarantees us the correct answer for all CSIDL_*
-    names.
-    """
-    if PY3:
-      import winreg as _winreg
-    else:
-      import _winreg
-
-    shell_folder_name = {
-        "CSIDL_APPDATA": "AppData",
-        "CSIDL_COMMON_APPDATA": "Common AppData",
-        "CSIDL_LOCAL_APPDATA": "Local AppData",
-    }[csidl_name]
-
-    key = _winreg.OpenKey(
-        _winreg.HKEY_CURRENT_USER,
-        r"Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders"
-    )
-    dir, type = _winreg.QueryValueEx(key, shell_folder_name)
-    return dir
-
-
-def _get_win_folder_with_pywin32(csidl_name):
-    from win32com.shell import shellcon, shell
-    dir = shell.SHGetFolderPath(0, getattr(shellcon, csidl_name), 0, 0)
-    # Try to make this a unicode path because SHGetFolderPath does
-    # not return unicode strings when there is unicode data in the
-    # path.
-    try:
-        dir = unicode(dir)
-
-        # Downgrade to short path name if have highbit chars. See
-        # <http://bugs.activestate.com/show_bug.cgi?id=85099>.
-        has_high_char = False
-        for c in dir:
-            if ord(c) > 255:
-                has_high_char = True
-                break
-        if has_high_char:
-            try:
-                import win32api
-                dir = win32api.GetShortPathName(dir)
-            except ImportError:
-                pass
-    except UnicodeError:
-        pass
-    return dir
-
-
-def _get_win_folder_with_ctypes(csidl_name):
-    import ctypes
-
-    csidl_const = {
-        "CSIDL_APPDATA": 26,
-        "CSIDL_COMMON_APPDATA": 35,
-        "CSIDL_LOCAL_APPDATA": 28,
-    }[csidl_name]
-
-    buf = ctypes.create_unicode_buffer(1024)
-    ctypes.windll.shell32.SHGetFolderPathW(None, csidl_const, None, 0, buf)
-
-    # Downgrade to short path name if have highbit chars. See
-    # <http://bugs.activestate.com/show_bug.cgi?id=85099>.
-    has_high_char = False
-    for c in buf:
-        if ord(c) > 255:
-            has_high_char = True
-            break
-    if has_high_char:
-        buf2 = ctypes.create_unicode_buffer(1024)
-        if ctypes.windll.kernel32.GetShortPathNameW(buf.value, buf2, 1024):
-            buf = buf2
-
-    return buf.value
-
-def _get_win_folder_with_jna(csidl_name):
-    import array
-    from com.sun import jna
-    from com.sun.jna.platform import win32
-
-    buf_size = win32.WinDef.MAX_PATH * 2
-    buf = array.zeros('c', buf_size)
-    shell = win32.Shell32.INSTANCE
-    shell.SHGetFolderPath(None, getattr(win32.ShlObj, csidl_name), None, win32.ShlObj.SHGFP_TYPE_CURRENT, buf)
-    dir = jna.Native.toString(buf.tostring()).rstrip("\0")
-
-    # Downgrade to short path name if have highbit chars. See
-    # <http://bugs.activestate.com/show_bug.cgi?id=85099>.
-    has_high_char = False
-    for c in dir:
-        if ord(c) > 255:
-            has_high_char = True
-            break
-    if has_high_char:
-        buf = array.zeros('c', buf_size)
-        kernel = win32.Kernel32.INSTANCE
-        if kernel.GetShortPathName(dir, buf, buf_size):
-            dir = jna.Native.toString(buf.tostring()).rstrip("\0")
-
-    return dir
-
-if system == "win32":
-    try:
-        from ctypes import windll
-        _get_win_folder = _get_win_folder_with_ctypes
-    except ImportError:
-        try:
-            import com.sun.jna
-            _get_win_folder = _get_win_folder_with_jna
-        except ImportError:
-            _get_win_folder = _get_win_folder_from_registry
-
-
-def _win_path_to_bytes(path):
-    """Encode Windows paths to bytes. Only used on Python 2.
-
-    Motivation is to be consistent with other operating systems where paths
-    are also returned as bytes. This avoids problems mixing bytes and Unicode
-    elsewhere in the codebase. For more details and discussion see
-    <https://github.com/pypa/pip/issues/3463>.
-
-    If encoding using ASCII and MBCS fails, return the original Unicode path.
-    """
-    for encoding in ('ASCII', 'MBCS'):
-        try:
-            return path.encode(encoding)
-        except (UnicodeEncodeError, LookupError):
-            pass
-    return path
-
-
-#---- self test code
-
-if __name__ == "__main__":
-    appname = "MyApp"
-    appauthor = "MyCompany"
-
-    props = ("user_data_dir",
-             "user_config_dir",
-             "user_cache_dir",
-             "user_state_dir",
-             "user_log_dir",
-             "site_data_dir",
-             "site_config_dir")
-
-    print("-- app dirs %s --" % __version__)
-
-    print("-- app dirs (with optional 'version')")
-    dirs = AppDirs(appname, appauthor, version="1.0")
-    for prop in props:
-        print("%s: %s" % (prop, getattr(dirs, prop)))
-
-    print("\n-- app dirs (without optional 'version')")
-    dirs = AppDirs(appname, appauthor)
-    for prop in props:
-        print("%s: %s" % (prop, getattr(dirs, prop)))
-
-    print("\n-- app dirs (without optional 'appauthor')")
-    dirs = AppDirs(appname)
-    for prop in props:
-        print("%s: %s" % (prop, getattr(dirs, prop)))
-
-    print("\n-- app dirs (with disabled 'appauthor')")
-    dirs = AppDirs(appname, appauthor=False)
-    for prop in props:
-        print("%s: %s" % (prop, getattr(dirs, prop)))
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py
index a1bbbbe3..f631ae6d 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/__init__.py
@@ -1,11 +1,18 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 """CacheControl import Interface.
 
 Make it easy to import from cachecontrol without long namespaces.
 """
 __author__ = "Eric Larson"
 __email__ = "eric@ionrock.org"
-__version__ = "0.12.6"
+__version__ = "0.12.11"
 
 from .wrapper import CacheControl
 from .adapter import CacheControlAdapter
 from .controller import CacheController
+
+import logging
+logging.getLogger(__name__).addHandler(logging.NullHandler())
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 7f8709b8f861c7d704fc88181acca9d7432a8e66..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 577
zcmYe~<>g{vU|^UdaWGYnk%8ech=Yuo7#J8F7#J9eEf^RWQW&BbQW&EcQ<$QdQkbKd
zQ&>`1b69d&qgWXkQdm;ha@ca&qu9Z0_8g8}&L~bsh7^uq22IYYB<IBBj8y0Rypp2)
z9EHr>g8ZTq1<$;a)S|S+<WxN_F5krLRE5kEh1A62N`;bqn3A-j{9J`(kltjd-tx?n
zjQr9Pg`E7nbcMXc+|=TN#N^asJ+3Nl*P_g11)s#C;{3cSfz+bRWQWZByrTT%Y`y%V
z^eQ$3JwqcsvzLqv3=Eo#w|J0Uq{(<o7@6;wl2}lZTBON%iyv7yC$-2=lj|0He0)lN
za(w(PuK4)G(vpn)qWJh*obmCgxrv!M@$t8~<KxRxi;6Sz^Wx)gv6mMm78Ilw6@h~C
z7JDMZ<RWGU28LT)P*3Hg78S8DFfgoSDB@vYfDpf0ovmU*i&Kk=V^VWcGK*sT^HN=k
zGRsmGbQMDVJi}arf;~eVgB3jeT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@p
zGP7e+^U7j;GLvG8GfPr+3lfvF6Vp?RV+t}0^yAA?^HTDQ^pV3@KR!M)FS8^*Uaz3?
g7Kcr4eoARhsvRiYib2j}VPRopVPs+AVdP;108zQFjQ{`u

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/_cmd.cpython-39.pyc
deleted file mode 100644
index babf4480c0b72b44b0c67208f79c3c7b208b1077..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1598
zcmYe~<>g{vU|^UdaWIvim4V?gh=Yuo85kHG7#J9eD;O9UQW#Pga~PsPG*b>^E>jc}
zBZ$qM!<@?!#R6ut<gn(lMX`a|tU2tt98nx#Hd_v7E>{#6BSQ*%3P%e=6n6?|3Req5
z6i*6w3Qr3|6mN<^3U3Nu3u6>tDt`)pHd9eaDqk}LBSQ*fFoUMxOOTuVG#PJk6r~oH
zrWThJYck#vc1}#rNOjK7D=Es)aZE`pC`m2SWW2@cl9^lrmeORr#g>zwo(>k~b1X_P
z%}vcK2}mp|PAy6XnFzy-3=9k)pE`qls>Hy+P{Oc)v4km$c_AYsLkZIYmW2$pATib&
z29QV!LokCTqn{>Q5i0`&!!3^D)DoZ6vecYg>>%4R^U`mzy0|)py5HgrE-6Y)%=Jjj
zOUX$sy2X{4k^*IGGTvg(fC#T-DB@*cVEEPOY!wq)oLW>IlbVx~Srp@+m+DfKS(d7x
zs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2?CR?p9O4?JU=|Y);1iQ*qMMVSo>^RynH`gw
zR~F-wnG{o;S(2(-keHmEn4Vf3Q;=DpA77T5my%zkp9~7SWJuWQ$0z5e=oM7n;w?@s
zDJ_VH`ho`(8f>62V&q}uU@YQiU|>KAHYNrJ29P{B*zCZ;R>IiKkiwV(N)}ALEVZD(
zV_wKm%UHv>fF*^whG8KSBLkSt0%bE~vDPrgv(<p2nbj{ullc}m*lF>pC5h?9x44Q^
zi!u{)GOJRHZgFO$mKK5hmt4i3QBqQ1rLSMb0b&$e>FaB<7lC51h=qZHp$O!#TkOH9
z#l@NVdAC?|^GoweZgD|<3yKK=h#d$KO{QDyiI608i={ZVxELHK5P}aB$=vCwCGjAM
z%=|ndP{0U)1BQu_>pvSa2O|$74-*GtktBK$fl?O8N#G!o0S8etLoGuMLl$ESV+vCW
zb1x`B7#1)s1f?k!zgx_uMLAUxAsML(p+P<hCHV>^MU@JPc_|8D7i%)!V#!F&DbQpt
z0tNgnp2U=t_(W*JzQt7lO4=YkD0{Ghc|{OEfKpfy*drVuk0chQ7t4Ws0WyVwk&Tg$
zu}B`|c945P9s^-ec*5Nt0(Uzoiop@eRKozuA+<~;ETEiP!<faofUSlpi@k;^ivtqT
zS*!~<K_Uwoi#$rWQW%>V85#08O1M&(KrC=RV)m<I2j|ul#VTIE{1S*qQxvQ;G`YcU
z0tf0X=JeE(A}LVhf|6m87${Eoz+n<!lv-SnpI4lEiyc}x++r?DEWZVjO^JsIvKAC&
z=9OqN-(mszzDNRO0t-kldI+)PCT8ZTfI<fn$83yj%sk9&%tFk3j9g4b8X%1v@$n#4
z@$sN?K%j^NB*tBkS)d2aU*IGdrGO-&2X-tp#pyxQ8aT~H$>CH6)&ow{QOdX#L2_|U
zY7w+NN-Ro;#62i>!PyoZhLF&NIX^EkH#I&U$?r%>#3naCr8Fni4wM>-K|#&I#KXh`
SPUJky9Bdps9Bf=79E<>cK9hd{

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/adapter.cpython-39.pyc
deleted file mode 100644
index e0f1373c6316e56a3453fc290c3eb991f10fb2d4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/cache.cpython-39.pyc
deleted file mode 100644
index f228f240b7d9bbfe7aaf212595e452a17ad68afa..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1850
zcmYe~<>g{vU|^UdaWGYtnStRkh=Yt-7#J8F7#J9eO&Ay$QW&BbQW#U1au{=&qL>&N
z+!<1sQ&?IUQdm-%o0+3n+!<0>Q`lM<QrJ>inwg_mQ`mzUG&!o0xI!{g6_OK^Gg1}u
zld@8iOB5UfJQdRNixe_*3vyC(Q}aqP^U@(IiuDvgs#8+a5=(PR6f%ny5*11^ic%9(
zxQY|gQWY}ubaPX4^NT7KQZkcEGV}8iiz@ZFUV_}L$#{#!CqFqm8N@-xOfXOAFfcHr
zGDI<^FhntdJkr7t#SHO66br=ZAV;Tgv@k@mrEmr_XmZ`+bV@8vbq2XT8DtF1SP+|$
zfq}sp6gHqBEMaJ7XktuZ2xeHx=(m#bmat!bi6_i=sVS~SMfpW5nQpNZr{<*HV$M#j
zT**)b()X*$*(xTqIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00
z*wZm4*wxoHIK(wb!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{lwATc>RF+H_7
zrXaIGKfWwAFD1W79~=wG`FSNp`8g1dUP0w8=JeDOkYkEL-eO>^;)Q!!FFmy+nHlD5
z1_lNY8;8e>K#8S@m4Sg_C36u60|P@5Cj$e+E!MKcoYGXVXCVYPNR+uawS*TGc$iie
zr<M>K)(9($*g+P8Jb`2hTS{t9YDua9l05<luR$b}LB4@`5X1&yaI}KF1By_HB_N|U
z86o}xv5~A{P0q<LP8CM7g&$!HSk6zA{T4@jd|qO1YJB`HuK4)e{FKrh5Su4HzOXbg
z2O?9%1M&nvhyb~{ND#zASO#W+LazuE3!o4#1`!-g9LyjH7R5;XAf@0OtcRTVxl))?
zm|Ga5m{V9%SX&sPSW?(h*jpH)SW`GsIKj!EF_=M<`xd85W^xHQ`TJqS2`J{k0VT%3
zzyM1BH4O2LHH-y(nG7`y@l5cb(_}6JDZRy#lb@V@izOwoBvF$I9FVs-GxIV_;z2nX
z5}a@!f<g-{7cU74R!~$hFmf<f3Blc?7atE%fZ;BXVz9gT7#J987_t}^FxD`pFf3#W
zW&lT}CR33(C}6>XjV0NDV?h>VEy&rR?0~QoTXq1&0oXn(sD1qkj39d%7ckW@)-Yu<
zE@Wh62xmxPU}0ckXl7<)$P+MRDAqAxU<AWR21W+tumXi9*nzj$N()jFOHzwK`2;O|
zia?1(0pv!IZ^1#si*O~j90YeIC^3LSrC*Jap@y-BA&aq$p-2uygWQYNtwx01%3P3N
zfGrOeffBL`$f0bYOvcE;$i-MCfN&}#6KXR0X|fjyfno)ejfzA-EKtmY;{xniut7+n
z08c7Kq6`cSpa_L#1}+v3W)2pxsGla=E%x~Ml>FrQ_*<NiY9uo+9g-Z`AaxNq*ML=H
YGyE2Z4J51Dfr^D<kRMoBc$fwF0rQYwn*aa+

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index b1058db3c293c3e418b78f03d0ada27255a6d3d4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 774
zcmYe~<>g{vU|^UdaWHi|69dCz5C<7^FfcGUFfcF_-(g^2s1itFNMX!j$YqRTWMl|u
z$dhAXNM)+jV`Kn9upBc)E|MXS$$+7XCxsz}DTgJBHJl+&3amB^q>_;VEY2Fm3RMR(
zmpO+mmpzId$=o)$TIL)Mh#Zo7mK@Gpt|%@f_1oa;S#r1`a!~agsXS4<;S70VEDWi9
zmDeEZQu(8JA@V6q!3>(LFG2p+WW2>*T9lKOpPA>U$#{#$BP1jsD7CmCKd(3y#Lp~_
zPb-K|&dD!MP0<v%#Zy|8laraGSCCj#oLa=hz`$^e+cUQyzo^8us3^ba7Ds7O4p{CM
zdvZW#a&}JYEw%zM9i>;0S)dnRmYSE6U!+%*T3DJ|TvDu8keHmEn4Vg!2Qk=KuLx>+
z5i<h=LzE1%CUhlHTFA1vjVvw6%qe04xm5yL1I##(^ey(%yv*eMl+;_CC8-r9@g<c7
zskb=&5_3}_{$egJDO$-;#LvJ0A$~PGTg8MHrxq2*q~@e#7RC7IrMeVlmZd7_DunuZ
zhPeg>dxkg$D|q_3`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-aX2+!FmBsjE
zCdCwImZa*!0wks&vp^pjT>8n0$r-81`FSNp`8oQ@`MCv&C3*#ww>WHa^HWN5QtcQ)
lDOQbvfq{upfRTq$h?$9zhmnVoj}^*ig3`=Pj2w(Si~w#0(%k?6

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/controller.cpython-39.pyc
deleted file mode 100644
index 1c44791a4bc4d1bb4f5cabcdb2c8dd7d69809daa..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/filewrapper.cpython-39.pyc
deleted file mode 100644
index 0841947fd645d6befe015bf398f76dabd0eccaea..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2199
zcmYe~<>g{vU|^UdaWM5MCj-M{5C<8vFfcGUFfcF_D=;uHq%fo~<}l<kMlmunxHF_M
zr7*WJq%fy4H8V#sr?3PwXtKTp>D6Ss#qLyDl3MKPpA6z7V`i9nP7DkTsSHt!DGX6e
zDU4Cf5YwVqQdm-0TNt8PQ`l12TNt9)QaDmLTNt9)Q}|Q3Q+Qe!qc~D{Q}|jKqBv8y
zf*CXgZV5Xl=Hw(LCTF{4=A?!fB^DH<7A2N3GB9u{C@3fd=O*UlD3n8l6%vc`OY>3`
z5*5-46!Md@Qj<#*$}=*PGZe}*b8-|)Qd1RD%TkLfOENO^(iMtQ6H^p2^Gfm+62V3#
zm8PYo7U?J?=A|f<XQbvSlw>59D5PcPq$*?<D<tRS7pJBuWR^h8O07suE-gt_NK{CM
zI!~cIvm`^IBqJ4USaN<|Norn6u|j?t#2kp}dR$;x$DAC6#FCPt%%swi)MACiqEv-~
zqWp@?)D(r1e2^ImrFki-MLCrqcY<92@eNdaNCwzJiN(bVrNybm3c0DdNvTD}5EmpW
zq~w<-<)lK4C{E5VN>$K^kJnVlNli=vnO9JhnwD9iP@J!jSPXVeUVaJ4+Qj7K%#_r;
zlEj>xN`>N##FYGUg~U9BJN3YdlR+^Ii*XQ}iGhK^8I*z~7#J8z7@8Ss7~&ag7;6~f
znQEA77~+{z7=jsAGWuz<6oHi9l8na^q4DuarD?Y$uuG*C+>*mC0}Fdi=36YqsX1x4
zn9>Svalk}ZG8Az$Ffjb;aJGsGElw>ej!Df)$t;TT&r5YF$}CG&&{YWa^9*wh3ib?f
z3|8>;bMg0c4fb@533l~$4GwV)QZS1N2=IwXG||n;PtPna$;^&P%`1!X$xMnV&MZmQ
zEl5nxPE1cNjw#42(2p-m%}dEI(oarI&PWACe^GvpJ}B;>iBqqj@)k#Yd}dx|NqoEj
zD8Sf2!N|zL$i`SDgC$J#V2YDL;RaF*!k{1rVQ`R(FfcIGFf3q5VO+>q%T&Tx!&JlA
z%oNO^$>diAGF_ADmOy-bdTI$gvBk&VVu$iInTt3W7#MD`<R#{&7I88#K!OV#W<@+8
z8E&}V_;^u}i$SFY11A?_l{|L$LQRg3Pi6$U6^cP@kWFAGyD%^?RPog?WHDqhrZAK;
zgfj#)urQP`RVpwtfM6s;9+Lq>6&F|qGhEgVB*(}AkxgL)d(lmk1?)?(+i&qX!ZMU=
zQBi);EjCDwUC9XcCB#>t<N)y+UwnLKaeP`qJVccu$ag{@_cAgu@-gu+vN16+a)D@;
zDkbcGMb?htT~I)Qy$dQ<L0%~m1I1GfLl)x#riBa(85tQ;KpBMrlsSq(sx_I5*g;Xi
z3JQ3R^wg5F#GKO9B2WyYyPXZ<Xd{rDL9xuh$i^tZUL}RqonZg@;Z8z2;3SmAuz;}!
zoQP@|vX~Yy*D!&cSi`V@Wg$b6Mh(LP)`bj=3^h!_3=qe%fdl>)3#be&0y~+tyeP9I
z^_CL$jEWpsMdAz$3@f3Dk2x{7<Q7XxVo4&JFN;9Mi7m*B;0lb9hmnVogOP)&N&=fV
zLGHlqM^FU^iUhbH8B-XunTix@m{OP^bT9)Jf7>AYTa(%EB`6;jg9u(OO=t*k#TO^0
zrN)Eo2ZuwEBq$Q4Km^E}MbaP^IN5;-P_`<PXJBA(1^J8*oZxsE1(;cwpuUsC<~xKP
znv8y$T%ckElxO4PZ*j%P=jNxB=A_2Q-{OgnFDy;Wfy%JQ$EV~c$Hy1(f?Oa7A`q?u
zg)P__NP&)UAE<Z%CCOrt`#2a`xH(ukcsK+(xVborKyrSXEVr04^C87K8>D6eOJFnY
R7KaVQg?6A~033Qe%mCFd9QyzO

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/heuristics.cpython-39.pyc
deleted file mode 100644
index 762c6978cd7a53faa5a511a76f8c8560e5f813ef..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4731
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
E08Nfkxc~qF

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/serialize.cpython-39.pyc
deleted file mode 100644
index 2ade01220d8e1573af27b8b9303741cea233c271..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/__pycache__/wrapper.cpython-39.pyc
deleted file mode 100644
index 2f99daf818dc703fd376949b4720b6abe42f8dd3..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 701
zcmYe~<>g{vU|^UdaWHig69dCz5C<8vGcYhXFfcF_t1&Pzq%fo~<}l<kMlmvi*i1Q0
zxy(__j0`F4DXb}MEsRktDa^qPnj9|~85kHe8E*+YCnjg4I_Kw=6y@hQrX&`Wq!wv1
z-r{u0OfCUS`Gq8NAlb&rz`y|FJA*9rVqjpXVN78tWhmk+VQ6N^W2#}SWvpQ<kSJlS
zWvgMUVXR@QVXk4RVXa|LVeDnA<)~p;z?8yN!?BQwkpawRhOvVgG+F#KS#NPCgB%o}
zT9TMve2c3%wJ0+&C$lQG=oV*2YH3ksaY<(KErDc+dvj8Y;*)a{i;Hgwf^{V(<)p^v
zrj}&nrxaJQXOxr_Sn2Cmaex@bR{Hvy%tg!$3=Bm~3=9mnSab7B^GY;1Z?P1o78l=Q
z1shPr0+MG15o{m=6tuT^6CuF@v8o8<`&;Z#v6T!(d<+Z>zgnEFVnT~ki;81Xb5b&k
zV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYs
zbMn(czRQkD%`1!X$xMnV&MZmQEl5nxPE1cNjw#42(2p-m%}dEI(g(X08V361MTrFk
zsYQAPmA81nF$RrHkS~g*KvBmn#K^(OgbaVNaquwmFck@a5&^qkh#v@OvKH}zJPit-
tB5n{199keXU{4|u{Gbrzu*uC&Da}c>10|(mAqEBp9!4Hk21X?K0|0qnuGIhl

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py
index f1e0ad94..4266b5ee 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/_cmd.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 import logging
 
 from pip._vendor import requests
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py
index 815650e8..94c75e1a 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/adapter.py
@@ -1,16 +1,20 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 import types
 import functools
 import zlib
 
 from pip._vendor.requests.adapters import HTTPAdapter
 
-from .controller import CacheController
+from .controller import CacheController, PERMANENT_REDIRECT_STATUSES
 from .cache import DictCache
 from .filewrapper import CallbackFileWrapper
 
 
 class CacheControlAdapter(HTTPAdapter):
-    invalidating_methods = {"PUT", "DELETE"}
+    invalidating_methods = {"PUT", "PATCH", "DELETE"}
 
     def __init__(
         self,
@@ -93,7 +97,7 @@ class CacheControlAdapter(HTTPAdapter):
                 response = cached_response
 
             # We always cache the 301 responses
-            elif response.status == 301:
+            elif int(response.status) in PERMANENT_REDIRECT_STATUSES:
                 self.controller.cache_response(request, response)
             else:
                 # Wrap the response file with a wrapper that will cache the
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py
index 94e07732..2a965f59 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/cache.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 """
 The cache object API for implementing caches. The default is a thread
 safe in-memory dictionary.
@@ -10,7 +14,7 @@ class BaseCache(object):
     def get(self, key):
         raise NotImplementedError()
 
-    def set(self, key, value):
+    def set(self, key, value, expires=None):
         raise NotImplementedError()
 
     def delete(self, key):
@@ -29,7 +33,7 @@ class DictCache(BaseCache):
     def get(self, key):
         return self.data.get(key, None)
 
-    def set(self, key, value):
+    def set(self, key, value, expires=None):
         with self.lock:
             self.data.update({key: value})
 
@@ -37,3 +41,25 @@ class DictCache(BaseCache):
         with self.lock:
             if key in self.data:
                 self.data.pop(key)
+
+
+class SeparateBodyBaseCache(BaseCache):
+    """
+    In this variant, the body is not stored mixed in with the metadata, but is
+    passed in (as a bytes-like object) in a separate call to ``set_body()``.
+
+    That is, the expected interaction pattern is::
+
+        cache.set(key, serialized_metadata)
+        cache.set_body(key)
+
+    Similarly, the body should be loaded separately via ``get_body()``.
+    """
+    def set_body(self, key, body):
+        raise NotImplementedError()
+
+    def get_body(self, key):
+        """
+        Return the body as file-like object.
+        """
+        raise NotImplementedError()
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py
index 0e1658fa..37827291 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__init__.py
@@ -1,2 +1,9 @@
-from .file_cache import FileCache  # noqa
-from .redis_cache import RedisCache  # noqa
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
+from .file_cache import FileCache, SeparateBodyFileCache
+from .redis_cache import RedisCache
+
+
+__all__ = ["FileCache", "SeparateBodyFileCache", "RedisCache"]
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index c73e5810a5331f1466b4a28580b19a019833375f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 321
zcmYe~<>g{vU|^UdaWFNEfq~&Mh=Yuo7#J8F7#J9eWf&M3QW#Pga~N_NqZk=MY^EHh
zT;?cdMursTU<OT=my8Sy44RC$INdUHQk@f%Gg37fZ*c{sreqd_d48HKx46<Wb5i4z
zL6Suvqi=B+f#jhg%nS?+D;bK|7#JYLuO4Tsn9$<XqT-m;oRrL>82`Lfm!izFR0Umy
zP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o
z7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk{33m@vy$`kN{aGxAe>_T`1s7c%#!$c
Zy@JYH95%W6DWy57b|8-ygPhO92mr!qSVsT=

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/file_cache.cpython-39.pyc
deleted file mode 100644
index 69ee4447ae818ae0a7b0a8a7e2a87e09b2cb0849..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3337
zcmYe~<>g{vU|^UdaWK_VfPvvLh=Ytd7#J8F7#J9eYZw?9QW#Pga~Pr^G-DKF3PTE0
z4pT036f+}33Udle4ofa;6f2m`n!}dM9>vbcP{onT!N?HKkSE2$kjhyZ#>fDIsa&bt
zX-rWZkqmiE1`H`|DeNr_Q9SMpDI6)BEet7~sjSV+QM@T!Dcmg#QG6+k!3>%_FG23|
z(`3BGmXey1npg6YiGhJZlkpa(Q(|$db7FEvswU$telWv1Kd+=HKPM-(C>f*(q!EN!
z7#J8h85kIxK^~gNz`#(#ki}TbRKrxlkOjibP7MAGwM-=}B@8Ky%}hmFU>R1p7*jJ-
zksVl!4J1~@SHiG>y@p{SBiMstEDR+aC7fwYl}R8kGBQ9sSHiG>tA?S5sfKYOb1gGi
z4|ff73iCpyaE4%TU@$V2Ff8DyVFsDg1l5(o5X_*-;&+S7Ki<#Z&ELnzKl~Plf4q~Y
zpJPzuEvE7$P2O8f`Nbfy@F0IbpU7M6{_)O1u8twM*!<&NBb<G1v1cR}Czg~H6|pfe
zFch&fFfiO=D@x7HFH60}?&<GZRFq$Ii`_pM!eGfSNX@&&mX-phS(9_}i&HgOZgHe#
z=A`B&=BD0aP0P(s0Z}=L>BYC0(o$A36iF~JF#PIswu%WYPAw{qNzF;gEQ;~ZOLZyA
zEK60;RS5O-408<%_6%_hR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy<
z%#KOTD~s{TOo}PaEJ@WZNKDR7OiwM2Dab6)k1tEjOUW<NPX@(vG9-E-oML^D8{@$e
zdIgoYgyM@+lS_+I<3T=&FE7e0N#zH{w*n{yFtM=-uy8SQF>^6;u`n_6F$yrTvGFl7
zG4e67F>x^#Nii@mB!d(pV^&xmaAII!NM!(}`zWRq!4%dMwid=H=2Vsx_7sj5hGxbn
z))dYZt`>$UwiNCZo)(5E_7vU}z7~ckjuieBffj}+&J>nl22G(`oNk#pkR<E&vVoC-
z;pG8F1_r-mP#nQ524zc7<^!kI2@DJjHLNKNrHn-qHEa+XoJJX&7^`Gbm{OQ?7;~9w
z*%=v9m{M4Bm~&ZbA(>8zg`tEMmg!2^QdpZAYdK3;YdD)3n;0V*@+1rxYFLYsYB*}y
z@_4`|GZf|3u-CHHFxD`{v)3@yFvN4zFxN1|bJnobFvN4!u+=ccbAwYSn_rc_b7Edz
zeu+Y9aViMMr(_nz=j116D<tNnD1aF8$vKI|#R?_)>8T|dsYOMMkSxpLlb@Uo3Ik2X
zTfDy6DVaqufvQzp3P`}uKg88a!81=GzbGZONTDPjWQ{^eMydixH#n~=ROXi|<dznf
zC}bp-rK0Etxd4<n6f*OQOA>Q(Qd9I4BJ)cXk`wb_LJFBB3T2sz3I&-3Rw#NEKtga;
zFq2S}X!6|R3QNo>O@(A34w#}MIZ$2`gK_n8K^}zhisV6(+@84w`9&pQjYXg$>K128
zW>IQ#Nq$k~E%vnhqSUg~B1rB7XFK+k%px#@3uF!?R5iJ7u@tA~q!p=v^0z98Py-R_
zAPaa(i&NpzQKSJ92e}GjJ6m3UNoH~?IR8QjNsu0n`1s7c%#!$cD^Pv`nZ>{*z{tVG
z#K^-az{tbM#K`oYg`JO?g^`VkgOP=ajS&K?gy4~(2QwlW6w|P@3}Umu%3UFFxx0X|
zhG7BILWYHm3z!!&1T(B;^wVSk7g-rOnMt?UiZc?8j7)B^rRF7riXG03)QXhM^wi=K
zO~zY{6%a>*ik~8o%Zm&c7#I>kjs^uK15=d%!a)!NFscE#bId?li(vsn4dX(_TBZ`l
z8YWOJ*UBWx(9BrFl+Gy5P|IAxl*OFIQp1qNn$B3myofP~p$}9%Gx@y)6%CqfVEb>e
z<YX3?6mfz=lBFQAB;yuKR(@t4ICeByiZsFE;G&c*Be6ImHRTp-L1Ix!F`8d)F~_In
zrGoqdDz+JzxfsP5t9TLqiBHSJ@C>}1h(Ym8l?B*4jLl5_Qnk!A%%JcNXJBGTVPIik
zVQ6Ls)mp&}h784K2GDvak^v-^C&I!|!VD`lA{jur-2hB#GWp$NDoWC1DFP*tB0;d9
zic%9(ZV7^1=$BvOmS38e0#4R2KQm{iRu-9qR5GPyV0bn?wIm1RSsqYYVdP>2r8ONU
z9uzO9r<No$gXEzY6fmG*1{aNskiE=YB~`+>fT@Hri+KSHs6qwB*+M3;r$E&+TM2s_
zQ>7Jh^<2ZSfCHqm-=mhLgtLYvi@Am&iwhiNtTn6)xNDd|)p9sepyde|G8C7g1{oqq
z!Ln13WkJDLqzfwecp$+Ba{Dcg+{EnEl+2>yB2!S<fHF8JaTI}aZxN`%DiQ!?T5!$<
z)k;O6{CJBMT%T#Ofs<2_9Y`l@8K?+?gfI)JbSSb1X#{5uFagRTx0s7lOG-fj4KkI1
zk&Bs$QHoK3k&TImNdP6Vi&INb(ibS;;pq!Cv(zwTF%}zD@s%(wV1@-#o)8N|2}`8`
zau6c|fE5w|;Iax73PpS%r`m$Th8f`{uwT$q3R_BQPHIVNGsq9H#KH!uxEXmEk@Gu5
znI@}SkqpReSq26MKR->bTO9H6pzw{4zr__FpPQdjnv)tIe~TwRzOXbg2O?9X0}4-`
z;*!LY%;enEl8pQmaL$G}8q^9das!#^4kExoiy%OOTqMoFz+eG#AV{2p6`H9S8Gdr9
zGcj^8bFg!8a`1swVFWQKn8E2;1YSIX%A*>_1x%oz4Q9|}tcnRrEh#O^16P0GYAqSm
z7*YV0H3~_I#i=O@`4Gv_ARj$0a8(tOky)&elAl_v0IH@_^NLH0QW5%7D>92qiWR{s
zHJOV*h1o4mu%Yp#MLA$^Yck(rE-lKr#R;+yECo(==&>VET9gxCk{=IJ6%TSy4=5Nw
zg)9Rr7h{n>D2Dlq^gsaziuYR_C8-r9<wc1Fkjjr0VlqhmEiP#5E+@4J?4lx2^0>w6
zmzWEwXOS`oIA4GQ9c%%Tn?T_Yt{HA|*yMua+746)6^k)2FmNz(F!C_*F!C@lfmwXa
I9GU_l0N1qn5C8xG

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/__pycache__/redis_cache.cpython-39.pyc
deleted file mode 100644
index 25d81532e984ec5fec1d5b61f04ded9f82bc250e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1593
zcmYe~<>g{vU|^UdaWFN4nStRkh=Yt-7#J8F7#J9eEf^RWQW#Pga~N_NqZk=MY^EHh
zT&5@{Fq=7tIhQ4hg^|IXA%!J{wS^&tHI=2AIf^xfEto-*{UyjuO~zXsDVb%N#hLke
zV0L0jYDs2pswU$tPN&4;ROiIxjMQY1N@UCobAcTL14Al96k`fQ6jKUg3R4S16mtr5
z3QG$^6iW(U3R?<$3u6>(3P%cO3qurJ3Renu3qurp3Qr1e3quq~3TrTfCjTw2pwyJi
zVu(#lNY;SZAnXkCD=0{67;6~f8B!R68CEj-X)@koNzTv9(`35EQk<HTR>aQ0z_5~`
zh?9YV;a9)2RZM7cYEf}aYEDXKQH+0Hs!LI3S*n7rLa3i-m}^k5XNY64f~TL0zn^Qc
zr(;a8tFLQth-;97Sxi8HPfVhTZccuBW^qYoc1&tsS&UC+QcQ7XNvdu^Vsdt3dTMb@
zL1uw|d|7H<N`8@kGB}X(^Gb^Hb0C~z{UVT`;=wX{1(mlr;^Q;(GE3s)IYFKQ`HF$D
zN*LjBJ(zqlSPmKrAT}th!6CrIz`#($kj1cov4(LWV=zMz8v_G_CKK4-x0usYOI9)!
zaWF72++xm7tpo=HgaCzH5lAx#7lVvsV65UpvN}Dr#4j0?sGznofY>0z!PeS<tYt11
zfmvO{w2+CBAy1`-xrAu}^Fjs*hFWH@97_#j32P1W0=9(=&5Sin3z<QQ5avvFs56UG
zONu}~y2VynlAM=cev7p@wIsFT7IS7^$t~WJ{F20+_~O*${JfN6O%||siugc&Vl7L|
zDNVh_o?20mS(I7~@fj#Ai@@IFXJB9e;bKq#Ffg((3NZ1Yda^jR1b5I1fcyv#T4Z-a
zgO@EOH7B(swTPF20g}QX4glLN#=yV;!mywfL<(Anwq!<F$TBc6fFb}Cz~I1DfLpwf
z!G$4Kpq3FFluV!)W@ISjN?{CU&}6Fe^hnJqNG(!G%P&$$&Ph!y%FIhwNX*GmD9K1w
z$WE;+R>;g#NK{BkEJ;jCEKb!^2rW)kD9<d(;8K8s<iygF%=|n>KTT#xOt65o6@lE1
z%~Q8n!PZEE5-Z5D49t9tRRTyJ152a$3*<)-2Kx)72kLfvur7tt;?!aVP<~BK2028b
zAU{7RGcR37AunGcFEuqqp(I}+IVZn373?R3LOnllP-`+m5(7BO!2~GmLC(xCPL&5a
z6BMotOlXeGFHY5D^wZ=7<-fed+|>B^TU_z+x%nxjIUqJqe0*VPVh%*6h#M5SpiEK(
zN=lHhkpPK-f&uIbBm!i85i0`&1E|<32I=Bp;$Y@r=3?hy=3oQM_-V3%Y)dOGDJ@Ek
zk1qnb5S;j<<O(ti^q{4O9=ME1hLj!<P7x^hz(ychi10Lr4a5U>px`bBWmFy}9!4H!
E0Pzo9l>h($

diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py
index 607b9452..f1ddb2eb 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/file_cache.py
@@ -1,8 +1,12 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 import hashlib
 import os
 from textwrap import dedent
 
-from ..cache import BaseCache
+from ..cache import BaseCache, SeparateBodyBaseCache
 from ..controller import CacheController
 
 try:
@@ -53,7 +57,8 @@ def _secure_open_write(filename, fmode):
         raise
 
 
-class FileCache(BaseCache):
+class _FileCacheMixin:
+    """Shared implementation for both FileCache variants."""
 
     def __init__(
         self,
@@ -114,22 +119,27 @@ class FileCache(BaseCache):
         except FileNotFoundError:
             return None
 
-    def set(self, key, value):
+    def set(self, key, value, expires=None):
         name = self._fn(key)
+        self._write(name, value)
 
+    def _write(self, path, data: bytes):
+        """
+        Safely write the data to the given path.
+        """
         # Make sure the directory exists
         try:
-            os.makedirs(os.path.dirname(name), self.dirmode)
+            os.makedirs(os.path.dirname(path), self.dirmode)
         except (IOError, OSError):
             pass
 
-        with self.lock_class(name) as lock:
+        with self.lock_class(path) as lock:
             # Write our actual file
             with _secure_open_write(lock.path, self.filemode) as fh:
-                fh.write(value)
+                fh.write(data)
 
-    def delete(self, key):
-        name = self._fn(key)
+    def _delete(self, key, suffix):
+        name = self._fn(key) + suffix
         if not self.forever:
             try:
                 os.remove(name)
@@ -137,6 +147,38 @@ class FileCache(BaseCache):
                 pass
 
 
+class FileCache(_FileCacheMixin, BaseCache):
+    """
+    Traditional FileCache: body is stored in memory, so not suitable for large
+    downloads.
+    """
+
+    def delete(self, key):
+        self._delete(key, "")
+
+
+class SeparateBodyFileCache(_FileCacheMixin, SeparateBodyBaseCache):
+    """
+    Memory-efficient FileCache: body is stored in a separate file, reducing
+    peak memory usage.
+    """
+
+    def get_body(self, key):
+        name = self._fn(key) + ".body"
+        try:
+            return open(name, "rb")
+        except FileNotFoundError:
+            return None
+
+    def set_body(self, key, body):
+        name = self._fn(key) + ".body"
+        self._write(name, body)
+
+    def delete(self, key):
+        self._delete(key, "")
+        self._delete(key, ".body")
+
+
 def url_to_file_path(url, filecache):
     """Return the file cache path based on the URL.
 
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py
index ed705ce7..2cba4b07 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/caches/redis_cache.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 from __future__ import division
 
 from datetime import datetime
@@ -15,9 +19,11 @@ class RedisCache(BaseCache):
     def set(self, key, value, expires=None):
         if not expires:
             self.conn.set(key, value)
-        else:
+        elif isinstance(expires, datetime):
             expires = expires - datetime.utcnow()
             self.conn.setex(key, int(expires.total_seconds()), value)
+        else:
+            self.conn.setex(key, expires, value)
 
     def delete(self, key):
         self.conn.delete(key)
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py
index 33b5aed0..ccec9379 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/compat.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 try:
     from urllib.parse import urljoin
 except ImportError:
@@ -9,7 +13,6 @@ try:
 except ImportError:
     import pickle
 
-
 # Handle the case where the requests module has been patched to not have
 # urllib3 bundled as part of its source.
 try:
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py
index dafe55ca..7f23529f 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/controller.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 """
 The httplib2 algorithms ported for use with requests.
 """
@@ -9,7 +13,7 @@ from email.utils import parsedate_tz
 
 from pip._vendor.requests.structures import CaseInsensitiveDict
 
-from .cache import DictCache
+from .cache import DictCache, SeparateBodyBaseCache
 from .serialize import Serializer
 
 
@@ -17,19 +21,20 @@ logger = logging.getLogger(__name__)
 
 URI = re.compile(r"^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))?")
 
+PERMANENT_REDIRECT_STATUSES = (301, 308)
+
 
 def parse_uri(uri):
     """Parses a URI using the regex given in Appendix B of RFC 3986.
 
-        (scheme, authority, path, query, fragment) = parse_uri(uri)
+    (scheme, authority, path, query, fragment) = parse_uri(uri)
     """
     groups = URI.match(uri).groups()
     return (groups[1], groups[3], groups[4], groups[6], groups[8])
 
 
 class CacheController(object):
-    """An interface to see if request should cached or not.
-    """
+    """An interface to see if request should cached or not."""
 
     def __init__(
         self, cache=None, cache_etags=True, serializer=None, status_codes=None
@@ -37,7 +42,7 @@ class CacheController(object):
         self.cache = DictCache() if cache is None else cache
         self.cache_etags = cache_etags
         self.serializer = serializer or Serializer()
-        self.cacheable_status_codes = status_codes or (200, 203, 300, 301)
+        self.cacheable_status_codes = status_codes or (200, 203, 300, 301, 308)
 
     @classmethod
     def _urlnorm(cls, uri):
@@ -141,23 +146,29 @@ class CacheController(object):
             logger.debug("No cache entry available")
             return False
 
+        if isinstance(self.cache, SeparateBodyBaseCache):
+            body_file = self.cache.get_body(cache_url)
+        else:
+            body_file = None
+
         # Check whether it can be deserialized
-        resp = self.serializer.loads(request, cache_data)
+        resp = self.serializer.loads(request, cache_data, body_file)
         if not resp:
             logger.warning("Cache entry deserialization failed, entry ignored")
             return False
 
-        # If we have a cached 301, return it immediately. We don't
-        # need to test our response for other headers b/c it is
+        # If we have a cached permanent redirect, return it immediately. We
+        # don't need to test our response for other headers b/c it is
         # intrinsically "cacheable" as it is Permanent.
+        #
         # See:
         #   https://tools.ietf.org/html/rfc7231#section-6.4.2
         #
         # Client can try to refresh the value by repeating the request
         # with cache busting headers as usual (ie no-cache).
-        if resp.status == 301:
+        if int(resp.status) in PERMANENT_REDIRECT_STATUSES:
             msg = (
-                'Returning cached "301 Moved Permanently" response '
+                "Returning cached permanent redirect response "
                 "(ignoring date and etag information)"
             )
             logger.debug(msg)
@@ -244,6 +255,26 @@ class CacheController(object):
 
         return new_headers
 
+    def _cache_set(self, cache_url, request, response, body=None, expires_time=None):
+        """
+        Store the data in the cache.
+        """
+        if isinstance(self.cache, SeparateBodyBaseCache):
+            # We pass in the body separately; just put a placeholder empty
+            # string in the metadata.
+            self.cache.set(
+                cache_url,
+                self.serializer.dumps(request, response, b""),
+                expires=expires_time,
+            )
+            self.cache.set_body(cache_url, body)
+        else:
+            self.cache.set(
+                cache_url,
+                self.serializer.dumps(request, response, body),
+                expires=expires_time,
+            )
+
     def cache_response(self, request, response, body=None, status_codes=None):
         """
         Algorithm for caching requests.
@@ -261,6 +292,11 @@ class CacheController(object):
 
         response_headers = CaseInsensitiveDict(response.headers)
 
+        if "date" in response_headers:
+            date = calendar.timegm(parsedate_tz(response_headers["date"]))
+        else:
+            date = 0
+
         # If we've been given a body, our response has a Content-Length, that
         # Content-Length is valid then we can check to see if the body we've
         # been given matches the expected size, and if it doesn't we'll just
@@ -304,35 +340,62 @@ class CacheController(object):
 
         # If we've been given an etag, then keep the response
         if self.cache_etags and "etag" in response_headers:
+            expires_time = 0
+            if response_headers.get("expires"):
+                expires = parsedate_tz(response_headers["expires"])
+                if expires is not None:
+                    expires_time = calendar.timegm(expires) - date
+
+            expires_time = max(expires_time, 14 * 86400)
+
+            logger.debug("etag object cached for {0} seconds".format(expires_time))
             logger.debug("Caching due to etag")
-            self.cache.set(
-                cache_url, self.serializer.dumps(request, response, body=body)
-            )
+            self._cache_set(cache_url, request, response, body, expires_time)
 
-        # Add to the cache any 301s. We do this before looking that
-        # the Date headers.
-        elif response.status == 301:
-            logger.debug("Caching permanant redirect")
-            self.cache.set(cache_url, self.serializer.dumps(request, response))
+        # Add to the cache any permanent redirects. We do this before looking
+        # that the Date headers.
+        elif int(response.status) in PERMANENT_REDIRECT_STATUSES:
+            logger.debug("Caching permanent redirect")
+            self._cache_set(cache_url, request, response, b"")
 
         # Add to the cache if the response headers demand it. If there
         # is no date header then we can't do anything about expiring
         # the cache.
         elif "date" in response_headers:
+            date = calendar.timegm(parsedate_tz(response_headers["date"]))
             # cache when there is a max-age > 0
             if "max-age" in cc and cc["max-age"] > 0:
                 logger.debug("Caching b/c date exists and max-age > 0")
-                self.cache.set(
-                    cache_url, self.serializer.dumps(request, response, body=body)
+                expires_time = cc["max-age"]
+                self._cache_set(
+                    cache_url,
+                    request,
+                    response,
+                    body,
+                    expires_time,
                 )
 
             # If the request can expire, it means we should cache it
             # in the meantime.
             elif "expires" in response_headers:
                 if response_headers["expires"]:
-                    logger.debug("Caching b/c of expires header")
-                    self.cache.set(
-                        cache_url, self.serializer.dumps(request, response, body=body)
+                    expires = parsedate_tz(response_headers["expires"])
+                    if expires is not None:
+                        expires_time = calendar.timegm(expires) - date
+                    else:
+                        expires_time = None
+
+                    logger.debug(
+                        "Caching b/c of expires header. expires in {0} seconds".format(
+                            expires_time
+                        )
+                    )
+                    self._cache_set(
+                        cache_url,
+                        request,
+                        response,
+                        body,
+                        expires_time,
                     )
 
     def update_cached_response(self, request, response):
@@ -371,6 +434,6 @@ class CacheController(object):
         cached_response.status = 200
 
         # update our cache
-        self.cache.set(cache_url, self.serializer.dumps(request, cached_response))
+        self._cache_set(cache_url, request, cached_response)
 
         return cached_response
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py
index 30ed4c5a..f5ed5f6f 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/filewrapper.py
@@ -1,4 +1,9 @@
-from io import BytesIO
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
+from tempfile import NamedTemporaryFile
+import mmap
 
 
 class CallbackFileWrapper(object):
@@ -11,10 +16,17 @@ class CallbackFileWrapper(object):
 
     This class uses members with a double underscore (__) leading prefix so as
     not to accidentally shadow an attribute.
+
+    The data is stored in a temporary file until it is all available.  As long
+    as the temporary files directory is disk-based (sometimes it's a
+    memory-backed-``tmpfs`` on Linux), data will be unloaded to disk if memory
+    pressure is high.  For small files the disk usually won't be used at all,
+    it'll all be in the filesystem memory cache, so there should be no
+    performance impact.
     """
 
     def __init__(self, fp, callback):
-        self.__buf = BytesIO()
+        self.__buf = NamedTemporaryFile("rb+", delete=True)
         self.__fp = fp
         self.__callback = callback
 
@@ -49,7 +61,19 @@ class CallbackFileWrapper(object):
 
     def _close(self):
         if self.__callback:
-            self.__callback(self.__buf.getvalue())
+            if self.__buf.tell() == 0:
+                # Empty file:
+                result = b""
+            else:
+                # Return the data without actually loading it into memory,
+                # relying on Python's buffer API and mmap(). mmap() just gives
+                # a view directly into the filesystem's memory cache, so it
+                # doesn't result in duplicate memory use.
+                self.__buf.seek(0, 0)
+                result = memoryview(
+                    mmap.mmap(self.__buf.fileno(), 0, access=mmap.ACCESS_READ)
+                )
+            self.__callback(result)
 
         # We assign this to None here, because otherwise we can get into
         # really tricky problems where the CPython interpreter dead locks
@@ -58,9 +82,16 @@ class CallbackFileWrapper(object):
         # and allows the garbage collector to do it's thing normally.
         self.__callback = None
 
+        # Closing the temporary file releases memory and frees disk space.
+        # Important when caching big files.
+        self.__buf.close()
+
     def read(self, amt=None):
         data = self.__fp.read(amt)
-        self.__buf.write(data)
+        if data:
+            # We may be dealing with b'', a sign that things are over:
+            # it's passed e.g. after we've already closed self.__buf.
+            self.__buf.write(data)
         if self.__is_fp_closed():
             self._close()
 
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py
index 6c0e9790..ebe4a96f 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/heuristics.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 import calendar
 import time
 
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py
index 3b6ec2de..7fe1a3e3 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/serialize.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 import base64
 import io
 import json
@@ -17,24 +21,18 @@ def _b64_decode_str(s):
     return _b64_decode_bytes(s).decode("utf8")
 
 
-class Serializer(object):
+_default_body_read = object()
+
 
+class Serializer(object):
     def dumps(self, request, response, body=None):
         response_headers = CaseInsensitiveDict(response.headers)
 
         if body is None:
+            # When a body isn't passed in, we'll read the response. We
+            # also update the response with a new file handler to be
+            # sure it acts as though it was never read.
             body = response.read(decode_content=False)
-
-            # NOTE: 99% sure this is dead code. I'm only leaving it
-            #       here b/c I don't have a test yet to prove
-            #       it. Basically, before using
-            #       `cachecontrol.filewrapper.CallbackFileWrapper`,
-            #       this made an effort to reset the file handle. The
-            #       `CallbackFileWrapper` short circuits this code by
-            #       setting the body as the content is consumed, the
-            #       result being a `body` argument is *always* passed
-            #       into cache_response, and in turn,
-            #       `Serializer.dump`.
             response._fp = io.BytesIO(body)
 
         # NOTE: This is all a bit weird, but it's really important that on
@@ -46,7 +44,7 @@ class Serializer(object):
         #       enough to have msgpack know the difference.
         data = {
             u"response": {
-                u"body": body,
+                u"body": body,  # Empty bytestring if body is stored separately
                 u"headers": dict(
                     (text_type(k), text_type(v)) for k, v in response.headers.items()
                 ),
@@ -71,7 +69,7 @@ class Serializer(object):
 
         return b",".join([b"cc=4", msgpack.dumps(data, use_bin_type=True)])
 
-    def loads(self, request, data):
+    def loads(self, request, data, body_file=None):
         # Short circuit if we've been given an empty set of data
         if not data:
             return
@@ -94,14 +92,14 @@ class Serializer(object):
 
         # Dispatch to the actual load method for the given version
         try:
-            return getattr(self, "_loads_v{}".format(ver))(request, data)
+            return getattr(self, "_loads_v{}".format(ver))(request, data, body_file)
 
         except AttributeError:
             # This is a version we don't have a loads function for, so we'll
             # just treat it as a miss and return None
             return
 
-    def prepare_response(self, request, cached):
+    def prepare_response(self, request, cached, body_file=None):
         """Verify our vary headers match and construct a real urllib3
         HTTPResponse object.
         """
@@ -127,7 +125,10 @@ class Serializer(object):
         cached["response"]["headers"] = headers
 
         try:
-            body = io.BytesIO(body_raw)
+            if body_file is None:
+                body = io.BytesIO(body_raw)
+            else:
+                body = body_file
         except TypeError:
             # This can happen if cachecontrol serialized to v1 format (pickle)
             # using Python 2. A Python 2 str(byte string) will be unpickled as
@@ -139,21 +140,22 @@ class Serializer(object):
 
         return HTTPResponse(body=body, preload_content=False, **cached["response"])
 
-    def _loads_v0(self, request, data):
+    def _loads_v0(self, request, data, body_file=None):
         # The original legacy cache data. This doesn't contain enough
         # information to construct everything we need, so we'll treat this as
         # a miss.
         return
 
-    def _loads_v1(self, request, data):
+    def _loads_v1(self, request, data, body_file=None):
         try:
             cached = pickle.loads(data)
         except ValueError:
             return
 
-        return self.prepare_response(request, cached)
+        return self.prepare_response(request, cached, body_file)
 
-    def _loads_v2(self, request, data):
+    def _loads_v2(self, request, data, body_file=None):
+        assert body_file is None
         try:
             cached = json.loads(zlib.decompress(data).decode("utf8"))
         except (ValueError, zlib.error):
@@ -171,18 +173,18 @@ class Serializer(object):
             for k, v in cached["vary"].items()
         )
 
-        return self.prepare_response(request, cached)
+        return self.prepare_response(request, cached, body_file)
 
-    def _loads_v3(self, request, data):
+    def _loads_v3(self, request, data, body_file):
         # Due to Python 2 encoding issues, it's impossible to know for sure
         # exactly how to load v3 entries, thus we'll treat these as a miss so
         # that they get rewritten out as v4 entries.
         return
 
-    def _loads_v4(self, request, data):
+    def _loads_v4(self, request, data, body_file=None):
         try:
             cached = msgpack.loads(data, raw=False)
         except ValueError:
             return
 
-        return self.prepare_response(request, cached)
+        return self.prepare_response(request, cached, body_file)
diff --git a/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py b/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py
index d8e6fc6a..b6ee7f20 100644
--- a/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py
+++ b/env/Lib/site-packages/pip/_vendor/cachecontrol/wrapper.py
@@ -1,3 +1,7 @@
+# SPDX-FileCopyrightText: 2015 Eric Larson
+#
+# SPDX-License-Identifier: Apache-2.0
+
 from .adapter import CacheControlAdapter
 from .cache import DictCache
 
diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__init__.py b/env/Lib/site-packages/pip/_vendor/certifi/__init__.py
index 17aaf900..705f416d 100644
--- a/env/Lib/site-packages/pip/_vendor/certifi/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/certifi/__init__.py
@@ -1,3 +1,4 @@
 from .core import contents, where
 
-__version__ = "2020.12.05"
+__all__ = ["contents", "where"]
+__version__ = "2023.05.07"
diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 99d32824883247cc407f8e383caf487b5f3a287f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 303
zcmYe~<>g{vU|^UdaWK`6fq~&Mh=Yuo7#J8F7#J9eB^VeOQW#Pga~N_NqZo6UqL>&N
zQkbHcQ<#GpG+ACUGB7Y`GTq`x&d)1J%_}Ls#af<`T9jJFWn^Gvpl4{LXJG25$#RP&
zIlm~i2xMpxGXn#|E$;aEvecsD%>2Cg_>~MrYzzz#;#Y&SRZM7cYEf}aYEDXKQH+0H
zs!LI3S*n7rLa3i-m}^k5XNY64f~TL0zn^Qcr(;a8tFLQth-;97Sxi8HPfVhTZccuB
zW^qYoc1&tsS&UC+QcQ7XNvdu^Vsdt3dTMb@L1uw|d|7H<N`8@ka%xdYW?H6xe0*kJ
dW=VX!UP0w84x8Nkl+v73JCN6kK~5H60swD<QFZ_T

diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/__main__.cpython-39.pyc
deleted file mode 100644
index 4612f777771face6c86a29b2157064620795bdcb..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 480
zcmYe~<>g{vU|^UdaWM5i0|Ucj5C<8vGB7YWFfcF_M=&rjq%fo~<}gHoXr>&-T&5_d
zT;?cdMut>|1uP30qF7T|v)EFYQ&>`1Q`mYz;;akU7cxX~q;h026?vs{rZP1%G&3?X
z<Z-2PrZPj=DU87kn(Qw@cKT^D-Qq~j&nrpID=EIkTAq<wlv>54n_R`Es|y$ADlW+{
zN{ufmDoxd7yv3H7T#}ier^$7TBe5vGAhD=8^_Fl!W`SOOS!!NNevw{sYEemMT4oUw
z0|P@5GXn#|Ek4Jh^wQkaypjNr>Y`h0U|mJGcoI`m;uE2Ax46KfAb#;Jmc*j;;#;f*
zMVWaeD;bLTKt_RxUk%PyF`>n&Ma40xIVqV%G5&d}E=8GTsS3IZp?;oWu0g?`A&$Wc
zo_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylBsk#M;
z$=QkNsl_n`nFab#ujoU)q8}fho0ypwAFo$Xd5gm)H$SB`C)JJ-6h|OOaWDxmaWD!n
Laxk$m@-P7a>4S@2

diff --git a/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/certifi/__pycache__/core.cpython-39.pyc
deleted file mode 100644
index 61150cb275e196c9b6cc95dfacb202ace573d423..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1571
zcmYe~<>g{vU|^UdaWGYan}Ojmh=Ytd7#J8F7#J9e7cej|q%cG=q%fv1<uFDux-+CO
zr?9jzq_CtiH8V#sS2?9JX0a?_O<`Tg7{!*#R%DaHmcrh`5XGL#+|1C#n8KLCk;9S8
z8O4>$9mUPakiwM6lfsn9o5BfE70!@n!orZsTv@=#0D_SWc`7UnseF}_Ks-i<6oC}(
z6rL8wDDD(qh>l2xJSGE%6uuPx7KSMP6sBMXO~I;EuH@9BlFYPBy@E=vIym6s3dzVU
zR>;jyDa}b$C`v6UEy^oaD9K1w$jmD)NzBPfEXmBzQ^?6rhA{He6p|A`Cg~NV<|^bD
zDP)!uD<tRVm89mC6zg%l1O<^_GKfURjIhAsVPIfLWr$)-VTfW%VGL%_WV$65ACOrP
zkXVwOk(%NRabj{}NvfYF^DU0}_`Jm2)cE*YT=DU_U?;}M-{OgnFDy;Wfyk_6C}Lw^
zfDpfGoULL)i&Kk=V^VWcGK*sT^HN=kGRsmGbQMDVJi}arf;~eVgB3jeT>Sl9gFPK%
zf?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+^U7j;GLvG8GfPr+3lfvF6Vp?RV+t}0
z^yAA?^HTDQ^g*GJnU<-aoL`ixS5R5R#K6D+@?SBC!NCaT-x7%r@C=9#4srBzarE)`
zbB%X)4GO^;KF*-T#KOS9P{I(*pvmZ`$yfwRV+ij-SnLc847XUzGg6CE#XvehmN76E
zaWXJ~0+Xd6u_WUbXHjZmN_<IbMG1yY%nS?+V4IY{Hl;9>G8D;`fD$27GgBf{33Cb4
z0+xjg&5Vf<cQE@^2^VA*=s`WL2lezXE<`HOWWB``@9YTjSbTtEh{r9C^wg4gutT_E
z;?5xvx0s7dif(bn$EW6%q!z`;L%aizydsdtz}}Dtc?;xq1`ZBxE=C@vTdax2$(fnS
zAh*L(6)2!UYQTQ60sEzdv6&%-v4$yysh7E5qL#Uac>&WxhHwTZh7<-C1{Q{9W=4i!
z21ABoJp*t?Vq}P9U}Q)Eg*LO_EykjijJG&a^OEyZGV{_knQyV=7o_Ha9dwHY6rP$a
zx7eYH@D?lBdqtw4xL`?1EJ;N24A>vs3=9nRAb)_|$-pSYSOgM5i49Pm0Lg-VAO-e8
z7UKe@66S@BwG1T;S&R!<Y8X-&7lN`clV1@iWofeBV#+Tr0u@ZR*i$l#Kv@8kNzyWN
zK$(OkD?c+&lkpZ~8oF~pslyfF93CbVmw>{Q6_zgez%Bt5W}srMmpPb0lhyAQJ2c+G
z&L|QB<v0;gii7wI$vSX+f`Z@{2dq@^23ZVEriu_vAOkc7Zn4M5r{pKc#}`S10+Q3U
zB004HRNO$a4tr`|S!Pjw-Yw?z)DlQu0QuvVaAs~neo;wIW|Ce}YH@yPQF1CIOo~8m
z2M2T!Kgfl=AXB+L!Kz)0it>w!K-Ob-tPP}iu>+;CVo=^-VdG#HU}0k6VPs+CU}9qu
TU}9lpVd9bC0g<d+Y<z40h-+Gl

diff --git a/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem b/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem
index c9459dc8..5183934b 100644
--- a/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem
+++ b/env/Lib/site-packages/pip/_vendor/certifi/cacert.pem
@@ -28,36 +28,6 @@ DKqC5JlR3XC321Y9YeRq4VzW9v493kHMB65jUr9TU/Qr6cf9tveCX4XSQRjbgbME
 HMUfpIBvFSDJ3gyICh3WZlXi/EjJKSZp4A==
 -----END CERTIFICATE-----
 
-# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R2
-# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign Root CA - R2
-# Label: "GlobalSign Root CA - R2"
-# Serial: 4835703278459682885658125
-# MD5 Fingerprint: 94:14:77:7e:3e:5e:fd:8f:30:bd:41:b0:cf:e7:d0:30
-# SHA1 Fingerprint: 75:e0:ab:b6:13:85:12:27:1c:04:f8:5f:dd:de:38:e4:b7:24:2e:fe
-# SHA256 Fingerprint: ca:42:dd:41:74:5f:d0:b8:1e:b9:02:36:2c:f9:d8:bf:71:9d:a1:bd:1b:1e:fc:94:6f:5b:4c:99:f4:2c:1b:9e
------BEGIN CERTIFICATE-----
-MIIDujCCAqKgAwIBAgILBAAAAAABD4Ym5g0wDQYJKoZIhvcNAQEFBQAwTDEgMB4G
-A1UECxMXR2xvYmFsU2lnbiBSb290IENBIC0gUjIxEzARBgNVBAoTCkdsb2JhbFNp
-Z24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMDYxMjE1MDgwMDAwWhcNMjExMjE1
-MDgwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxTaWduIFJvb3QgQ0EgLSBSMjETMBEG
-A1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2lnbjCCASIwDQYJKoZI
-hvcNAQEBBQADggEPADCCAQoCggEBAKbPJA6+Lm8omUVCxKs+IVSbC9N/hHD6ErPL
-v4dfxn+G07IwXNb9rfF73OX4YJYJkhD10FPe+3t+c4isUoh7SqbKSaZeqKeMWhG8
-eoLrvozps6yWJQeXSpkqBy+0Hne/ig+1AnwblrjFuTosvNYSuetZfeLQBoZfXklq
-tTleiDTsvHgMCJiEbKjNS7SgfQx5TfC4LcshytVsW33hoCmEofnTlEnLJGKRILzd
-C9XZzPnqJworc5HGnRusyMvo4KD0L5CLTfuwNhv2GXqF4G3yYROIXJ/gkwpRl4pa
-zq+r1feqCapgvdzZX99yqWATXgAByUr6P6TqBwMhAo6CygPCm48CAwEAAaOBnDCB
-mTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUm+IH
-V2ccHsBqBt5ZtJot39wZhi4wNgYDVR0fBC8wLTAroCmgJ4YlaHR0cDovL2NybC5n
-bG9iYWxzaWduLm5ldC9yb290LXIyLmNybDAfBgNVHSMEGDAWgBSb4gdXZxwewGoG
-3lm0mi3f3BmGLjANBgkqhkiG9w0BAQUFAAOCAQEAmYFThxxol4aR7OBKuEQLq4Gs
-J0/WwbgcQ3izDJr86iw8bmEbTUsp9Z8FHSbBuOmDAGJFtqkIk7mpM0sYmsL4h4hO
-291xNBrBVNpGP+DTKqttVCL1OmLNIG+6KYnX3ZHu01yiPqFbQfXf5WRDLenVOavS
-ot+3i9DAgBkcRcAtjOj4LaR0VknFBbVPFd5uRHg5h6h+u/N5GJG79G+dwfCMNYxd
-AfvDbbnvRG15RjF+Cv6pgsH/76tuIMRQyV+dTZsXjAzlAcmgQWpzU/qlULRuJQ/7
-TBj0/VLZjmmx6BEP3ojY+x1J96relc8geMJgEtslQIxq/H5COEBkEveegeGTLg==
------END CERTIFICATE-----
-
 # Issuer: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited
 # Subject: CN=Entrust.net Certification Authority (2048) O=Entrust.net OU=www.entrust.net/CPS_2048 incorp. by ref. (limits liab.)/(c) 1999 Entrust.net Limited
 # Label: "Entrust.net Premium 2048 Secure Server CA"
@@ -188,48 +158,6 @@ l2D4kF501KKaU73yqWjgom7C12yxow+ev+to51byrvLjKzg6CYG1a4XXvi3tPxq3
 smPi9WIsgtRqAEFQ8TmDn5XpNpaYbg==
 -----END CERTIFICATE-----
 
-# Issuer: CN=QuoVadis Root Certification Authority O=QuoVadis Limited OU=Root Certification Authority
-# Subject: CN=QuoVadis Root Certification Authority O=QuoVadis Limited OU=Root Certification Authority
-# Label: "QuoVadis Root CA"
-# Serial: 985026699
-# MD5 Fingerprint: 27:de:36:fe:72:b7:00:03:00:9d:f4:f0:1e:6c:04:24
-# SHA1 Fingerprint: de:3f:40:bd:50:93:d3:9b:6c:60:f6:da:bc:07:62:01:00:89:76:c9
-# SHA256 Fingerprint: a4:5e:de:3b:bb:f0:9c:8a:e1:5c:72:ef:c0:72:68:d6:93:a2:1c:99:6f:d5:1e:67:ca:07:94:60:fd:6d:88:73
------BEGIN CERTIFICATE-----
-MIIF0DCCBLigAwIBAgIEOrZQizANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJC
-TTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDElMCMGA1UECxMcUm9vdCBDZXJ0
-aWZpY2F0aW9uIEF1dGhvcml0eTEuMCwGA1UEAxMlUXVvVmFkaXMgUm9vdCBDZXJ0
-aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wMTAzMTkxODMzMzNaFw0yMTAzMTcxODMz
-MzNaMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1pdGVkMSUw
-IwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYDVQQDEyVR
-dW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG
-9w0BAQEFAAOCAQ8AMIIBCgKCAQEAv2G1lVO6V/z68mcLOhrfEYBklbTRvM16z/Yp
-li4kVEAkOPcahdxYTMukJ0KX0J+DisPkBgNbAKVRHnAEdOLB1Dqr1607BxgFjv2D
-rOpm2RgbaIr1VxqYuvXtdj182d6UajtLF8HVj71lODqV0D1VNk7feVcxKh7YWWVJ
-WCCYfqtffp/p1k3sg3Spx2zY7ilKhSoGFPlU5tPaZQeLYzcS19Dsw3sgQUSj7cug
-F+FxZc4dZjH3dgEZyH0DWLaVSR2mEiboxgx24ONmy+pdpibu5cxfvWenAScOospU
-xbF6lR1xHkopigPcakXBpBlebzbNw6Kwt/5cOOJSvPhEQ+aQuwIDAQABo4ICUjCC
-Ak4wPQYIKwYBBQUHAQEEMTAvMC0GCCsGAQUFBzABhiFodHRwczovL29jc3AucXVv
-dmFkaXNvZmZzaG9yZS5jb20wDwYDVR0TAQH/BAUwAwEB/zCCARoGA1UdIASCAREw
-ggENMIIBCQYJKwYBBAG+WAABMIH7MIHUBggrBgEFBQcCAjCBxxqBxFJlbGlhbmNl
-IG9uIHRoZSBRdW9WYWRpcyBSb290IENlcnRpZmljYXRlIGJ5IGFueSBwYXJ0eSBh
-c3N1bWVzIGFjY2VwdGFuY2Ugb2YgdGhlIHRoZW4gYXBwbGljYWJsZSBzdGFuZGFy
-ZCB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB1c2UsIGNlcnRpZmljYXRpb24gcHJh
-Y3RpY2VzLCBhbmQgdGhlIFF1b1ZhZGlzIENlcnRpZmljYXRlIFBvbGljeS4wIgYI
-KwYBBQUHAgEWFmh0dHA6Ly93d3cucXVvdmFkaXMuYm0wHQYDVR0OBBYEFItLbe3T
-KbkGGew5Oanwl4Rqy+/fMIGuBgNVHSMEgaYwgaOAFItLbe3TKbkGGew5Oanwl4Rq
-y+/foYGEpIGBMH8xCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBMaW1p
-dGVkMSUwIwYDVQQLExxSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MS4wLAYD
-VQQDEyVRdW9WYWRpcyBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggQ6tlCL
-MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAitQUtf70mpKnGdSk
-fnIYj9lofFIk3WdvOXrEql494liwTXCYhGHoG+NpGA7O+0dQoE7/8CQfvbLO9Sf8
-7C9TqnN7Az10buYWnuulLsS/VidQK2K6vkscPFVcQR0kvoIgR13VRH56FmjffU1R
-cHhXHTMe/QKZnAzNCgVPx7uOpHX6Sm2xgI4JVrmcGmD+XcHXetwReNDWXcG31a0y
-mQM6isxUJTkxgXsTIlG6Rmyhu576BGxJJnSP0nPrzDCi5upZIof4l/UO/erMkqQW
-xFIY6iHOsfHmhIHluqmGKPJDWl0Snawe2ajlCmqnf6CHKc/yiU3U7MXi5nrQNiOK
-SnQ2+Q==
------END CERTIFICATE-----
-
 # Issuer: CN=QuoVadis Root CA 2 O=QuoVadis Limited
 # Subject: CN=QuoVadis Root CA 2 O=QuoVadis Limited
 # Label: "QuoVadis Root CA 2"
@@ -345,33 +273,6 @@ JRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ6rBK+1YWc26sTfcioU+tHXot
 RSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAiFL39vmwLAw==
 -----END CERTIFICATE-----
 
-# Issuer: CN=Sonera Class2 CA O=Sonera
-# Subject: CN=Sonera Class2 CA O=Sonera
-# Label: "Sonera Class 2 Root CA"
-# Serial: 29
-# MD5 Fingerprint: a3:ec:75:0f:2e:88:df:fa:48:01:4e:0b:5c:48:6f:fb
-# SHA1 Fingerprint: 37:f7:6d:e6:07:7c:90:c5:b1:3e:93:1a:b7:41:10:b4:f2:e4:9a:27
-# SHA256 Fingerprint: 79:08:b4:03:14:c1:38:10:0b:51:8d:07:35:80:7f:fb:fc:f8:51:8a:00:95:33:71:05:ba:38:6b:15:3d:d9:27
------BEGIN CERTIFICATE-----
-MIIDIDCCAgigAwIBAgIBHTANBgkqhkiG9w0BAQUFADA5MQswCQYDVQQGEwJGSTEP
-MA0GA1UEChMGU29uZXJhMRkwFwYDVQQDExBTb25lcmEgQ2xhc3MyIENBMB4XDTAx
-MDQwNjA3Mjk0MFoXDTIxMDQwNjA3Mjk0MFowOTELMAkGA1UEBhMCRkkxDzANBgNV
-BAoTBlNvbmVyYTEZMBcGA1UEAxMQU29uZXJhIENsYXNzMiBDQTCCASIwDQYJKoZI
-hvcNAQEBBQADggEPADCCAQoCggEBAJAXSjWdyvANlsdE+hY3/Ei9vX+ALTU74W+o
-Z6m/AxxNjG8yR9VBaKQTBME1DJqEQ/xcHf+Js+gXGM2RX/uJ4+q/Tl18GybTdXnt
-5oTjV+WtKcT0OijnpXuENmmz/V52vaMtmdOQTiMofRhj8VQ7Jp12W5dCsv+u8E7s
-3TmVToMGf+dJQMjFAbJUWmYdPfz56TwKnoG4cPABi+QjVHzIrviQHgCWctRUz2Ej
-vOr7nQKV0ba5cTppCD8PtOFCx4j1P5iop7oc4HFx71hXgVB6XGt0Rg6DA5jDjqhu
-8nYybieDwnPz3BjotJPqdURrBGAgcVeHnfO+oJAjPYok4doh28MCAwEAAaMzMDEw
-DwYDVR0TAQH/BAUwAwEB/zARBgNVHQ4ECgQISqCqWITTXjwwCwYDVR0PBAQDAgEG
-MA0GCSqGSIb3DQEBBQUAA4IBAQBazof5FnIVV0sd2ZvnoiYw7JNn39Yt0jSv9zil
-zqsWuasvfDXLrNAPtEwr/IDva4yRXzZ299uzGxnq9LIR/WFxRL8oszodv7ND6J+/
-3DEIcbCdjdY0RzKQxmUk96BKfARzjzlvF4xytb1LyHr4e4PDKE6cCepnP7JnBBvD
-FNr450kkkdAdavphOe9r5yF1BgfYErQhIHBCcYHaPJo2vqZbDWpsmh+Re/n570K6
-Tk6ezAyNlNzZRZxe7EJQY670XcSxEtzKO6gunRRaBXW37Ndj4ro1tgQIkejanZz2
-ZrUYrAqmVCY0M9IbwdR/GjqOC6oybtv8TyWf2TLHllpwrN9M
------END CERTIFICATE-----
-
 # Issuer: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com
 # Subject: CN=XRamp Global Certification Authority O=XRamp Security Services Inc OU=www.xrampsecurity.com
 # Label: "XRamp Global CA Root"
@@ -560,34 +461,6 @@ vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep
 +OkuE6N36B9K
 -----END CERTIFICATE-----
 
-# Issuer: CN=DST Root CA X3 O=Digital Signature Trust Co.
-# Subject: CN=DST Root CA X3 O=Digital Signature Trust Co.
-# Label: "DST Root CA X3"
-# Serial: 91299735575339953335919266965803778155
-# MD5 Fingerprint: 41:03:52:dc:0f:f7:50:1b:16:f0:02:8e:ba:6f:45:c5
-# SHA1 Fingerprint: da:c9:02:4f:54:d8:f6:df:94:93:5f:b1:73:26:38:ca:6a:d7:7c:13
-# SHA256 Fingerprint: 06:87:26:03:31:a7:24:03:d9:09:f1:05:e6:9b:cf:0d:32:e1:bd:24:93:ff:c6:d9:20:6d:11:bc:d6:77:07:39
------BEGIN CERTIFICATE-----
-MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/
-MSQwIgYDVQQKExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMT
-DkRTVCBSb290IENBIFgzMB4XDTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVow
-PzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QgQ28uMRcwFQYDVQQD
-Ew5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB
-AN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmTrE4O
-rz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEq
-OLl5CjH9UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9b
-xiqKqy69cK3FCxolkHRyxXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw
-7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40dutolucbY38EVAjqr2m7xPi71XAicPNaD
-aeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNV
-HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQMA0GCSqG
-SIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69
-ikugdB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXr
-AvHRAosZy5Q6XkjEGB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZz
-R8srzJmwN0jP41ZL9c8PDHIyh8bwRLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5
-JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubSfZGL+T0yjWW06XyxV3bqxbYo
-Ob8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ
------END CERTIFICATE-----
-
 # Issuer: CN=SwissSign Gold CA - G2 O=SwissSign AG
 # Subject: CN=SwissSign Gold CA - G2 O=SwissSign AG
 # Label: "SwissSign Gold CA - G2"
@@ -763,37 +636,6 @@ BA6+C4OmF4O5MBKgxTMVBbkN+8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IB
 ZQ==
 -----END CERTIFICATE-----
 
-# Issuer: CN=Network Solutions Certificate Authority O=Network Solutions L.L.C.
-# Subject: CN=Network Solutions Certificate Authority O=Network Solutions L.L.C.
-# Label: "Network Solutions Certificate Authority"
-# Serial: 116697915152937497490437556386812487904
-# MD5 Fingerprint: d3:f3:a6:16:c0:fa:6b:1d:59:b1:2d:96:4d:0e:11:2e
-# SHA1 Fingerprint: 74:f8:a3:c3:ef:e7:b3:90:06:4b:83:90:3c:21:64:60:20:e5:df:ce
-# SHA256 Fingerprint: 15:f0:ba:00:a3:ac:7a:f3:ac:88:4c:07:2b:10:11:a0:77:bd:77:c0:97:f4:01:64:b2:f8:59:8a:bd:83:86:0c
------BEGIN CERTIFICATE-----
-MIID5jCCAs6gAwIBAgIQV8szb8JcFuZHFhfjkDFo4DANBgkqhkiG9w0BAQUFADBi
-MQswCQYDVQQGEwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMu
-MTAwLgYDVQQDEydOZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3Jp
-dHkwHhcNMDYxMjAxMDAwMDAwWhcNMjkxMjMxMjM1OTU5WjBiMQswCQYDVQQGEwJV
-UzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMuMTAwLgYDVQQDEydO
-ZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0GCSqG
-SIb3DQEBAQUAA4IBDwAwggEKAoIBAQDkvH6SMG3G2I4rC7xGzuAnlt7e+foS0zwz
-c7MEL7xxjOWftiJgPl9dzgn/ggwbmlFQGiaJ3dVhXRncEg8tCqJDXRfQNJIg6nPP
-OCwGJgl6cvf6UDL4wpPTaaIjzkGxzOTVHzbRijr4jGPiFFlp7Q3Tf2vouAPlT2rl
-mGNpSAW+Lv8ztumXWWn4Zxmuk2GWRBXTcrA/vGp97Eh/jcOrqnErU2lBUzS1sLnF
-BgrEsEX1QV1uiUV7PTsmjHTC5dLRfbIR1PtYMiKagMnc/Qzpf14Dl847ABSHJ3A4
-qY5usyd2mFHgBeMhqxrVhSI8KbWaFsWAqPS7azCPL0YCorEMIuDTAgMBAAGjgZcw
-gZQwHQYDVR0OBBYEFCEwyfsA106Y2oeqKtCnLrFAMadMMA4GA1UdDwEB/wQEAwIB
-BjAPBgNVHRMBAf8EBTADAQH/MFIGA1UdHwRLMEkwR6BFoEOGQWh0dHA6Ly9jcmwu
-bmV0c29sc3NsLmNvbS9OZXR3b3JrU29sdXRpb25zQ2VydGlmaWNhdGVBdXRob3Jp
-dHkuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQC7rkvnt1frf6ott3NHhWrB5KUd5Oc8
-6fRZZXe1eltajSU24HqXLjjAV2CDmAaDn7l2em5Q4LqILPxFzBiwmZVRDuwduIj/
-h1AcgsLj4DKAv6ALR8jDMe+ZZzKATxcheQxpXN5eNK4CtSbqUN9/GGUsyfJj4akH
-/nxxH2szJGoeBfcFaMBqEssuXmHLrijTfsK0ZpEmXzwuJF/LWA/rKOyvEZbz3Htv
-wKeI8lN3s2Berq4o2jUsbzRF0ybh3uxbTydrFny9RAQYgrOJeRcQcT16ohZO9QHN
-pGxlaKFJdlxDydi8NmdspZS11My5vWo1ViHe2MPr+8ukYEywVaCge1ey
------END CERTIFICATE-----
-
 # Issuer: CN=COMODO ECC Certification Authority O=COMODO CA Limited
 # Subject: CN=COMODO ECC Certification Authority O=COMODO CA Limited
 # Label: "COMODO ECC Certification Authority"
@@ -848,36 +690,6 @@ t0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw
 WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg==
 -----END CERTIFICATE-----
 
-# Issuer: CN=Cybertrust Global Root O=Cybertrust, Inc
-# Subject: CN=Cybertrust Global Root O=Cybertrust, Inc
-# Label: "Cybertrust Global Root"
-# Serial: 4835703278459682877484360
-# MD5 Fingerprint: 72:e4:4a:87:e3:69:40:80:77:ea:bc:e3:f4:ff:f0:e1
-# SHA1 Fingerprint: 5f:43:e5:b1:bf:f8:78:8c:ac:1c:c7:ca:4a:9a:c6:22:2b:cc:34:c6
-# SHA256 Fingerprint: 96:0a:df:00:63:e9:63:56:75:0c:29:65:dd:0a:08:67:da:0b:9c:bd:6e:77:71:4a:ea:fb:23:49:ab:39:3d:a3
------BEGIN CERTIFICATE-----
-MIIDoTCCAomgAwIBAgILBAAAAAABD4WqLUgwDQYJKoZIhvcNAQEFBQAwOzEYMBYG
-A1UEChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2Jh
-bCBSb290MB4XDTA2MTIxNTA4MDAwMFoXDTIxMTIxNTA4MDAwMFowOzEYMBYGA1UE
-ChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2JhbCBS
-b290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA+Mi8vRRQZhP/8NN5
-7CPytxrHjoXxEnOmGaoQ25yiZXRadz5RfVb23CO21O1fWLE3TdVJDm71aofW0ozS
-J8bi/zafmGWgE07GKmSb1ZASzxQG9Dvj1Ci+6A74q05IlG2OlTEQXO2iLb3VOm2y
-HLtgwEZLAfVJrn5GitB0jaEMAs7u/OePuGtm839EAL9mJRQr3RAwHQeWP032a7iP
-t3sMpTjr3kfb1V05/Iin89cqdPHoWqI7n1C6poxFNcJQZZXcY4Lv3b93TZxiyWNz
-FtApD0mpSPCzqrdsxacwOUBdrsTiXSZT8M4cIwhhqJQZugRiQOwfOHB3EgZxpzAY
-XSUnpQIDAQABo4GlMIGiMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/
-MB0GA1UdDgQWBBS2CHsNesysIEyGVjJez6tuhS1wVzA/BgNVHR8EODA2MDSgMqAw
-hi5odHRwOi8vd3d3Mi5wdWJsaWMtdHJ1c3QuY29tL2NybC9jdC9jdHJvb3QuY3Js
-MB8GA1UdIwQYMBaAFLYIew16zKwgTIZWMl7Pq26FLXBXMA0GCSqGSIb3DQEBBQUA
-A4IBAQBW7wojoFROlZfJ+InaRcHUowAl9B8Tq7ejhVhpwjCt2BWKLePJzYFa+HMj
-Wqd8BfP9IjsO0QbE2zZMcwSO5bAi5MXzLqXZI+O4Tkogp24CJJ8iYGd7ix1yCcUx
-XOl5n4BHPa2hCwcUPUf/A2kaDAtE52Mlp3+yybh2hO0j9n0Hq0V+09+zv+mKts2o
-omcrUtW3ZfA5TGOgkXmTUg9U3YO7n9GPp1Nzw8v/MOx8BLjYRB+TX3EJIrduPuoc
-A06dGiBh+4E37F78CkWr1+cXVdCg6mCbpvbjjFspwgZgFJ0tl0ypkxWdYcQBX0jW
-WL1WMRJOEcgh4LMRkWXbtKaIOM5V
------END CERTIFICATE-----
-
 # Issuer: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority
 # Subject: O=Chunghwa Telecom Co., Ltd. OU=ePKI Root Certification Authority
 # Label: "ePKI Root Certification Authority"
@@ -947,67 +759,6 @@ i/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7NzTogVZ96edhBiIL5VaZVDADlN
 9u6wWk5JRFRYX0KD
 -----END CERTIFICATE-----
 
-# Issuer: CN=GeoTrust Primary Certification Authority - G2 O=GeoTrust Inc. OU=(c) 2007 GeoTrust Inc. - For authorized use only
-# Subject: CN=GeoTrust Primary Certification Authority - G2 O=GeoTrust Inc. OU=(c) 2007 GeoTrust Inc. - For authorized use only
-# Label: "GeoTrust Primary Certification Authority - G2"
-# Serial: 80682863203381065782177908751794619243
-# MD5 Fingerprint: 01:5e:d8:6b:bd:6f:3d:8e:a1:31:f8:12:e0:98:73:6a
-# SHA1 Fingerprint: 8d:17:84:d5:37:f3:03:7d:ec:70:fe:57:8b:51:9a:99:e6:10:d7:b0
-# SHA256 Fingerprint: 5e:db:7a:c4:3b:82:a0:6a:87:61:e8:d7:be:49:79:eb:f2:61:1f:7d:d7:9b:f9:1c:1c:6b:56:6a:21:9e:d7:66
------BEGIN CERTIFICATE-----
-MIICrjCCAjWgAwIBAgIQPLL0SAoA4v7rJDteYD7DazAKBggqhkjOPQQDAzCBmDEL
-MAkGA1UEBhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChj
-KSAyMDA3IEdlb1RydXN0IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2
-MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0
-eSAtIEcyMB4XDTA3MTEwNTAwMDAwMFoXDTM4MDExODIzNTk1OVowgZgxCzAJBgNV
-BAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykgMjAw
-NyBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNV
-BAMTLUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBH
-MjB2MBAGByqGSM49AgEGBSuBBAAiA2IABBWx6P0DFUPlrOuHNxFi79KDNlJ9RVcL
-So17VDs6bl8VAsBQps8lL33KSLjHUGMcKiEIfJo22Av+0SbFWDEwKCXzXV2juLal
-tJLtbCyf691DiaI8S0iRHVDsJt/WYC69IaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAO
-BgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBVfNVdRVfslsq0DafwBo/q+EVXVMAoG
-CCqGSM49BAMDA2cAMGQCMGSWWaboCd6LuvpaiIjwH5HTRqjySkwCY/tsXzjbLkGT
-qQ7mndwxHLKgpxgceeHHNgIwOlavmnRs9vuD4DPTCF+hnMJbn0bWtsuRBmOiBucz
-rD6ogRLQy7rQkgu2npaqBA+K
------END CERTIFICATE-----
-
-# Issuer: CN=VeriSign Universal Root Certification Authority O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2008 VeriSign, Inc. - For authorized use only
-# Subject: CN=VeriSign Universal Root Certification Authority O=VeriSign, Inc. OU=VeriSign Trust Network/(c) 2008 VeriSign, Inc. - For authorized use only
-# Label: "VeriSign Universal Root Certification Authority"
-# Serial: 85209574734084581917763752644031726877
-# MD5 Fingerprint: 8e:ad:b5:01:aa:4d:81:e4:8c:1d:d1:e1:14:00:95:19
-# SHA1 Fingerprint: 36:79:ca:35:66:87:72:30:4d:30:a5:fb:87:3b:0f:a7:7b:b7:0d:54
-# SHA256 Fingerprint: 23:99:56:11:27:a5:71:25:de:8c:ef:ea:61:0d:df:2f:a0:78:b5:c8:06:7f:4e:82:82:90:bf:b8:60:e8:4b:3c
------BEGIN CERTIFICATE-----
-MIIEuTCCA6GgAwIBAgIQQBrEZCGzEyEDDrvkEhrFHTANBgkqhkiG9w0BAQsFADCB
-vTELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQL
-ExZWZXJpU2lnbiBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwOCBWZXJp
-U2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVzZSBvbmx5MTgwNgYDVQQDEy9W
-ZXJpU2lnbiBVbml2ZXJzYWwgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAe
-Fw0wODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIG9MQswCQYDVQQGEwJVUzEX
-MBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0
-IE5ldHdvcmsxOjA4BgNVBAsTMShjKSAyMDA4IFZlcmlTaWduLCBJbmMuIC0gRm9y
-IGF1dGhvcml6ZWQgdXNlIG9ubHkxODA2BgNVBAMTL1ZlcmlTaWduIFVuaXZlcnNh
-bCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEF
-AAOCAQ8AMIIBCgKCAQEAx2E3XrEBNNti1xWb/1hajCMj1mCOkdeQmIN65lgZOIzF
-9uVkhbSicfvtvbnazU0AtMgtc6XHaXGVHzk8skQHnOgO+k1KxCHfKWGPMiJhgsWH
-H26MfF8WIFFE0XBPV+rjHOPMee5Y2A7Cs0WTwCznmhcrewA3ekEzeOEz4vMQGn+H
-LL729fdC4uW/h2KJXwBL38Xd5HVEMkE6HnFuacsLdUYI0crSK5XQz/u5QGtkjFdN
-/BMReYTtXlT2NJ8IAfMQJQYXStrxHXpma5hgZqTZ79IugvHw7wnqRMkVauIDbjPT
-rJ9VAMf2CGqUuV/c4DPxhGD5WycRtPwW8rtWaoAljQIDAQABo4GyMIGvMA8GA1Ud
-EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMG0GCCsGAQUFBwEMBGEwX6FdoFsw
-WTBXMFUWCWltYWdlL2dpZjAhMB8wBwYFKw4DAhoEFI/l0xqGrI2Oa8PPgGrUSBgs
-exkuMCUWI2h0dHA6Ly9sb2dvLnZlcmlzaWduLmNvbS92c2xvZ28uZ2lmMB0GA1Ud
-DgQWBBS2d/ppSEefUxLVwuoHMnYH0ZcHGTANBgkqhkiG9w0BAQsFAAOCAQEASvj4
-sAPmLGd75JR3Y8xuTPl9Dg3cyLk1uXBPY/ok+myDjEedO2Pzmvl2MpWRsXe8rJq+
-seQxIcaBlVZaDrHC1LGmWazxY8u4TB1ZkErvkBYoH1quEPuBUDgMbMzxPcP1Y+Oz
-4yHJJDnp/RVmRvQbEdBNc6N9Rvk97ahfYtTxP/jgdFcrGJ2BtMQo2pSXpXDrrB2+
-BxHw1dvd5Yzw1TKwg+ZX4o+/vqGqvz0dtdQ46tewXDpPaj+PwGZsY6rp2aQW9IHR
-lRQOfc2VNNnSj3BzgXucfr2YYdhFh5iQxeuGMMY1v/D/w1WIg0vvBZIGcfK4mJO3
-7M2CYfE45k+XmCpajQ==
------END CERTIFICATE-----
-
 # Issuer: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services)
 # Subject: CN=NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny O=NetLock Kft. OU=Tan\xfas\xedtv\xe1nykiad\xf3k (Certification Services)
 # Label: "NetLock Arany (Class Gold) F\u0151tan\xfas\xedtv\xe1ny"
@@ -1243,105 +994,6 @@ naM8THLCV8Sg1Mw4J87VBp6iSNnpn86CcDaTmjvfliHjWbcM2pE38P1ZWrOZyGls
 QyYBNWNgVYkDOnXYukrZVP/u3oDYLdE41V4tC5h9Pmzb/CaIxw==
 -----END CERTIFICATE-----
 
-# Issuer: CN=Chambers of Commerce Root - 2008 O=AC Camerfirma S.A.
-# Subject: CN=Chambers of Commerce Root - 2008 O=AC Camerfirma S.A.
-# Label: "Chambers of Commerce Root - 2008"
-# Serial: 11806822484801597146
-# MD5 Fingerprint: 5e:80:9e:84:5a:0e:65:0b:17:02:f3:55:18:2a:3e:d7
-# SHA1 Fingerprint: 78:6a:74:ac:76:ab:14:7f:9c:6a:30:50:ba:9e:a8:7e:fe:9a:ce:3c
-# SHA256 Fingerprint: 06:3e:4a:fa:c4:91:df:d3:32:f3:08:9b:85:42:e9:46:17:d8:93:d7:fe:94:4e:10:a7:93:7e:e2:9d:96:93:c0
------BEGIN CERTIFICATE-----
-MIIHTzCCBTegAwIBAgIJAKPaQn6ksa7aMA0GCSqGSIb3DQEBBQUAMIGuMQswCQYD
-VQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0
-IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3
-MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xKTAnBgNVBAMTIENoYW1iZXJz
-IG9mIENvbW1lcmNlIFJvb3QgLSAyMDA4MB4XDTA4MDgwMTEyMjk1MFoXDTM4MDcz
-MTEyMjk1MFowga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNlZSBj
-dXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29tL2FkZHJlc3MpMRIw
-EAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVyZmlybWEgUy5BLjEp
-MCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDgwggIiMA0G
-CSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCvAMtwNyuAWko6bHiUfaN/Gh/2NdW9
-28sNRHI+JrKQUrpjOyhYb6WzbZSm891kDFX29ufyIiKAXuFixrYp4YFs8r/lfTJq
-VKAyGVn+H4vXPWCGhSRv4xGzdz4gljUha7MI2XAuZPeEklPWDrCQiorjh40G072Q
-DuKZoRuGDtqaCrsLYVAGUvGef3bsyw/QHg3PmTA9HMRFEFis1tPo1+XqxQEHd9ZR
-5gN/ikilTWh1uem8nk4ZcfUyS5xtYBkL+8ydddy/Js2Pk3g5eXNeJQ7KXOt3EgfL
-ZEFHcpOrUMPrCXZkNNI5t3YRCQ12RcSprj1qr7V9ZS+UWBDsXHyvfuK2GNnQm05a
-Sd+pZgvMPMZ4fKecHePOjlO+Bd5gD2vlGts/4+EhySnB8esHnFIbAURRPHsl18Tl
-UlRdJQfKFiC4reRB7noI/plvg6aRArBsNlVq5331lubKgdaX8ZSD6e2wsWsSaR6s
-+12pxZjptFtYer49okQ6Y1nUCyXeG0+95QGezdIp1Z8XGQpvvwyQ0wlf2eOKNcx5
-Wk0ZN5K3xMGtr/R5JJqyAQuxr1yW84Ay+1w9mPGgP0revq+ULtlVmhduYJ1jbLhj
-ya6BXBg14JC7vjxPNyK5fuvPnnchpj04gftI2jE9K+OJ9dC1vX7gUMQSibMjmhAx
-hduub+84Mxh2EQIDAQABo4IBbDCCAWgwEgYDVR0TAQH/BAgwBgEB/wIBDDAdBgNV
-HQ4EFgQU+SSsD7K1+HnA+mCIG8TZTQKeFxkwgeMGA1UdIwSB2zCB2IAU+SSsD7K1
-+HnA+mCIG8TZTQKeFxmhgbSkgbEwga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpN
-YWRyaWQgKHNlZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29t
-L2FkZHJlc3MpMRIwEAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVy
-ZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAt
-IDIwMDiCCQCj2kJ+pLGu2jAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRV
-HSAAMCowKAYIKwYBBQUHAgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20w
-DQYJKoZIhvcNAQEFBQADggIBAJASryI1wqM58C7e6bXpeHxIvj99RZJe6dqxGfwW
-PJ+0W2aeaufDuV2I6A+tzyMP3iU6XsxPpcG1Lawk0lgH3qLPaYRgM+gQDROpI9CF
-5Y57pp49chNyM/WqfcZjHwj0/gF/JM8rLFQJ3uIrbZLGOU8W6jx+ekbURWpGqOt1
-glanq6B8aBMz9p0w8G8nOSQjKpD9kCk18pPfNKXG9/jvjA9iSnyu0/VU+I22mlaH
-FoI6M6taIgj3grrqLuBHmrS1RaMFO9ncLkVAO+rcf+g769HsJtg1pDDFOqxXnrN2
-pSB7+R5KBWIBpih1YJeSDW4+TTdDDZIVnBgizVGZoCkaPF+KMjNbMMeJL0eYD6MD
-xvbxrN8y8NmBGuScvfaAFPDRLLmF9dijscilIeUcE5fuDr3fKanvNFNb0+RqE4QG
-tjICxFKuItLcsiFCGtpA8CnJ7AoMXOLQusxI0zcKzBIKinmwPQN/aUv0NCB9szTq
-jktk9T79syNnFQ0EuPAtwQlRPLJsFfClI9eDdOTlLsn+mCdCxqvGnrDQWzilm1De
-fhiYtUU79nm06PcaewaD+9CL2rvHvRirCG88gGtAPxkZumWK5r7VXNM21+9AUiRg
-OGcEMeyP84LG3rlV8zsxkVrctQgVrXYlCg17LofiDKYGvCYQbTed7N14jHyAxfDZ
-d0jQ
------END CERTIFICATE-----
-
-# Issuer: CN=Global Chambersign Root - 2008 O=AC Camerfirma S.A.
-# Subject: CN=Global Chambersign Root - 2008 O=AC Camerfirma S.A.
-# Label: "Global Chambersign Root - 2008"
-# Serial: 14541511773111788494
-# MD5 Fingerprint: 9e:80:ff:78:01:0c:2e:c1:36:bd:fe:96:90:6e:08:f3
-# SHA1 Fingerprint: 4a:bd:ee:ec:95:0d:35:9c:89:ae:c7:52:a1:2c:5b:29:f6:d6:aa:0c
-# SHA256 Fingerprint: 13:63:35:43:93:34:a7:69:80:16:a0:d3:24:de:72:28:4e:07:9d:7b:52:20:bb:8f:bd:74:78:16:ee:be:ba:ca
------BEGIN CERTIFICATE-----
-MIIHSTCCBTGgAwIBAgIJAMnN0+nVfSPOMA0GCSqGSIb3DQEBBQUAMIGsMQswCQYD
-VQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0
-IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3
-MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAlBgNVBAMTHkdsb2JhbCBD
-aGFtYmVyc2lnbiBSb290IC0gMjAwODAeFw0wODA4MDExMjMxNDBaFw0zODA3MzEx
-MjMxNDBaMIGsMQswCQYDVQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUgY3Vy
-cmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAG
-A1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAl
-BgNVBAMTHkdsb2JhbCBDaGFtYmVyc2lnbiBSb290IC0gMjAwODCCAiIwDQYJKoZI
-hvcNAQEBBQADggIPADCCAgoCggIBAMDfVtPkOpt2RbQT2//BthmLN0EYlVJH6xed
-KYiONWwGMi5HYvNJBL99RDaxccy9Wglz1dmFRP+RVyXfXjaOcNFccUMd2drvXNL7
-G706tcuto8xEpw2uIRU/uXpbknXYpBI4iRmKt4DS4jJvVpyR1ogQC7N0ZJJ0YPP2
-zxhPYLIj0Mc7zmFLmY/CDNBAspjcDahOo7kKrmCgrUVSY7pmvWjg+b4aqIG7HkF4
-ddPB/gBVsIdU6CeQNR1MM62X/JcumIS/LMmjv9GYERTtY/jKmIhYF5ntRQOXfjyG
-HoiMvvKRhI9lNNgATH23MRdaKXoKGCQwoze1eqkBfSbW+Q6OWfH9GzO1KTsXO0G2
-Id3UwD2ln58fQ1DJu7xsepeY7s2MH/ucUa6LcL0nn3HAa6x9kGbo1106DbDVwo3V
-yJ2dwW3Q0L9R5OP4wzg2rtandeavhENdk5IMagfeOx2YItaswTXbo6Al/3K1dh3e
-beksZixShNBFks4c5eUzHdwHU1SjqoI7mjcv3N2gZOnm3b2u/GSFHTynyQbehP9r
-6GsaPMWis0L7iwk+XwhSx2LE1AVxv8Rk5Pihg+g+EpuoHtQ2TS9x9o0o9oOpE9Jh
-wZG7SMA0j0GMS0zbaRL/UJScIINZc+18ofLx/d33SdNDWKBWY8o9PeU1VlnpDsog
-zCtLkykPAgMBAAGjggFqMIIBZjASBgNVHRMBAf8ECDAGAQH/AgEMMB0GA1UdDgQW
-BBS5CcqcHtvTbDprru1U8VuTBjUuXjCB4QYDVR0jBIHZMIHWgBS5CcqcHtvTbDpr
-ru1U8VuTBjUuXqGBsqSBrzCBrDELMAkGA1UEBhMCRVUxQzBBBgNVBAcTOk1hZHJp
-ZCAoc2VlIGN1cnJlbnQgYWRkcmVzcyBhdCB3d3cuY2FtZXJmaXJtYS5jb20vYWRk
-cmVzcykxEjAQBgNVBAUTCUE4Mjc0MzI4NzEbMBkGA1UEChMSQUMgQ2FtZXJmaXJt
-YSBTLkEuMScwJQYDVQQDEx5HbG9iYWwgQ2hhbWJlcnNpZ24gUm9vdCAtIDIwMDiC
-CQDJzdPp1X0jzjAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCow
-KAYIKwYBBQUHAgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZI
-hvcNAQEFBQADggIBAICIf3DekijZBZRG/5BXqfEv3xoNa/p8DhxJJHkn2EaqbylZ
-UohwEurdPfWbU1Rv4WCiqAm57OtZfMY18dwY6fFn5a+6ReAJ3spED8IXDneRRXoz
-X1+WLGiLwUePmJs9wOzL9dWCkoQ10b42OFZyMVtHLaoXpGNR6woBrX/sdZ7LoR/x
-fxKxueRkf2fWIyr0uDldmOghp+G9PUIadJpwr2hsUF1Jz//7Dl3mLEfXgTpZALVz
-a2Mg9jFFCDkO9HB+QHBaP9BrQql0PSgvAm11cpUJjUhjxsYjV5KTXjXBjfkK9yyd
-Yhz2rXzdpjEetrHHfoUm+qRqtdpjMNHvkzeyZi99Bffnt0uYlDXA2TopwZ2yUDMd
-SqlapskD7+3056huirRXhOukP9DuqqqHW2Pok+JrqNS4cnhrG+055F3Lm6qH1U9O
-AP7Zap88MQ8oAgF9mOinsKJknnn4SPIVqczmyETrP3iZ8ntxPjzxmKfFGBI/5rso
-M0LpRQp8bfKGeS/Fghl9CYl8slR2iK7ewfPM4W7bMdaTrpmg7yVqc5iJWzouE4ge
-v8CSlDQb4ye3ix5vQv/n6TebUB0tovkC7stYWDpxvGjjqsGvHCgfotwjZT+B6q6Z
-09gwzxMNTxXJhLynSC34MCN32EZLeW32jO06f2ARePTpm67VVMB0gNELQp/B
------END CERTIFICATE-----
-
 # Issuer: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc.
 # Subject: CN=Go Daddy Root Certificate Authority - G2 O=GoDaddy.com, Inc.
 # Label: "Go Daddy Root Certificate Authority - G2"
@@ -1640,78 +1292,6 @@ t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6qtnRGEmyR7jTV7JqR50S+kDFy
 SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03
 -----END CERTIFICATE-----
 
-# Issuer: CN=EC-ACC O=Agencia Catalana de Certificacio (NIF Q-0801176-I) OU=Serveis Publics de Certificacio/Vegeu https://www.catcert.net/verarrel (c)03/Jerarquia Entitats de Certificacio Catalanes
-# Subject: CN=EC-ACC O=Agencia Catalana de Certificacio (NIF Q-0801176-I) OU=Serveis Publics de Certificacio/Vegeu https://www.catcert.net/verarrel (c)03/Jerarquia Entitats de Certificacio Catalanes
-# Label: "EC-ACC"
-# Serial: -23701579247955709139626555126524820479
-# MD5 Fingerprint: eb:f5:9d:29:0d:61:f9:42:1f:7c:c2:ba:6d:e3:15:09
-# SHA1 Fingerprint: 28:90:3a:63:5b:52:80:fa:e6:77:4c:0b:6d:a7:d6:ba:a6:4a:f2:e8
-# SHA256 Fingerprint: 88:49:7f:01:60:2f:31:54:24:6a:e2:8c:4d:5a:ef:10:f1:d8:7e:bb:76:62:6f:4a:e0:b7:f9:5b:a7:96:87:99
------BEGIN CERTIFICATE-----
-MIIFVjCCBD6gAwIBAgIQ7is969Qh3hSoYqwE893EATANBgkqhkiG9w0BAQUFADCB
-8zELMAkGA1UEBhMCRVMxOzA5BgNVBAoTMkFnZW5jaWEgQ2F0YWxhbmEgZGUgQ2Vy
-dGlmaWNhY2lvIChOSUYgUS0wODAxMTc2LUkpMSgwJgYDVQQLEx9TZXJ2ZWlzIFB1
-YmxpY3MgZGUgQ2VydGlmaWNhY2lvMTUwMwYDVQQLEyxWZWdldSBodHRwczovL3d3
-dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAoYykwMzE1MDMGA1UECxMsSmVyYXJxdWlh
-IEVudGl0YXRzIGRlIENlcnRpZmljYWNpbyBDYXRhbGFuZXMxDzANBgNVBAMTBkVD
-LUFDQzAeFw0wMzAxMDcyMzAwMDBaFw0zMTAxMDcyMjU5NTlaMIHzMQswCQYDVQQG
-EwJFUzE7MDkGA1UEChMyQWdlbmNpYSBDYXRhbGFuYSBkZSBDZXJ0aWZpY2FjaW8g
-KE5JRiBRLTA4MDExNzYtSSkxKDAmBgNVBAsTH1NlcnZlaXMgUHVibGljcyBkZSBD
-ZXJ0aWZpY2FjaW8xNTAzBgNVBAsTLFZlZ2V1IGh0dHBzOi8vd3d3LmNhdGNlcnQu
-bmV0L3ZlcmFycmVsIChjKTAzMTUwMwYDVQQLEyxKZXJhcnF1aWEgRW50aXRhdHMg
-ZGUgQ2VydGlmaWNhY2lvIENhdGFsYW5lczEPMA0GA1UEAxMGRUMtQUNDMIIBIjAN
-BgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsyLHT+KXQpWIR4NA9h0X84NzJB5R
-85iKw5K4/0CQBXCHYMkAqbWUZRkiFRfCQ2xmRJoNBD45b6VLeqpjt4pEndljkYRm
-4CgPukLjbo73FCeTae6RDqNfDrHrZqJyTxIThmV6PttPB/SnCWDaOkKZx7J/sxaV
-HMf5NLWUhdWZXqBIoH7nF2W4onW4HvPlQn2v7fOKSGRdghST2MDk/7NQcvJ29rNd
-QlB50JQ+awwAvthrDk4q7D7SzIKiGGUzE3eeml0aE9jD2z3Il3rucO2n5nzbcc8t
-lGLfbdb1OL4/pYUKGbio2Al1QnDE6u/LDsg0qBIimAy4E5S2S+zw0JDnJwIDAQAB
-o4HjMIHgMB0GA1UdEQQWMBSBEmVjX2FjY0BjYXRjZXJ0Lm5ldDAPBgNVHRMBAf8E
-BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUoMOLRKo3pUW/l4Ba0fF4
-opvpXY0wfwYDVR0gBHgwdjB0BgsrBgEEAfV4AQMBCjBlMCwGCCsGAQUFBwIBFiBo
-dHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbDA1BggrBgEFBQcCAjApGidW
-ZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAwDQYJKoZIhvcN
-AQEFBQADggEBAKBIW4IB9k1IuDlVNZyAelOZ1Vr/sXE7zDkJlF7W2u++AVtd0x7Y
-/X1PzaBB4DSTv8vihpw3kpBWHNzrKQXlxJ7HNd+KDM3FIUPpqojlNcAZQmNaAl6k
-SBg6hW/cnbw/nZzBh7h6YQjpdwt/cKt63dmXLGQehb+8dJahw3oS7AwaboMMPOhy
-Rp/7SNVel+axofjk70YllJyJ22k4vuxcDlbHZVHlUIiIv0LVKz3l+bqeLrPK9HOS
-Agu+TGbrIP65y7WZf+a2E/rKS03Z7lNGBjvGTq2TWoF+bCpLagVFjPIhpDGQh2xl
-nJ2lYJU6Un/10asIbvPuW/mIPX64b24D5EI=
------END CERTIFICATE-----
-
-# Issuer: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority
-# Subject: CN=Hellenic Academic and Research Institutions RootCA 2011 O=Hellenic Academic and Research Institutions Cert. Authority
-# Label: "Hellenic Academic and Research Institutions RootCA 2011"
-# Serial: 0
-# MD5 Fingerprint: 73:9f:4c:4b:73:5b:79:e9:fa:ba:1c:ef:6e:cb:d5:c9
-# SHA1 Fingerprint: fe:45:65:9b:79:03:5b:98:a1:61:b5:51:2e:ac:da:58:09:48:22:4d
-# SHA256 Fingerprint: bc:10:4f:15:a4:8b:e7:09:dc:a5:42:a7:e1:d4:b9:df:6f:05:45:27:e8:02:ea:a9:2d:59:54:44:25:8a:fe:71
------BEGIN CERTIFICATE-----
-MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1Ix
-RDBCBgNVBAoTO0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1
-dGlvbnMgQ2VydC4gQXV0aG9yaXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1p
-YyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIFJvb3RDQSAyMDExMB4XDTExMTIw
-NjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYTAkdSMUQwQgYDVQQK
-EztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25zIENl
-cnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl
-c2VhcmNoIEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEB
-BQADggEPADCCAQoCggEBAKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPz
-dYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJ
-fel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa71HFK9+WXesyHgLacEns
-bgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u8yBRQlqD
-75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSP
-FEDH3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNV
-HRMBAf8EBTADAQH/MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp
-5dgTBCPuQSUwRwYDVR0eBEAwPqA8MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQu
-b3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQub3JnMA0GCSqGSIb3DQEBBQUA
-A4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVtXdMiKahsog2p
-6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8
-TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7
-dIsXRSZMFpGD/md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8Acys
-Nnq/onN694/BtZqhFLKPM58N7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXI
-l7WdmplNsDz4SgCbZN2fOUvRJ9e4
------END CERTIFICATE-----
-
 # Issuer: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967
 # Subject: CN=Actalis Authentication Root CA O=Actalis S.p.A./03358520967
 # Label: "Actalis Authentication Root CA"
@@ -1753,35 +1333,6 @@ LysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9vwGYT7JZVEc+NHt4bVaT
 LnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg==
 -----END CERTIFICATE-----
 
-# Issuer: O=Trustis Limited OU=Trustis FPS Root CA
-# Subject: O=Trustis Limited OU=Trustis FPS Root CA
-# Label: "Trustis FPS Root CA"
-# Serial: 36053640375399034304724988975563710553
-# MD5 Fingerprint: 30:c9:e7:1e:6b:e6:14:eb:65:b2:16:69:20:31:67:4d
-# SHA1 Fingerprint: 3b:c0:38:0b:33:c3:f6:a6:0c:86:15:22:93:d9:df:f5:4b:81:c0:04
-# SHA256 Fingerprint: c1:b4:82:99:ab:a5:20:8f:e9:63:0a:ce:55:ca:68:a0:3e:da:5a:51:9c:88:02:a0:d3:a6:73:be:8f:8e:55:7d
------BEGIN CERTIFICATE-----
-MIIDZzCCAk+gAwIBAgIQGx+ttiD5JNM2a/fH8YygWTANBgkqhkiG9w0BAQUFADBF
-MQswCQYDVQQGEwJHQjEYMBYGA1UEChMPVHJ1c3RpcyBMaW1pdGVkMRwwGgYDVQQL
-ExNUcnVzdGlzIEZQUyBSb290IENBMB4XDTAzMTIyMzEyMTQwNloXDTI0MDEyMTEx
-MzY1NFowRTELMAkGA1UEBhMCR0IxGDAWBgNVBAoTD1RydXN0aXMgTGltaXRlZDEc
-MBoGA1UECxMTVHJ1c3RpcyBGUFMgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQAD
-ggEPADCCAQoCggEBAMVQe547NdDfxIzNjpvto8A2mfRC6qc+gIMPpqdZh8mQRUN+
-AOqGeSoDvT03mYlmt+WKVoaTnGhLaASMk5MCPjDSNzoiYYkchU59j9WvezX2fihH
-iTHcDnlkH5nSW7r+f2C/revnPDgpai/lkQtV/+xvWNUtyd5MZnGPDNcE2gfmHhjj
-vSkCqPoc4Vu5g6hBSLwacY3nYuUtsuvffM/bq1rKMfFMIvMFE/eC+XN5DL7XSxzA
-0RU8k0Fk0ea+IxciAIleH2ulrG6nS4zto3Lmr2NNL4XSFDWaLk6M6jKYKIahkQlB
-OrTh4/L68MkKokHdqeMDx4gVOxzUGpTXn2RZEm0CAwEAAaNTMFEwDwYDVR0TAQH/
-BAUwAwEB/zAfBgNVHSMEGDAWgBS6+nEleYtXQSUhhgtx67JkDoshZzAdBgNVHQ4E
-FgQUuvpxJXmLV0ElIYYLceuyZA6LIWcwDQYJKoZIhvcNAQEFBQADggEBAH5Y//01
-GX2cGE+esCu8jowU/yyg2kdbw++BLa8F6nRIW/M+TgfHbcWzk88iNVy2P3UnXwmW
-zaD+vkAMXBJV+JOCyinpXj9WV4s4NvdFGkwozZ5BuO1WTISkQMi4sKUraXAEasP4
-1BIy+Q7DsdwyhEQsb8tGD+pmQQ9P8Vilpg0ND2HepZ5dfWWhPBfnqFVO76DH7cZE
-f1T1o+CP8HxVIo8ptoGj4W1OLBuAZ+ytIJ8MYmHVl/9D7S3B2l0pKoU/rGXuhg8F
-jZBf3+6f9L/uHfuY5H+QK4R4EA5sSVPvFVtlRkpdr7r7OnIdzfYliB6XzCGcKQEN
-ZetX2fNXlrtIzYE=
------END CERTIFICATE-----
-
 # Issuer: CN=Buypass Class 2 Root CA O=Buypass AS-983163327
 # Subject: CN=Buypass Class 2 Root CA O=Buypass AS-983163327
 # Label: "Buypass Class 2 Root CA"
@@ -2600,27 +2151,6 @@ zzuqQhFkoJ2UOQIReVx7Hfpkue4WQrO/isIJxOzksU0CMQDpKmFHjFJKS04YcPbW
 RNZu9YO6bVi9JNlWSOrvxKJGgYhqOkbRqZtNyWHa0V1Xahg=
 -----END CERTIFICATE-----
 
-# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4
-# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4
-# Label: "GlobalSign ECC Root CA - R4"
-# Serial: 14367148294922964480859022125800977897474
-# MD5 Fingerprint: 20:f0:27:68:d1:7e:a0:9d:0e:e6:2a:ca:df:5c:89:8e
-# SHA1 Fingerprint: 69:69:56:2e:40:80:f4:24:a1:e7:19:9f:14:ba:f3:ee:58:ab:6a:bb
-# SHA256 Fingerprint: be:c9:49:11:c2:95:56:76:db:6c:0a:55:09:86:d7:6e:3b:a0:05:66:7c:44:2c:97:62:b4:fb:b7:73:de:22:8c
------BEGIN CERTIFICATE-----
-MIIB4TCCAYegAwIBAgIRKjikHJYKBN5CsiilC+g0mAIwCgYIKoZIzj0EAwIwUDEk
-MCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBDQSAtIFI0MRMwEQYDVQQKEwpH
-bG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWduMB4XDTEyMTExMzAwMDAwMFoX
-DTM4MDExOTAzMTQwN1owUDEkMCIGA1UECxMbR2xvYmFsU2lnbiBFQ0MgUm9vdCBD
-QSAtIFI0MRMwEQYDVQQKEwpHbG9iYWxTaWduMRMwEQYDVQQDEwpHbG9iYWxTaWdu
-MFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAEuMZ5049sJQ6fLjkZHAOkrprlOQcJ
-FspjsbmG+IpXwVfOQvpzofdlQv8ewQCybnMO/8ch5RikqtlxP6jUuc6MHaNCMEAw
-DgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFFSwe61F
-uOJAf/sKbvu+M8k8o4TVMAoGCCqGSM49BAMCA0gAMEUCIQDckqGgE6bPA7DmxCGX
-kPoUVy0D7O48027KqGx2vKLeuwIgJ6iFJzWbVsaj8kfSt24bAgAXqmemFZHe+pTs
-ewv4n4Q=
------END CERTIFICATE-----
-
 # Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5
 # Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R5
 # Label: "GlobalSign ECC Root CA - R5"
@@ -2643,86 +2173,6 @@ KoZIzj0EAwMDaAAwZQIxAOVpEslu28YxuglB4Zf4+/2a4n0Sye18ZNPLBSWLVtmg
 xwy8p2Fp8fc74SrL+SvzZpA3
 -----END CERTIFICATE-----
 
-# Issuer: CN=Staat der Nederlanden Root CA - G3 O=Staat der Nederlanden
-# Subject: CN=Staat der Nederlanden Root CA - G3 O=Staat der Nederlanden
-# Label: "Staat der Nederlanden Root CA - G3"
-# Serial: 10003001
-# MD5 Fingerprint: 0b:46:67:07:db:10:2f:19:8c:35:50:60:d1:0b:f4:37
-# SHA1 Fingerprint: d8:eb:6b:41:51:92:59:e0:f3:e7:85:00:c0:3d:b6:88:97:c9:ee:fc
-# SHA256 Fingerprint: 3c:4f:b0:b9:5a:b8:b3:00:32:f4:32:b8:6f:53:5f:e1:72:c1:85:d0:fd:39:86:58:37:cf:36:18:7f:a6:f4:28
------BEGIN CERTIFICATE-----
-MIIFdDCCA1ygAwIBAgIEAJiiOTANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJO
-TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFh
-dCBkZXIgTmVkZXJsYW5kZW4gUm9vdCBDQSAtIEczMB4XDTEzMTExNDExMjg0MloX
-DTI4MTExMzIzMDAwMFowWjELMAkGA1UEBhMCTkwxHjAcBgNVBAoMFVN0YWF0IGRl
-ciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5lZGVybGFuZGVuIFJv
-b3QgQ0EgLSBHMzCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAL4yolQP
-cPssXFnrbMSkUeiFKrPMSjTysF/zDsccPVMeiAho2G89rcKezIJnByeHaHE6n3WW
-IkYFsO2tx1ueKt6c/DrGlaf1F2cY5y9JCAxcz+bMNO14+1Cx3Gsy8KL+tjzk7FqX
-xz8ecAgwoNzFs21v0IJyEavSgWhZghe3eJJg+szeP4TrjTgzkApyI/o1zCZxMdFy
-KJLZWyNtZrVtB0LrpjPOktvA9mxjeM3KTj215VKb8b475lRgsGYeCasH/lSJEULR
-9yS6YHgamPfJEf0WwTUaVHXvQ9Plrk7O53vDxk5hUUurmkVLoR9BvUhTFXFkC4az
-5S6+zqQbwSmEorXLCCN2QyIkHxcE1G6cxvx/K2Ya7Irl1s9N9WMJtxU51nus6+N8
-6U78dULI7ViVDAZCopz35HCz33JvWjdAidiFpNfxC95DGdRKWCyMijmev4SH8RY7
-Ngzp07TKbBlBUgmhHbBqv4LvcFEhMtwFdozL92TkA1CvjJFnq8Xy7ljY3r735zHP
-bMk7ccHViLVlvMDoFxcHErVc0qsgk7TmgoNwNsXNo42ti+yjwUOH5kPiNL6VizXt
-BznaqB16nzaeErAMZRKQFWDZJkBE41ZgpRDUajz9QdwOWke275dhdU/Z/seyHdTt
-XUmzqWrLZoQT1Vyg3N9udwbRcXXIV2+vD3dbAgMBAAGjQjBAMA8GA1UdEwEB/wQF
-MAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRUrfrHkleuyjWcLhL75Lpd
-INyUVzANBgkqhkiG9w0BAQsFAAOCAgEAMJmdBTLIXg47mAE6iqTnB/d6+Oea31BD
-U5cqPco8R5gu4RV78ZLzYdqQJRZlwJ9UXQ4DO1t3ApyEtg2YXzTdO2PCwyiBwpwp
-LiniyMMB8jPqKqrMCQj3ZWfGzd/TtiunvczRDnBfuCPRy5FOCvTIeuXZYzbB1N/8
-Ipf3YF3qKS9Ysr1YvY2WTxB1v0h7PVGHoTx0IsL8B3+A3MSs/mrBcDCw6Y5p4ixp
-gZQJut3+TcCDjJRYwEYgr5wfAvg1VUkvRtTA8KCWAg8zxXHzniN9lLf9OtMJgwYh
-/WA9rjLA0u6NpvDntIJ8CsxwyXmA+P5M9zWEGYox+wrZ13+b8KKaa8MFSu1BYBQw
-0aoRQm7TIwIEC8Zl3d1Sd9qBa7Ko+gE4uZbqKmxnl4mUnrzhVNXkanjvSr0rmj1A
-fsbAddJu+2gw7OyLnflJNZoaLNmzlTnVHpL3prllL+U9bTpITAjc5CgSKL59NVzq
-4BZ+Extq1z7XnvwtdbLBFNUjA9tbbws+eC8N3jONFrdI54OagQ97wUNNVQQXOEpR
-1VmiiXTTn74eS9fGbbeIJG9gkaSChVtWQbzQRKtqE77RLFi3EjNYsjdj3BP1lB0/
-QFH1T/U67cjF68IeHRaVesd+QnGTbksVtzDfqu1XhUisHWrdOWnk4Xl4vs4Fv6EM
-94B7IWcnMFk=
------END CERTIFICATE-----
-
-# Issuer: CN=Staat der Nederlanden EV Root CA O=Staat der Nederlanden
-# Subject: CN=Staat der Nederlanden EV Root CA O=Staat der Nederlanden
-# Label: "Staat der Nederlanden EV Root CA"
-# Serial: 10000013
-# MD5 Fingerprint: fc:06:af:7b:e8:1a:f1:9a:b4:e8:d2:70:1f:c0:f5:ba
-# SHA1 Fingerprint: 76:e2:7e:c1:4f:db:82:c1:c0:a6:75:b5:05:be:3d:29:b4:ed:db:bb
-# SHA256 Fingerprint: 4d:24:91:41:4c:fe:95:67:46:ec:4c:ef:a6:cf:6f:72:e2:8a:13:29:43:2f:9d:8a:90:7a:c4:cb:5d:ad:c1:5a
------BEGIN CERTIFICATE-----
-MIIFcDCCA1igAwIBAgIEAJiWjTANBgkqhkiG9w0BAQsFADBYMQswCQYDVQQGEwJO
-TDEeMBwGA1UECgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSkwJwYDVQQDDCBTdGFh
-dCBkZXIgTmVkZXJsYW5kZW4gRVYgUm9vdCBDQTAeFw0xMDEyMDgxMTE5MjlaFw0y
-MjEyMDgxMTEwMjhaMFgxCzAJBgNVBAYTAk5MMR4wHAYDVQQKDBVTdGFhdCBkZXIg
-TmVkZXJsYW5kZW4xKTAnBgNVBAMMIFN0YWF0IGRlciBOZWRlcmxhbmRlbiBFViBS
-b290IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA48d+ifkkSzrS
-M4M1LGns3Amk41GoJSt5uAg94JG6hIXGhaTK5skuU6TJJB79VWZxXSzFYGgEt9nC
-UiY4iKTWO0Cmws0/zZiTs1QUWJZV1VD+hq2kY39ch/aO5ieSZxeSAgMs3NZmdO3d
-Z//BYY1jTw+bbRcwJu+r0h8QoPnFfxZpgQNH7R5ojXKhTbImxrpsX23Wr9GxE46p
-rfNeaXUmGD5BKyF/7otdBwadQ8QpCiv8Kj6GyzyDOvnJDdrFmeK8eEEzduG/L13l
-pJhQDBXd4Pqcfzho0LKmeqfRMb1+ilgnQ7O6M5HTp5gVXJrm0w912fxBmJc+qiXb
-j5IusHsMX/FjqTf5m3VpTCgmJdrV8hJwRVXj33NeN/UhbJCONVrJ0yPr08C+eKxC
-KFhmpUZtcALXEPlLVPxdhkqHz3/KRawRWrUgUY0viEeXOcDPusBCAUCZSCELa6fS
-/ZbV0b5GnUngC6agIk440ME8MLxwjyx1zNDFjFE7PZQIZCZhfbnDZY8UnCHQqv0X
-cgOPvZuM5l5Tnrmd74K74bzickFbIZTTRTeU0d8JOV3nI6qaHcptqAqGhYqCvkIH
-1vI4gnPah1vlPNOePqc7nvQDs/nxfRN0Av+7oeX6AHkcpmZBiFxgV6YuCcS6/ZrP
-px9Aw7vMWgpVSzs4dlG4Y4uElBbmVvMCAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB
-/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFP6rAJCYniT8qcwaivsnuL8wbqg7
-MA0GCSqGSIb3DQEBCwUAA4ICAQDPdyxuVr5Os7aEAJSrR8kN0nbHhp8dB9O2tLsI
-eK9p0gtJ3jPFrK3CiAJ9Brc1AsFgyb/E6JTe1NOpEyVa/m6irn0F3H3zbPB+po3u
-2dfOWBfoqSmuc0iH55vKbimhZF8ZE/euBhD/UcabTVUlT5OZEAFTdfETzsemQUHS
-v4ilf0X8rLiltTMMgsT7B/Zq5SWEXwbKwYY5EdtYzXc7LMJMD16a4/CrPmEbUCTC
-wPTxGfARKbalGAKb12NMcIxHowNDXLldRqANb/9Zjr7dn3LDWyvfjFvO5QxGbJKy
-CqNMVEIYFRIYvdr8unRu/8G2oGTYqV9Vrp9canaW2HNnh/tNf1zuacpzEPuKqf2e
-vTY4SUmH9A4U8OmHuD+nT3pajnnUk+S7aFKErGzp85hwVXIy+TSrK0m1zSBi5Dp6
-Z2Orltxtrpfs/J92VoguZs9btsmksNcFuuEnL5O7Jiqik7Ab846+HUCjuTaPPoIa
-Gl6I6lD4WeKDRikL40Rc4ZW2aZCaFG+XroHPaO+Zmr615+F/+PoTRxZMzG0IQOeL
-eG9QgkRQP2YGiqtDhFZKDyAthg710tvSeopLzaXoTvFeJiUBWSOgftL2fiFX1ye8
-FVdMpEbB4IMeDExNH08GGeL5qPQ6gqGyeUN51q1veieQA6TqJIc/2b3Z6fJfUEkc
-7uzXLg==
------END CERTIFICATE-----
-
 # Issuer: CN=IdenTrust Commercial Root CA 1 O=IdenTrust
 # Subject: CN=IdenTrust Commercial Root CA 1 O=IdenTrust
 # Label: "IdenTrust Commercial Root CA 1"
@@ -3330,116 +2780,6 @@ T8p+ck0LcIymSLumoRT2+1hEmRSuqguTaaApJUqlyyvdimYHFngVV3Eb7PVHhPOe
 MTd61X8kreS8/f3MboPoDKi3QWwH3b08hpcv0g==
 -----END CERTIFICATE-----
 
-# Issuer: CN=TrustCor RootCert CA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority
-# Subject: CN=TrustCor RootCert CA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority
-# Label: "TrustCor RootCert CA-1"
-# Serial: 15752444095811006489
-# MD5 Fingerprint: 6e:85:f1:dc:1a:00:d3:22:d5:b2:b2:ac:6b:37:05:45
-# SHA1 Fingerprint: ff:bd:cd:e7:82:c8:43:5e:3c:6f:26:86:5c:ca:a8:3a:45:5b:c3:0a
-# SHA256 Fingerprint: d4:0e:9c:86:cd:8f:e4:68:c1:77:69:59:f4:9e:a7:74:fa:54:86:84:b6:c4:06:f3:90:92:61:f4:dc:e2:57:5c
------BEGIN CERTIFICATE-----
-MIIEMDCCAxigAwIBAgIJANqb7HHzA7AZMA0GCSqGSIb3DQEBCwUAMIGkMQswCQYD
-VQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEk
-MCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U
-cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRydXN0Q29y
-IFJvb3RDZXJ0IENBLTEwHhcNMTYwMjA0MTIzMjE2WhcNMjkxMjMxMTcyMzE2WjCB
-pDELMAkGA1UEBhMCUEExDzANBgNVBAgMBlBhbmFtYTEUMBIGA1UEBwwLUGFuYW1h
-IENpdHkxJDAiBgNVBAoMG1RydXN0Q29yIFN5c3RlbXMgUy4gZGUgUi5MLjEnMCUG
-A1UECwweVHJ1c3RDb3IgQ2VydGlmaWNhdGUgQXV0aG9yaXR5MR8wHQYDVQQDDBZU
-cnVzdENvciBSb290Q2VydCBDQS0xMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB
-CgKCAQEAv463leLCJhJrMxnHQFgKq1mqjQCj/IDHUHuO1CAmujIS2CNUSSUQIpid
-RtLByZ5OGy4sDjjzGiVoHKZaBeYei0i/mJZ0PmnK6bV4pQa81QBeCQryJ3pS/C3V
-seq0iWEk8xoT26nPUu0MJLq5nux+AHT6k61sKZKuUbS701e/s/OojZz0JEsq1pme
-9J7+wH5COucLlVPat2gOkEz7cD+PSiyU8ybdY2mplNgQTsVHCJCZGxdNuWxu72CV
-EY4hgLW9oHPY0LJ3xEXqWib7ZnZ2+AYfYW0PVcWDtxBWcgYHpfOxGgMFZA6dWorW
-hnAbJN7+KIor0Gqw/Hqi3LJ5DotlDwIDAQABo2MwYTAdBgNVHQ4EFgQU7mtJPHo/
-DeOxCbeKyKsZn3MzUOcwHwYDVR0jBBgwFoAU7mtJPHo/DeOxCbeKyKsZn3MzUOcw
-DwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYwDQYJKoZIhvcNAQELBQAD
-ggEBACUY1JGPE+6PHh0RU9otRCkZoB5rMZ5NDp6tPVxBb5UrJKF5mDo4Nvu7Zp5I
-/5CQ7z3UuJu0h3U/IJvOcs+hVcFNZKIZBqEHMwwLKeXx6quj7LUKdJDHfXLy11yf
-ke+Ri7fc7Waiz45mO7yfOgLgJ90WmMCV1Aqk5IGadZQ1nJBfiDcGrVmVCrDRZ9MZ
-yonnMlo2HD6CqFqTvsbQZJG2z9m2GM/bftJlo6bEjhcxwft+dtvTheNYsnd6djts
-L1Ac59v2Z3kf9YKVmgenFK+P3CghZwnS1k1aHBkcjndcw5QkPTJrS37UeJSDvjdN
-zl/HHk484IkzlQsPpTLWPFp5LBk=
------END CERTIFICATE-----
-
-# Issuer: CN=TrustCor RootCert CA-2 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority
-# Subject: CN=TrustCor RootCert CA-2 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority
-# Label: "TrustCor RootCert CA-2"
-# Serial: 2711694510199101698
-# MD5 Fingerprint: a2:e1:f8:18:0b:ba:45:d5:c7:41:2a:bb:37:52:45:64
-# SHA1 Fingerprint: b8:be:6d:cb:56:f1:55:b9:63:d4:12:ca:4e:06:34:c7:94:b2:1c:c0
-# SHA256 Fingerprint: 07:53:e9:40:37:8c:1b:d5:e3:83:6e:39:5d:ae:a5:cb:83:9e:50:46:f1:bd:0e:ae:19:51:cf:10:fe:c7:c9:65
------BEGIN CERTIFICATE-----
-MIIGLzCCBBegAwIBAgIIJaHfyjPLWQIwDQYJKoZIhvcNAQELBQAwgaQxCzAJBgNV
-BAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQw
-IgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRy
-dXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0eTEfMB0GA1UEAwwWVHJ1c3RDb3Ig
-Um9vdENlcnQgQ0EtMjAeFw0xNjAyMDQxMjMyMjNaFw0zNDEyMzExNzI2MzlaMIGk
-MQswCQYDVQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEg
-Q2l0eTEkMCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYD
-VQQLDB5UcnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxHzAdBgNVBAMMFlRy
-dXN0Q29yIFJvb3RDZXJ0IENBLTIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIK
-AoICAQCnIG7CKqJiJJWQdsg4foDSq8GbZQWU9MEKENUCrO2fk8eHyLAnK0IMPQo+
-QVqedd2NyuCb7GgypGmSaIwLgQ5WoD4a3SwlFIIvl9NkRvRUqdw6VC0xK5mC8tkq
-1+9xALgxpL56JAfDQiDyitSSBBtlVkxs1Pu2YVpHI7TYabS3OtB0PAx1oYxOdqHp
-2yqlO/rOsP9+aij9JxzIsekp8VduZLTQwRVtDr4uDkbIXvRR/u8OYzo7cbrPb1nK
-DOObXUm4TOJXsZiKQlecdu/vvdFoqNL0Cbt3Nb4lggjEFixEIFapRBF37120Hape
-az6LMvYHL1cEksr1/p3C6eizjkxLAjHZ5DxIgif3GIJ2SDpxsROhOdUuxTTCHWKF
-3wP+TfSvPd9cW436cOGlfifHhi5qjxLGhF5DUVCcGZt45vz27Ud+ez1m7xMTiF88
-oWP7+ayHNZ/zgp6kPwqcMWmLmaSISo5uZk3vFsQPeSghYA2FFn3XVDjxklb9tTNM
-g9zXEJ9L/cb4Qr26fHMC4P99zVvh1Kxhe1fVSntb1IVYJ12/+CtgrKAmrhQhJ8Z3
-mjOAPF5GP/fDsaOGM8boXg25NSyqRsGFAnWAoOsk+xWq5Gd/bnc/9ASKL3x74xdh
-8N0JqSDIvgmk0H5Ew7IwSjiqqewYmgeCK9u4nBit2uBGF6zPXQIDAQABo2MwYTAd
-BgNVHQ4EFgQU2f4hQG6UnrybPZx9mCAZ5YwwYrIwHwYDVR0jBBgwFoAU2f4hQG6U
-nrybPZx9mCAZ5YwwYrIwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAYYw
-DQYJKoZIhvcNAQELBQADggIBAJ5Fngw7tu/hOsh80QA9z+LqBrWyOrsGS2h60COX
-dKcs8AjYeVrXWoSK2BKaG9l9XE1wxaX5q+WjiYndAfrs3fnpkpfbsEZC89NiqpX+
-MWcUaViQCqoL7jcjx1BRtPV+nuN79+TMQjItSQzL/0kMmx40/W5ulop5A7Zv2wnL
-/V9lFDfhOPXzYRZY5LVtDQsEGz9QLX+zx3oaFoBg+Iof6Rsqxvm6ARppv9JYx1RX
-CI/hOWB3S6xZhBqI8d3LT3jX5+EzLfzuQfogsL7L9ziUwOHQhQ+77Sxzq+3+knYa
-ZH9bDTMJBzN7Bj8RpFxwPIXAz+OQqIN3+tvmxYxoZxBnpVIt8MSZj3+/0WvitUfW
-2dCFmU2Umw9Lje4AWkcdEQOsQRivh7dvDDqPys/cA8GiCcjl/YBeyGBCARsaU1q7
-N6a3vLqE6R5sGtRk2tRD/pOLS/IseRYQ1JMLiI+h2IYURpFHmygk71dSTlxCnKr3
-Sewn6EAes6aJInKc9Q0ztFijMDvd1GpUk74aTfOTlPf8hAs/hCBcNANExdqtvArB
-As8e5ZTZ845b2EzwnexhF7sUMlQMAimTHpKG9n/v55IFDlndmQguLvqcAFLTxWYp
-5KeXRKQOKIETNcX2b2TmQcTVL8w0RSXPQQCWPUouwpaYT05KnJe32x+SMsj/D1Fu
-1uwJ
------END CERTIFICATE-----
-
-# Issuer: CN=TrustCor ECA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority
-# Subject: CN=TrustCor ECA-1 O=TrustCor Systems S. de R.L. OU=TrustCor Certificate Authority
-# Label: "TrustCor ECA-1"
-# Serial: 9548242946988625984
-# MD5 Fingerprint: 27:92:23:1d:0a:f5:40:7c:e9:e6:6b:9d:d8:f5:e7:6c
-# SHA1 Fingerprint: 58:d1:df:95:95:67:6b:63:c0:f0:5b:1c:17:4d:8b:84:0b:c8:78:bd
-# SHA256 Fingerprint: 5a:88:5d:b1:9c:01:d9:12:c5:75:93:88:93:8c:af:bb:df:03:1a:b2:d4:8e:91:ee:15:58:9b:42:97:1d:03:9c
------BEGIN CERTIFICATE-----
-MIIEIDCCAwigAwIBAgIJAISCLF8cYtBAMA0GCSqGSIb3DQEBCwUAMIGcMQswCQYD
-VQQGEwJQQTEPMA0GA1UECAwGUGFuYW1hMRQwEgYDVQQHDAtQYW5hbWEgQ2l0eTEk
-MCIGA1UECgwbVHJ1c3RDb3IgU3lzdGVtcyBTLiBkZSBSLkwuMScwJQYDVQQLDB5U
-cnVzdENvciBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkxFzAVBgNVBAMMDlRydXN0Q29y
-IEVDQS0xMB4XDTE2MDIwNDEyMzIzM1oXDTI5MTIzMTE3MjgwN1owgZwxCzAJBgNV
-BAYTAlBBMQ8wDQYDVQQIDAZQYW5hbWExFDASBgNVBAcMC1BhbmFtYSBDaXR5MSQw
-IgYDVQQKDBtUcnVzdENvciBTeXN0ZW1zIFMuIGRlIFIuTC4xJzAlBgNVBAsMHlRy
-dXN0Q29yIENlcnRpZmljYXRlIEF1dGhvcml0eTEXMBUGA1UEAwwOVHJ1c3RDb3Ig
-RUNBLTEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDPj+ARtZ+odnbb
-3w9U73NjKYKtR8aja+3+XzP4Q1HpGjORMRegdMTUpwHmspI+ap3tDvl0mEDTPwOA
-BoJA6LHip1GnHYMma6ve+heRK9jGrB6xnhkB1Zem6g23xFUfJ3zSCNV2HykVh0A5
-3ThFEXXQmqc04L/NyFIduUd+Dbi7xgz2c1cWWn5DkR9VOsZtRASqnKmcp0yJF4Ou
-owReUoCLHhIlERnXDH19MURB6tuvsBzvgdAsxZohmz3tQjtQJvLsznFhBmIhVE5/
-wZ0+fyCMgMsq2JdiyIMzkX2woloPV+g7zPIlstR8L+xNxqE6FXrntl019fZISjZF
-ZtS6mFjBAgMBAAGjYzBhMB0GA1UdDgQWBBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAf
-BgNVHSMEGDAWgBREnkj1zG1I1KBLf/5ZJC+Dl5mahjAPBgNVHRMBAf8EBTADAQH/
-MA4GA1UdDwEB/wQEAwIBhjANBgkqhkiG9w0BAQsFAAOCAQEABT41XBVwm8nHc2Fv
-civUwo/yQ10CzsSUuZQRg2dd4mdsdXa/uwyqNsatR5Nj3B5+1t4u/ukZMjgDfxT2
-AHMsWbEhBuH7rBiVDKP/mZb3Kyeb1STMHd3BOuCYRLDE5D53sXOpZCz2HAF8P11F
-hcCF5yWPldwX8zyfGm6wyuMdKulMY/okYWLW2n62HGz1Ah3UKt1VkOsqEUc8Ll50
-soIipX1TH0XsJ5F95yIW6MBoNtjG8U+ARDL54dHRHareqKucBK+tIA5kmE2la8BI
-WJZpTdwHjFGTot+fDz2LYLSCjaoITmJF4PkL0uDgPFveXHEnJcLmA4GLEFPjx1Wi
-tJ/X5g==
------END CERTIFICATE-----
-
 # Issuer: CN=SSL.com Root Certification Authority RSA O=SSL Corporation
 # Subject: CN=SSL.com Root Certification Authority RSA O=SSL Corporation
 # Label: "SSL.com Root Certification Authority RSA"
@@ -3635,126 +2975,6 @@ rYy0UGYwEAYJKwYBBAGCNxUBBAMCAQAwCgYIKoZIzj0EAwMDaAAwZQIwJsdpW9zV
 Mgj/mkkCtojeFK9dbJlxjRo/i9fgojaGHAeCOnZT/cKi7e97sIBPWA9LUzm9
 -----END CERTIFICATE-----
 
-# Issuer: CN=GTS Root R1 O=Google Trust Services LLC
-# Subject: CN=GTS Root R1 O=Google Trust Services LLC
-# Label: "GTS Root R1"
-# Serial: 146587175971765017618439757810265552097
-# MD5 Fingerprint: 82:1a:ef:d4:d2:4a:f2:9f:e2:3d:97:06:14:70:72:85
-# SHA1 Fingerprint: e1:c9:50:e6:ef:22:f8:4c:56:45:72:8b:92:20:60:d7:d5:a7:a3:e8
-# SHA256 Fingerprint: 2a:57:54:71:e3:13:40:bc:21:58:1c:bd:2c:f1:3e:15:84:63:20:3e:ce:94:bc:f9:d3:cc:19:6b:f0:9a:54:72
------BEGIN CERTIFICATE-----
-MIIFWjCCA0KgAwIBAgIQbkepxUtHDA3sM9CJuRz04TANBgkqhkiG9w0BAQwFADBH
-MQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExM
-QzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIy
-MDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNl
-cnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEB
-AQUAA4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaM
-f/vo27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vX
-mX7wCl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7
-zUjwTcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0P
-fyblqAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtc
-vfaHszVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4
-Zor8Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUsp
-zBmkMiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOO
-Rc92wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYW
-k70paDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+
-DVrNVjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgF
-lQIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV
-HQ4EFgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBADiW
-Cu49tJYeX++dnAsznyvgyv3SjgofQXSlfKqE1OXyHuY3UjKcC9FhHb8owbZEKTV1
-d5iyfNm9dKyKaOOpMQkpAWBz40d8U6iQSifvS9efk+eCNs6aaAyC58/UEBZvXw6Z
-XPYfcX3v73svfuo21pdwCxXu11xWajOl40k4DLh9+42FpLFZXvRq4d2h9mREruZR
-gyFmxhE+885H7pwoHyXa/6xmld01D1zvICxi/ZG6qcz8WpyTgYMpl0p8WnK0OdC3
-d8t5/Wk6kjftbjhlRn7pYL15iJdfOBL07q9bgsiG1eGZbYwE8na6SfZu6W0eX6Dv
-J4J2QPim01hcDyxC2kLGe4g0x8HYRZvBPsVhHdljUEn2NIVq4BjFbkerQUIpm/Zg
-DdIx02OYI5NaAIFItO/Nis3Jz5nu2Z6qNuFoS3FJFDYoOj0dzpqPJeaAcWErtXvM
-+SUWgeExX6GjfhaknBZqlxi9dnKlC54dNuYvoS++cJEPqOba+MSSQGwlfnuzCdyy
-F62ARPBopY+Udf90WuioAnwMCeKpSwughQtiue+hMZL77/ZRBIls6Kl0obsXs7X9
-SQ98POyDGCBDTtWTurQ0sR8WNh8M5mQ5Fkzc4P4dyKliPUDqysU0ArSuiYgzNdws
-E3PYJ/HQcu51OyLemGhmW/HGY0dVHLqlCFF1pkgl
------END CERTIFICATE-----
-
-# Issuer: CN=GTS Root R2 O=Google Trust Services LLC
-# Subject: CN=GTS Root R2 O=Google Trust Services LLC
-# Label: "GTS Root R2"
-# Serial: 146587176055767053814479386953112547951
-# MD5 Fingerprint: 44:ed:9a:0e:a4:09:3b:00:f2:ae:4c:a3:c6:61:b0:8b
-# SHA1 Fingerprint: d2:73:96:2a:2a:5e:39:9f:73:3f:e1:c7:1e:64:3f:03:38:34:fc:4d
-# SHA256 Fingerprint: c4:5d:7b:b0:8e:6d:67:e6:2e:42:35:11:0b:56:4e:5f:78:fd:92:ef:05:8c:84:0a:ea:4e:64:55:d7:58:5c:60
------BEGIN CERTIFICATE-----
-MIIFWjCCA0KgAwIBAgIQbkepxlqz5yDFMJo/aFLybzANBgkqhkiG9w0BAQwFADBH
-MQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExM
-QzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIy
-MDAwMDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNl
-cnZpY2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEB
-AQUAA4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3Lv
-CvptnfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3Kg
-GjSY6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9Bu
-XvAuMC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOd
-re7kRXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXu
-PuWgf9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1
-mKPV+3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K
-8YzodDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqj
-x5RWIr9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsR
-nTKaG73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0
-kzCqgc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9Ok
-twIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV
-HQ4EFgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBALZp
-8KZ3/p7uC4Gt4cCpx/k1HUCCq+YEtN/L9x0Pg/B+E02NjO7jMyLDOfxA325BS0JT
-vhaI8dI4XsRomRyYUpOM52jtG2pzegVATX9lO9ZY8c6DR2Dj/5epnGB3GFW1fgiT
-z9D2PGcDFWEJ+YF59exTpJ/JjwGLc8R3dtyDovUMSRqodt6Sm2T4syzFJ9MHwAiA
-pJiS4wGWAqoC7o87xdFtCjMwc3i5T1QWvwsHoaRc5svJXISPD+AVdyx+Jn7axEvb
-pxZ3B7DNdehyQtaVhJ2Gg/LkkM0JR9SLA3DaWsYDQvTtN6LwG1BUSw7YhN4ZKJmB
-R64JGz9I0cNv4rBgF/XuIwKl2gBbbZCr7qLpGzvpx0QnRY5rn/WkhLx3+WuXrD5R
-RaIRpsyF7gpo8j5QOHokYh4XIDdtak23CZvJ/KRY9bb7nE4Yu5UC56GtmwfuNmsk
-0jmGwZODUNKBRqhfYlcsu2xkiAhu7xNUX90txGdj08+JN7+dIPT7eoOboB6BAFDC
-5AwiWVIQ7UNWhwD4FFKnHYuTjKJNRn8nxnGbJN7k2oaLDX5rIMHAnuFl2GqjpuiF
-izoHCBy69Y9Vmhh1fuXsgWbRIXOhNUQLgD1bnF5vKheW0YMjiGZt5obicDIvUiLn
-yOd/xCxgXS/Dr55FBcOEArf9LAhST4Ldo/DUhgkC
------END CERTIFICATE-----
-
-# Issuer: CN=GTS Root R3 O=Google Trust Services LLC
-# Subject: CN=GTS Root R3 O=Google Trust Services LLC
-# Label: "GTS Root R3"
-# Serial: 146587176140553309517047991083707763997
-# MD5 Fingerprint: 1a:79:5b:6b:04:52:9c:5d:c7:74:33:1b:25:9a:f9:25
-# SHA1 Fingerprint: 30:d4:24:6f:07:ff:db:91:89:8a:0b:e9:49:66:11:eb:8c:5e:46:e5
-# SHA256 Fingerprint: 15:d5:b8:77:46:19:ea:7d:54:ce:1c:a6:d0:b0:c4:03:e0:37:a9:17:f1:31:e8:a0:4e:1e:6b:7a:71:ba:bc:e5
------BEGIN CERTIFICATE-----
-MIICDDCCAZGgAwIBAgIQbkepx2ypcyRAiQ8DVd2NHTAKBggqhkjOPQQDAzBHMQsw
-CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU
-MBIGA1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw
-MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp
-Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQA
-IgNiAAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout
-736GjOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2A
-DDL24CejQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud
-DgQWBBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEAgFuk
-fCPAlaUs3L6JbyO5o91lAFJekazInXJ0glMLfalAvWhgxeG4VDvBNhcl2MG9AjEA
-njWSdIUlUfUk7GRSJFClH9voy8l27OyCbvWFGFPouOOaKaqW04MjyaR7YbPMAuhd
------END CERTIFICATE-----
-
-# Issuer: CN=GTS Root R4 O=Google Trust Services LLC
-# Subject: CN=GTS Root R4 O=Google Trust Services LLC
-# Label: "GTS Root R4"
-# Serial: 146587176229350439916519468929765261721
-# MD5 Fingerprint: 5d:b6:6a:c4:60:17:24:6a:1a:99:a8:4b:ee:5e:b4:26
-# SHA1 Fingerprint: 2a:1d:60:27:d9:4a:b1:0a:1c:4d:91:5c:cd:33:a0:cb:3e:2d:54:cb
-# SHA256 Fingerprint: 71:cc:a5:39:1f:9e:79:4b:04:80:25:30:b3:63:e1:21:da:8a:30:43:bb:26:66:2f:ea:4d:ca:7f:c9:51:a4:bd
------BEGIN CERTIFICATE-----
-MIICCjCCAZGgAwIBAgIQbkepyIuUtui7OyrYorLBmTAKBggqhkjOPQQDAzBHMQsw
-CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU
-MBIGA1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw
-MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp
-Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQA
-IgNiAATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzu
-hXyiQHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/l
-xKvRHYqjQjBAMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud
-DgQWBBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNnADBkAjBqUFJ0
-CMRw3J5QdCHojXohw0+WbhXRIjVhLfoIN+4Zba3bssx9BzT1YBkstTTZbyACMANx
-sbqjYAuG7ZoIapVon+Kz4ZNkfF6Tpt95LY2F45TPI11xzPKwTdb+mciUqXWi4w==
------END CERTIFICATE-----
-
 # Issuer: CN=UCA Global G2 Root O=UniTrust
 # Subject: CN=UCA Global G2 Root O=UniTrust
 # Label: "UCA Global G2 Root"
@@ -4323,3 +3543,1047 @@ LBT/DShycpWbXgnbiUSYqqFJu3FS8r/2/yehNq+4tneI3TqkbZs0kNwUXTC/t+sX
 dh2ajcQGjTa3FPOdVGm3jjzVpG2Tgbet9r1ke8LJaDmgkpzNNIaRkPpkUZ3+/uul
 9XXeifdy
 -----END CERTIFICATE-----
+
+# Issuer: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres
+# Subject: CN=AC RAIZ FNMT-RCM SERVIDORES SEGUROS O=FNMT-RCM OU=Ceres
+# Label: "AC RAIZ FNMT-RCM SERVIDORES SEGUROS"
+# Serial: 131542671362353147877283741781055151509
+# MD5 Fingerprint: 19:36:9c:52:03:2f:d2:d1:bb:23:cc:dd:1e:12:55:bb
+# SHA1 Fingerprint: 62:ff:d9:9e:c0:65:0d:03:ce:75:93:d2:ed:3f:2d:32:c9:e3:e5:4a
+# SHA256 Fingerprint: 55:41:53:b1:3d:2c:f9:dd:b7:53:bf:be:1a:4e:0a:e0:8d:0a:a4:18:70:58:fe:60:a2:b8:62:b2:e4:b8:7b:cb
+-----BEGIN CERTIFICATE-----
+MIICbjCCAfOgAwIBAgIQYvYybOXE42hcG2LdnC6dlTAKBggqhkjOPQQDAzB4MQsw
+CQYDVQQGEwJFUzERMA8GA1UECgwIRk5NVC1SQ00xDjAMBgNVBAsMBUNlcmVzMRgw
+FgYDVQRhDA9WQVRFUy1RMjgyNjAwNEoxLDAqBgNVBAMMI0FDIFJBSVogRk5NVC1S
+Q00gU0VSVklET1JFUyBTRUdVUk9TMB4XDTE4MTIyMDA5MzczM1oXDTQzMTIyMDA5
+MzczM1oweDELMAkGA1UEBhMCRVMxETAPBgNVBAoMCEZOTVQtUkNNMQ4wDAYDVQQL
+DAVDZXJlczEYMBYGA1UEYQwPVkFURVMtUTI4MjYwMDRKMSwwKgYDVQQDDCNBQyBS
+QUlaIEZOTVQtUkNNIFNFUlZJRE9SRVMgU0VHVVJPUzB2MBAGByqGSM49AgEGBSuB
+BAAiA2IABPa6V1PIyqvfNkpSIeSX0oNnnvBlUdBeh8dHsVnyV0ebAAKTRBdp20LH
+sbI6GA60XYyzZl2hNPk2LEnb80b8s0RpRBNm/dfF/a82Tc4DTQdxz69qBdKiQ1oK
+Um8BA06Oi6NCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD
+VR0OBBYEFAG5L++/EYZg8k/QQW6rcx/n0m5JMAoGCCqGSM49BAMDA2kAMGYCMQCu
+SuMrQMN0EfKVrRYj3k4MGuZdpSRea0R7/DjiT8ucRRcRTBQnJlU5dUoDzBOQn5IC
+MQD6SmxgiHPz7riYYqnOK8LZiqZwMR2vsJRM60/G49HzYqc8/5MuB1xJAWdpEgJy
+v+c=
+-----END CERTIFICATE-----
+
+# Issuer: CN=GlobalSign Root R46 O=GlobalSign nv-sa
+# Subject: CN=GlobalSign Root R46 O=GlobalSign nv-sa
+# Label: "GlobalSign Root R46"
+# Serial: 1552617688466950547958867513931858518042577
+# MD5 Fingerprint: c4:14:30:e4:fa:66:43:94:2a:6a:1b:24:5f:19:d0:ef
+# SHA1 Fingerprint: 53:a2:b0:4b:ca:6b:d6:45:e6:39:8a:8e:c4:0d:d2:bf:77:c3:a2:90
+# SHA256 Fingerprint: 4f:a3:12:6d:8d:3a:11:d1:c4:85:5a:4f:80:7c:ba:d6:cf:91:9d:3a:5a:88:b0:3b:ea:2c:63:72:d9:3c:40:c9
+-----BEGIN CERTIFICATE-----
+MIIFWjCCA0KgAwIBAgISEdK7udcjGJ5AXwqdLdDfJWfRMA0GCSqGSIb3DQEBDAUA
+MEYxCzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYD
+VQQDExNHbG9iYWxTaWduIFJvb3QgUjQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMy
+MDAwMDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYt
+c2ExHDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBSNDYwggIiMA0GCSqGSIb3DQEB
+AQUAA4ICDwAwggIKAoICAQCsrHQy6LNl5brtQyYdpokNRbopiLKkHWPd08EsCVeJ
+OaFV6Wc0dwxu5FUdUiXSE2te4R2pt32JMl8Nnp8semNgQB+msLZ4j5lUlghYruQG
+vGIFAha/r6gjA7aUD7xubMLL1aa7DOn2wQL7Id5m3RerdELv8HQvJfTqa1VbkNud
+316HCkD7rRlr+/fKYIje2sGP1q7Vf9Q8g+7XFkyDRTNrJ9CG0Bwta/OrffGFqfUo
+0q3v84RLHIf8E6M6cqJaESvWJ3En7YEtbWaBkoe0G1h6zD8K+kZPTXhc+CtI4wSE
+y132tGqzZfxCnlEmIyDLPRT5ge1lFgBPGmSXZgjPjHvjK8Cd+RTyG/FWaha/LIWF
+zXg4mutCagI0GIMXTpRW+LaCtfOW3T3zvn8gdz57GSNrLNRyc0NXfeD412lPFzYE
++cCQYDdF3uYM2HSNrpyibXRdQr4G9dlkbgIQrImwTDsHTUB+JMWKmIJ5jqSngiCN
+I/onccnfxkF0oE32kRbcRoxfKWMxWXEM2G/CtjJ9++ZdU6Z+Ffy7dXxd7Pj2Fxzs
+x2sZy/N78CsHpdlseVR2bJ0cpm4O6XkMqCNqo98bMDGfsVR7/mrLZqrcZdCinkqa
+ByFrgY/bxFn63iLABJzjqls2k+g9vXqhnQt2sQvHnf3PmKgGwvgqo6GDoLclcqUC
+4wIDAQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNV
+HQ4EFgQUA1yrc4GHqMywptWU4jaWSf8FmSwwDQYJKoZIhvcNAQEMBQADggIBAHx4
+7PYCLLtbfpIrXTncvtgdokIzTfnvpCo7RGkerNlFo048p9gkUbJUHJNOxO97k4Vg
+JuoJSOD1u8fpaNK7ajFxzHmuEajwmf3lH7wvqMxX63bEIaZHU1VNaL8FpO7XJqti
+2kM3S+LGteWygxk6x9PbTZ4IevPuzz5i+6zoYMzRx6Fcg0XERczzF2sUyQQCPtIk
+pnnpHs6i58FZFZ8d4kuaPp92CC1r2LpXFNqD6v6MVenQTqnMdzGxRBF6XLE+0xRF
+FRhiJBPSy03OXIPBNvIQtQ6IbbjhVp+J3pZmOUdkLG5NrmJ7v2B0GbhWrJKsFjLt
+rWhV/pi60zTe9Mlhww6G9kuEYO4Ne7UyWHmRVSyBQ7N0H3qqJZ4d16GLuc1CLgSk
+ZoNNiTW2bKg2SnkheCLQQrzRQDGQob4Ez8pn7fXwgNNgyYMqIgXQBztSvwyeqiv5
+u+YfjyW6hY0XHgL+XVAEV8/+LbzvXMAaq7afJMbfc2hIkCwU9D9SGuTSyxTDYWnP
+4vkYxboznxSjBF25cfe1lNj2M8FawTSLfJvdkzrnE6JwYZ+vj+vYxXX4M2bUdGc6
+N3ec592kD3ZDZopD8p/7DEJ4Y9HiD2971KE9dJeFt0g5QdYg/NA6s/rob8SKunE3
+vouXsXgxT7PntgMTzlSdriVZzH81Xwj3QEUxeCp6
+-----END CERTIFICATE-----
+
+# Issuer: CN=GlobalSign Root E46 O=GlobalSign nv-sa
+# Subject: CN=GlobalSign Root E46 O=GlobalSign nv-sa
+# Label: "GlobalSign Root E46"
+# Serial: 1552617690338932563915843282459653771421763
+# MD5 Fingerprint: b5:b8:66:ed:de:08:83:e3:c9:e2:01:34:06:ac:51:6f
+# SHA1 Fingerprint: 39:b4:6c:d5:fe:80:06:eb:e2:2f:4a:bb:08:33:a0:af:db:b9:dd:84
+# SHA256 Fingerprint: cb:b9:c4:4d:84:b8:04:3e:10:50:ea:31:a6:9f:51:49:55:d7:bf:d2:e2:c6:b4:93:01:01:9a:d6:1d:9f:50:58
+-----BEGIN CERTIFICATE-----
+MIICCzCCAZGgAwIBAgISEdK7ujNu1LzmJGjFDYQdmOhDMAoGCCqGSM49BAMDMEYx
+CzAJBgNVBAYTAkJFMRkwFwYDVQQKExBHbG9iYWxTaWduIG52LXNhMRwwGgYDVQQD
+ExNHbG9iYWxTaWduIFJvb3QgRTQ2MB4XDTE5MDMyMDAwMDAwMFoXDTQ2MDMyMDAw
+MDAwMFowRjELMAkGA1UEBhMCQkUxGTAXBgNVBAoTEEdsb2JhbFNpZ24gbnYtc2Ex
+HDAaBgNVBAMTE0dsb2JhbFNpZ24gUm9vdCBFNDYwdjAQBgcqhkjOPQIBBgUrgQQA
+IgNiAAScDrHPt+ieUnd1NPqlRqetMhkytAepJ8qUuwzSChDH2omwlwxwEwkBjtjq
+R+q+soArzfwoDdusvKSGN+1wCAB16pMLey5SnCNoIwZD7JIvU4Tb+0cUB+hflGdd
+yXqBPCCjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1Ud
+DgQWBBQxCpCPtsad0kRLgLWi5h+xEk8blTAKBggqhkjOPQQDAwNoADBlAjEA31SQ
+7Zvvi5QCkxeCmb6zniz2C5GMn0oUsfZkvLtoURMMA/cVi4RguYv/Uo7njLwcAjA8
++RHUjE7AwWHCFUyqqx0LMV87HOIAl0Qx5v5zli/altP+CAezNIm8BZ/3Hobui3A=
+-----END CERTIFICATE-----
+
+# Issuer: CN=GLOBALTRUST 2020 O=e-commerce monitoring GmbH
+# Subject: CN=GLOBALTRUST 2020 O=e-commerce monitoring GmbH
+# Label: "GLOBALTRUST 2020"
+# Serial: 109160994242082918454945253
+# MD5 Fingerprint: 8a:c7:6f:cb:6d:e3:cc:a2:f1:7c:83:fa:0e:78:d7:e8
+# SHA1 Fingerprint: d0:67:c1:13:51:01:0c:aa:d0:c7:6a:65:37:31:16:26:4f:53:71:a2
+# SHA256 Fingerprint: 9a:29:6a:51:82:d1:d4:51:a2:e3:7f:43:9b:74:da:af:a2:67:52:33:29:f9:0f:9a:0d:20:07:c3:34:e2:3c:9a
+-----BEGIN CERTIFICATE-----
+MIIFgjCCA2qgAwIBAgILWku9WvtPilv6ZeUwDQYJKoZIhvcNAQELBQAwTTELMAkG
+A1UEBhMCQVQxIzAhBgNVBAoTGmUtY29tbWVyY2UgbW9uaXRvcmluZyBHbWJIMRkw
+FwYDVQQDExBHTE9CQUxUUlVTVCAyMDIwMB4XDTIwMDIxMDAwMDAwMFoXDTQwMDYx
+MDAwMDAwMFowTTELMAkGA1UEBhMCQVQxIzAhBgNVBAoTGmUtY29tbWVyY2UgbW9u
+aXRvcmluZyBHbWJIMRkwFwYDVQQDExBHTE9CQUxUUlVTVCAyMDIwMIICIjANBgkq
+hkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAri5WrRsc7/aVj6B3GyvTY4+ETUWiD59b
+RatZe1E0+eyLinjF3WuvvcTfk0Uev5E4C64OFudBc/jbu9G4UeDLgztzOG53ig9Z
+YybNpyrOVPu44sB8R85gfD+yc/LAGbaKkoc1DZAoouQVBGM+uq/ufF7MpotQsjj3
+QWPKzv9pj2gOlTblzLmMCcpL3TGQlsjMH/1WljTbjhzqLL6FLmPdqqmV0/0plRPw
+yJiT2S0WR5ARg6I6IqIoV6Lr/sCMKKCmfecqQjuCgGOlYx8ZzHyyZqjC0203b+J+
+BlHZRYQfEs4kUmSFC0iAToexIiIwquuuvuAC4EDosEKAA1GqtH6qRNdDYfOiaxaJ
+SaSjpCuKAsR49GiKweR6NrFvG5Ybd0mN1MkGco/PU+PcF4UgStyYJ9ORJitHHmkH
+r96i5OTUawuzXnzUJIBHKWk7buis/UDr2O1xcSvy6Fgd60GXIsUf1DnQJ4+H4xj0
+4KlGDfV0OoIu0G4skaMxXDtG6nsEEFZegB31pWXogvziB4xiRfUg3kZwhqG8k9Me
+dKZssCz3AwyIDMvUclOGvGBG85hqwvG/Q/lwIHfKN0F5VVJjjVsSn8VoxIidrPIw
+q7ejMZdnrY8XD2zHc+0klGvIg5rQmjdJBKuxFshsSUktq6HQjJLyQUp5ISXbY9e2
+nKd+Qmn7OmMCAwEAAaNjMGEwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC
+AQYwHQYDVR0OBBYEFNwuH9FhN3nkq9XVsxJxaD1qaJwiMB8GA1UdIwQYMBaAFNwu
+H9FhN3nkq9XVsxJxaD1qaJwiMA0GCSqGSIb3DQEBCwUAA4ICAQCR8EICaEDuw2jA
+VC/f7GLDw56KoDEoqoOOpFaWEhCGVrqXctJUMHytGdUdaG/7FELYjQ7ztdGl4wJC
+XtzoRlgHNQIw4Lx0SsFDKv/bGtCwr2zD/cuz9X9tAy5ZVp0tLTWMstZDFyySCstd
+6IwPS3BD0IL/qMy/pJTAvoe9iuOTe8aPmxadJ2W8esVCgmxcB9CpwYhgROmYhRZf
++I/KARDOJcP5YBugxZfD0yyIMaK9MOzQ0MAS8cE54+X1+NZK3TTN+2/BT+MAi1bi
+kvcoskJ3ciNnxz8RFbLEAwW+uxF7Cr+obuf/WEPPm2eggAe2HcqtbepBEX4tdJP7
+wry+UUTF72glJ4DjyKDUEuzZpTcdN3y0kcra1LGWge9oXHYQSa9+pTeAsRxSvTOB
+TI/53WXZFM2KJVj04sWDpQmQ1GwUY7VA3+vA/MRYfg0UFodUJ25W5HCEuGwyEn6C
+MUO+1918oa2u1qsgEu8KwxCMSZY13At1XrFP1U80DhEgB3VDRemjEdqso5nCtnkn
+4rnvyOL2NSl6dPrFf4IFYqYK6miyeUcGbvJXqBUzxvd4Sj1Ce2t+/vdG6tHrju+I
+aFvowdlxfv1k7/9nR4hYJS8+hge9+6jlgqispdNpQ80xiEmEU5LAsTkbOYMBMMTy
+qfrQA71yN2BWHzZ8vTmR9W0Nv3vXkg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz
+# Subject: CN=ANF Secure Server Root CA O=ANF Autoridad de Certificacion OU=ANF CA Raiz
+# Label: "ANF Secure Server Root CA"
+# Serial: 996390341000653745
+# MD5 Fingerprint: 26:a6:44:5a:d9:af:4e:2f:b2:1d:b6:65:b0:4e:e8:96
+# SHA1 Fingerprint: 5b:6e:68:d0:cc:15:b6:a0:5f:1e:c1:5f:ae:02:fc:6b:2f:5d:6f:74
+# SHA256 Fingerprint: fb:8f:ec:75:91:69:b9:10:6b:1e:51:16:44:c6:18:c5:13:04:37:3f:6c:06:43:08:8d:8b:ef:fd:1b:99:75:99
+-----BEGIN CERTIFICATE-----
+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
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority
+# Subject: CN=Certum EC-384 CA O=Asseco Data Systems S.A. OU=Certum Certification Authority
+# Label: "Certum EC-384 CA"
+# Serial: 160250656287871593594747141429395092468
+# MD5 Fingerprint: b6:65:b3:96:60:97:12:a1:ec:4e:e1:3d:a3:c6:c9:f1
+# SHA1 Fingerprint: f3:3e:78:3c:ac:df:f4:a2:cc:ac:67:55:69:56:d7:e5:16:3c:e1:ed
+# SHA256 Fingerprint: 6b:32:80:85:62:53:18:aa:50:d1:73:c9:8d:8b:da:09:d5:7e:27:41:3d:11:4c:f7:87:a0:f5:d0:6c:03:0c:f6
+-----BEGIN CERTIFICATE-----
+MIICZTCCAeugAwIBAgIQeI8nXIESUiClBNAt3bpz9DAKBggqhkjOPQQDAzB0MQsw
+CQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBTLkEuMScw
+JQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAXBgNVBAMT
+EENlcnR1bSBFQy0zODQgQ0EwHhcNMTgwMzI2MDcyNDU0WhcNNDMwMzI2MDcyNDU0
+WjB0MQswCQYDVQQGEwJQTDEhMB8GA1UEChMYQXNzZWNvIERhdGEgU3lzdGVtcyBT
+LkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkxGTAX
+BgNVBAMTEENlcnR1bSBFQy0zODQgQ0EwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAATE
+KI6rGFtqvm5kN2PkzeyrOvfMobgOgknXhimfoZTy42B4mIF4Bk3y7JoOV2CDn7Tm
+Fy8as10CW4kjPMIRBSqniBMY81CE1700LCeJVf/OTOffph8oxPBUw7l8t1Ot68Kj
+QjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFI0GZnQkdjrzife81r1HfS+8
+EF9LMA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNoADBlAjADVS2m5hjEfO/J
+UG7BJw+ch69u1RsIGL2SKcHvlJF40jocVYli5RsJHrpka/F2tNQCMQC0QoSZ/6vn
+nvuRlydd3LBbMHHOXjgaatkl5+r3YZJW+OraNsKHZZYuciUvf9/DE8k=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority
+# Subject: CN=Certum Trusted Root CA O=Asseco Data Systems S.A. OU=Certum Certification Authority
+# Label: "Certum Trusted Root CA"
+# Serial: 40870380103424195783807378461123655149
+# MD5 Fingerprint: 51:e1:c2:e7:fe:4c:84:af:59:0e:2f:f4:54:6f:ea:29
+# SHA1 Fingerprint: c8:83:44:c0:18:ae:9f:cc:f1:87:b7:8f:22:d1:c5:d7:45:84:ba:e5
+# SHA256 Fingerprint: fe:76:96:57:38:55:77:3e:37:a9:5e:7a:d4:d9:cc:96:c3:01:57:c1:5d:31:76:5b:a9:b1:57:04:e1:ae:78:fd
+-----BEGIN CERTIFICATE-----
+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
+-----END CERTIFICATE-----
+
+# Issuer: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique
+# Subject: CN=TunTrust Root CA O=Agence Nationale de Certification Electronique
+# Label: "TunTrust Root CA"
+# Serial: 108534058042236574382096126452369648152337120275
+# MD5 Fingerprint: 85:13:b9:90:5b:36:5c:b6:5e:b8:5a:f8:e0:31:57:b4
+# SHA1 Fingerprint: cf:e9:70:84:0f:e0:73:0f:9d:f6:0c:7f:2c:4b:ee:20:46:34:9c:bb
+# SHA256 Fingerprint: 2e:44:10:2a:b5:8c:b8:54:19:45:1c:8e:19:d9:ac:f3:66:2c:af:bc:61:4b:6a:53:96:0a:30:f7:d0:e2:eb:41
+-----BEGIN CERTIFICATE-----
+MIIFszCCA5ugAwIBAgIUEwLV4kBMkkaGFmddtLu7sms+/BMwDQYJKoZIhvcNAQEL
+BQAwYTELMAkGA1UEBhMCVE4xNzA1BgNVBAoMLkFnZW5jZSBOYXRpb25hbGUgZGUg
+Q2VydGlmaWNhdGlvbiBFbGVjdHJvbmlxdWUxGTAXBgNVBAMMEFR1blRydXN0IFJv
+b3QgQ0EwHhcNMTkwNDI2MDg1NzU2WhcNNDQwNDI2MDg1NzU2WjBhMQswCQYDVQQG
+EwJUTjE3MDUGA1UECgwuQWdlbmNlIE5hdGlvbmFsZSBkZSBDZXJ0aWZpY2F0aW9u
+IEVsZWN0cm9uaXF1ZTEZMBcGA1UEAwwQVHVuVHJ1c3QgUm9vdCBDQTCCAiIwDQYJ
+KoZIhvcNAQEBBQADggIPADCCAgoCggIBAMPN0/y9BFPdDCA61YguBUtB9YOCfvdZ
+n56eY+hz2vYGqU8ftPkLHzmMmiDQfgbU7DTZhrx1W4eI8NLZ1KMKsmwb60ksPqxd
+2JQDoOw05TDENX37Jk0bbjBU2PWARZw5rZzJJQRNmpA+TkBuimvNKWfGzC3gdOgF
+VwpIUPp6Q9p+7FuaDmJ2/uqdHYVy7BG7NegfJ7/Boce7SBbdVtfMTqDhuazb1YMZ
+GoXRlJfXyqNlC/M4+QKu3fZnz8k/9YosRxqZbwUN/dAdgjH8KcwAWJeRTIAAHDOF
+li/LQcKLEITDCSSJH7UP2dl3RxiSlGBcx5kDPP73lad9UKGAwqmDrViWVSHbhlnU
+r8a83YFuB9tgYv7sEG7aaAH0gxupPqJbI9dkxt/con3YS7qC0lH4Zr8GRuR5KiY2
+eY8fTpkdso8MDhz/yV3A/ZAQprE38806JG60hZC/gLkMjNWb1sjxVj8agIl6qeIb
+MlEsPvLfe/ZdeikZjuXIvTZxi11Mwh0/rViizz1wTaZQmCXcI/m4WEEIcb9PuISg
+jwBUFfyRbVinljvrS5YnzWuioYasDXxU5mZMZl+QviGaAkYt5IPCgLnPSz7ofzwB
+7I9ezX/SKEIBlYrilz0QIX32nRzFNKHsLA4KUiwSVXAkPcvCFDVDXSdOvsC9qnyW
+5/yeYa1E0wCXAgMBAAGjYzBhMB0GA1UdDgQWBBQGmpsfU33x9aTI04Y+oXNZtPdE
+ITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFAaamx9TffH1pMjThj6hc1m0
+90QhMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAqgVutt0Vyb+z
+xiD2BkewhpMl0425yAA/l/VSJ4hxyXT968pk21vvHl26v9Hr7lxpuhbI87mP0zYu
+QEkHDVneixCwSQXi/5E/S7fdAo74gShczNxtr18UnH1YeA32gAm56Q6XKRm4t+v4
+FstVEuTGfbvE7Pi1HE4+Z7/FXxttbUcoqgRYYdZ2vyJ/0Adqp2RT8JeNnYA/u8EH
+22Wv5psymsNUk8QcCMNE+3tjEUPRahphanltkE8pjkcFwRJpadbGNjHh/PqAulxP
+xOu3Mqz4dWEX1xAZufHSCe96Qp1bWgvUxpVOKs7/B9dPfhgGiPEZtdmYu65xxBzn
+dFlY7wyJz4sfdZMaBBSSSFCp61cpABbjNhzI+L/wM9VBD8TMPN3pM0MBkRArHtG5
+Xc0yGYuPjCB31yLEQtyEFpslbei0VXF/sHyz03FJuc9SpAQ/3D2gu68zngowYI7b
+nV2UqL1g52KAdoGDDIzMMEZJ4gzSqK/rYXHv5yJiqfdcZGyfFoxnNidF9Ql7v/YQ
+CvGwjVRDjAS6oz/v4jXH+XTgbzRB0L9zZVcg+ZtnemZoJE6AZb0QmQZZ8mWvuMZH
+u/2QeItBcy6vVR/cO5JyboTT0GFMDcx2V+IthSIVNg3rAZ3r2OvEhJn7wAzMMujj
+d9qDRIueVSjAi1jTkD5OGwDxFa2DK5o=
+-----END CERTIFICATE-----
+
+# Issuer: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA
+# Subject: CN=HARICA TLS RSA Root CA 2021 O=Hellenic Academic and Research Institutions CA
+# Label: "HARICA TLS RSA Root CA 2021"
+# Serial: 76817823531813593706434026085292783742
+# MD5 Fingerprint: 65:47:9b:58:86:dd:2c:f0:fc:a2:84:1f:1e:96:c4:91
+# SHA1 Fingerprint: 02:2d:05:82:fa:88:ce:14:0c:06:79:de:7f:14:10:e9:45:d7:a5:6d
+# SHA256 Fingerprint: d9:5d:0e:8e:da:79:52:5b:f9:be:b1:1b:14:d2:10:0d:32:94:98:5f:0c:62:d9:fa:bd:9c:d9:99:ec:cb:7b:1d
+-----BEGIN CERTIFICATE-----
+MIIFpDCCA4ygAwIBAgIQOcqTHO9D88aOk8f0ZIk4fjANBgkqhkiG9w0BAQsFADBs
+MQswCQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJl
+c2VhcmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBSU0Eg
+Um9vdCBDQSAyMDIxMB4XDTIxMDIxOTEwNTUzOFoXDTQ1MDIxMzEwNTUzN1owbDEL
+MAkGA1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNl
+YXJjaCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgUlNBIFJv
+b3QgQ0EgMjAyMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAIvC569l
+mwVnlskNJLnQDmT8zuIkGCyEf3dRywQRNrhe7Wlxp57kJQmXZ8FHws+RFjZiPTgE
+4VGC/6zStGndLuwRo0Xua2s7TL+MjaQenRG56Tj5eg4MmOIjHdFOY9TnuEFE+2uv
+a9of08WRiFukiZLRgeaMOVig1mlDqa2YUlhu2wr7a89o+uOkXjpFc5gH6l8Cct4M
+pbOfrqkdtx2z/IpZ525yZa31MJQjB/OCFks1mJxTuy/K5FrZx40d/JiZ+yykgmvw
+Kh+OC19xXFyuQnspiYHLA6OZyoieC0AJQTPb5lh6/a6ZcMBaD9YThnEvdmn8kN3b
+LW7R8pv1GmuebxWMevBLKKAiOIAkbDakO/IwkfN4E8/BPzWr8R0RI7VDIp4BkrcY
+AuUR0YLbFQDMYTfBKnya4dC6s1BG7oKsnTH4+yPiAwBIcKMJJnkVU2DzOFytOOqB
+AGMUuTNe3QvboEUHGjMJ+E20pwKmafTCWQWIZYVWrkvL4N48fS0ayOn7H6NhStYq
+E613TBoYm5EPWNgGVMWX+Ko/IIqmhaZ39qb8HOLubpQzKoNQhArlT4b4UEV4AIHr
+W2jjJo3Me1xR9BQsQL4aYB16cmEdH2MtiKrOokWQCPxrvrNQKlr9qEgYRtaQQJKQ
+CoReaDH46+0N0x3GfZkYVVYnZS6NRcUk7M7jAgMBAAGjQjBAMA8GA1UdEwEB/wQF
+MAMBAf8wHQYDVR0OBBYEFApII6ZgpJIKM+qTW8VX6iVNvRLuMA4GA1UdDwEB/wQE
+AwIBhjANBgkqhkiG9w0BAQsFAAOCAgEAPpBIqm5iFSVmewzVjIuJndftTgfvnNAU
+X15QvWiWkKQUEapobQk1OUAJ2vQJLDSle1mESSmXdMgHHkdt8s4cUCbjnj1AUz/3
+f5Z2EMVGpdAgS1D0NTsY9FVqQRtHBmg8uwkIYtlfVUKqrFOFrJVWNlar5AWMxaja
+H6NpvVMPxP/cyuN+8kyIhkdGGvMA9YCRotxDQpSbIPDRzbLrLFPCU3hKTwSUQZqP
+JzLB5UkZv/HywouoCjkxKLR9YjYsTewfM7Z+d21+UPCfDtcRj88YxeMn/ibvBZ3P
+zzfF0HvaO7AWhAw6k9a+F9sPPg4ZeAnHqQJyIkv3N3a6dcSFA1pj1bF1BcK5vZSt
+jBWZp5N99sXzqnTPBIWUmAD04vnKJGW/4GKvyMX6ssmeVkjaef2WdhW+o45WxLM0
+/L5H9MG0qPzVMIho7suuyWPEdr6sOBjhXlzPrjoiUevRi7PzKzMHVIf6tLITe7pT
+BGIBnfHAT+7hOtSLIBD6Alfm78ELt5BGnBkpjNxvoEppaZS3JGWg/6w/zgH7IS79
+aPib8qXPMThcFarmlwDB31qlpzmq6YR/PFGoOtmUW4y/Twhx5duoXNTSpv4Ao8YW
+xw/ogM4cKGR0GQjTQuPOAF1/sdwTsOEFy9EgqoZ0njnnkf3/W9b3raYvAwtt41dU
+63ZTGI0RmLo=
+-----END CERTIFICATE-----
+
+# Issuer: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA
+# Subject: CN=HARICA TLS ECC Root CA 2021 O=Hellenic Academic and Research Institutions CA
+# Label: "HARICA TLS ECC Root CA 2021"
+# Serial: 137515985548005187474074462014555733966
+# MD5 Fingerprint: ae:f7:4c:e5:66:35:d1:b7:9b:8c:22:93:74:d3:4b:b0
+# SHA1 Fingerprint: bc:b0:c1:9d:e9:98:92:70:19:38:57:e9:8d:a7:b4:5d:6e:ee:01:48
+# SHA256 Fingerprint: 3f:99:cc:47:4a:cf:ce:4d:fe:d5:87:94:66:5e:47:8d:15:47:73:9f:2e:78:0f:1b:b4:ca:9b:13:30:97:d4:01
+-----BEGIN CERTIFICATE-----
+MIICVDCCAdugAwIBAgIQZ3SdjXfYO2rbIvT/WeK/zjAKBggqhkjOPQQDAzBsMQsw
+CQYDVQQGEwJHUjE3MDUGA1UECgwuSGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2Vh
+cmNoIEluc3RpdHV0aW9ucyBDQTEkMCIGA1UEAwwbSEFSSUNBIFRMUyBFQ0MgUm9v
+dCBDQSAyMDIxMB4XDTIxMDIxOTExMDExMFoXDTQ1MDIxMzExMDEwOVowbDELMAkG
+A1UEBhMCR1IxNzA1BgNVBAoMLkhlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJj
+aCBJbnN0aXR1dGlvbnMgQ0ExJDAiBgNVBAMMG0hBUklDQSBUTFMgRUNDIFJvb3Qg
+Q0EgMjAyMTB2MBAGByqGSM49AgEGBSuBBAAiA2IABDgI/rGgltJ6rK9JOtDA4MM7
+KKrxcm1lAEeIhPyaJmuqS7psBAqIXhfyVYf8MLA04jRYVxqEU+kw2anylnTDUR9Y
+STHMmE5gEYd103KUkE+bECUqqHgtvpBBWJAVcqeht6NCMEAwDwYDVR0TAQH/BAUw
+AwEB/zAdBgNVHQ4EFgQUyRtTgRL+BNUW0aq8mm+3oJUZbsowDgYDVR0PAQH/BAQD
+AgGGMAoGCCqGSM49BAMDA2cAMGQCMBHervjcToiwqfAircJRQO9gcS3ujwLEXQNw
+SaSS6sUUiHCm0w2wqsosQJz76YJumgIwK0eaB8bRwoF8yguWGEEbo/QwCZ61IygN
+nxS2PFOiTAZpffpskcYqSUXm7LcT4Tps
+-----END CERTIFICATE-----
+
+# Issuer: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068
+# Subject: CN=Autoridad de Certificacion Firmaprofesional CIF A62634068
+# Label: "Autoridad de Certificacion Firmaprofesional CIF A62634068"
+# Serial: 1977337328857672817
+# MD5 Fingerprint: 4e:6e:9b:54:4c:ca:b7:fa:48:e4:90:b1:15:4b:1c:a3
+# SHA1 Fingerprint: 0b:be:c2:27:22:49:cb:39:aa:db:35:5c:53:e3:8c:ae:78:ff:b6:fe
+# SHA256 Fingerprint: 57:de:05:83:ef:d2:b2:6e:03:61:da:99:da:9d:f4:64:8d:ef:7e:e8:44:1c:3b:72:8a:fa:9b:cd:e0:f9:b2:6a
+-----BEGIN CERTIFICATE-----
+MIIGFDCCA/ygAwIBAgIIG3Dp0v+ubHEwDQYJKoZIhvcNAQELBQAwUTELMAkGA1UE
+BhMCRVMxQjBABgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1h
+cHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODAeFw0xNDA5MjMxNTIyMDdaFw0zNjA1
+MDUxNTIyMDdaMFExCzAJBgNVBAYTAkVTMUIwQAYDVQQDDDlBdXRvcmlkYWQgZGUg
+Q2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBBNjI2MzQwNjgwggIi
+MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDDUtd9
+thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQM
+cas9UX4PB99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefG
+L9ItWY16Ck6WaVICqjaY7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15i
+NA9wBj4gGFrO93IbJWyTdBSTo3OxDqqHECNZXyAFGUftaI6SEspd/NYrspI8IM/h
+X68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyIplD9amML9ZMWGxmPsu2b
+m8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctXMbScyJCy
+Z/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirja
+EbsXLZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/T
+KI8xWVvTyQKmtFLKbpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF
+6NkBiDkal4ZkQdU7hwxu+g/GvUgUvzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVh
+OSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMB0GA1UdDgQWBBRlzeurNR4APn7VdMAc
+tHNHDhpkLzASBgNVHRMBAf8ECDAGAQH/AgEBMIGmBgNVHSAEgZ4wgZswgZgGBFUd
+IAAwgY8wLwYIKwYBBQUHAgEWI2h0dHA6Ly93d3cuZmlybWFwcm9mZXNpb25hbC5j
+b20vY3BzMFwGCCsGAQUFBwICMFAeTgBQAGEAcwBlAG8AIABkAGUAIABsAGEAIABC
+AG8AbgBhAG4AbwB2AGEAIAA0ADcAIABCAGEAcgBjAGUAbABvAG4AYQAgADAAOAAw
+ADEANzAOBgNVHQ8BAf8EBAMCAQYwDQYJKoZIhvcNAQELBQADggIBAHSHKAIrdx9m
+iWTtj3QuRhy7qPj4Cx2Dtjqn6EWKB7fgPiDL4QjbEwj4KKE1soCzC1HA01aajTNF
+Sa9J8OA9B3pFE1r/yJfY0xgsfZb43aJlQ3CTkBW6kN/oGbDbLIpgD7dvlAceHabJ
+hfa9NPhAeGIQcDq+fUs5gakQ1JZBu/hfHAsdCPKxsIl68veg4MSPi3i1O1ilI45P
+Vf42O+AMt8oqMEEgtIDNrvx2ZnOorm7hfNoD6JQg5iKj0B+QXSBTFCZX2lSX3xZE
+EAEeiGaPcjiT3SC3NL7X8e5jjkd5KAb881lFJWAiMxujX6i6KtoaPc1A6ozuBRWV
+1aUsIC+nmCjuRfzxuIgALI9C2lHVnOUTaHFFQ4ueCyE8S1wF3BqfmI7avSKecs2t
+CsvMo2ebKHTEm9caPARYpoKdrcd7b/+Alun4jWq9GJAd/0kakFI3ky88Al2CdgtR
+5xbHV/g4+afNmyJU72OwFW1TZQNKXkqgsqeOSQBZONXH9IBk9W6VULgRfhVwOEqw
+f9DEMnDAGf/JOC0ULGb0QkTmVXYbgBVX/8Cnp6o5qtjTcNAuuuuUavpfNIbnYrX9
+ivAwhZTJryQCL2/W3Wf+47BVTwSYT6RBVuKT0Gro1vP7ZeDOdcQxWQzugsgMYDNK
+GbqEZycPvEJdvSRUDewdcAZfpLz6IHxV
+-----END CERTIFICATE-----
+
+# Issuer: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd.
+# Subject: CN=vTrus ECC Root CA O=iTrusChina Co.,Ltd.
+# Label: "vTrus ECC Root CA"
+# Serial: 630369271402956006249506845124680065938238527194
+# MD5 Fingerprint: de:4b:c1:f5:52:8c:9b:43:e1:3e:8f:55:54:17:8d:85
+# SHA1 Fingerprint: f6:9c:db:b0:fc:f6:02:13:b6:52:32:a6:a3:91:3f:16:70:da:c3:e1
+# SHA256 Fingerprint: 30:fb:ba:2c:32:23:8e:2a:98:54:7a:f9:79:31:e5:50:42:8b:9b:3f:1c:8e:eb:66:33:dc:fa:86:c5:b2:7d:d3
+-----BEGIN CERTIFICATE-----
+MIICDzCCAZWgAwIBAgIUbmq8WapTvpg5Z6LSa6Q75m0c1towCgYIKoZIzj0EAwMw
+RzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4xGjAY
+BgNVBAMTEXZUcnVzIEVDQyBSb290IENBMB4XDTE4MDczMTA3MjY0NFoXDTQzMDcz
+MTA3MjY0NFowRzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28u
+LEx0ZC4xGjAYBgNVBAMTEXZUcnVzIEVDQyBSb290IENBMHYwEAYHKoZIzj0CAQYF
+K4EEACIDYgAEZVBKrox5lkqqHAjDo6LN/llWQXf9JpRCux3NCNtzslt188+cToL0
+v/hhJoVs1oVbcnDS/dtitN9Ti72xRFhiQgnH+n9bEOf+QP3A2MMrMudwpremIFUd
+e4BdS49nTPEQo0IwQDAdBgNVHQ4EFgQUmDnNvtiyjPeyq+GtJK97fKHbH88wDwYD
+VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwCgYIKoZIzj0EAwMDaAAwZQIw
+V53dVvHH4+m4SVBrm2nDb+zDfSXkV5UTQJtS0zvzQBm8JsctBp61ezaf9SXUY2sA
+AjEA6dPGnlaaKsyh2j/IZivTWJwghfqrkYpwcBE4YGQLYgmRWAD5Tfs0aNoJrSEG
+GJTO
+-----END CERTIFICATE-----
+
+# Issuer: CN=vTrus Root CA O=iTrusChina Co.,Ltd.
+# Subject: CN=vTrus Root CA O=iTrusChina Co.,Ltd.
+# Label: "vTrus Root CA"
+# Serial: 387574501246983434957692974888460947164905180485
+# MD5 Fingerprint: b8:c9:37:df:fa:6b:31:84:64:c5:ea:11:6a:1b:75:fc
+# SHA1 Fingerprint: 84:1a:69:fb:f5:cd:1a:25:34:13:3d:e3:f8:fc:b8:99:d0:c9:14:b7
+# SHA256 Fingerprint: 8a:71:de:65:59:33:6f:42:6c:26:e5:38:80:d0:0d:88:a1:8d:a4:c6:a9:1f:0d:cb:61:94:e2:06:c5:c9:63:87
+-----BEGIN CERTIFICATE-----
+MIIFVjCCAz6gAwIBAgIUQ+NxE9izWRRdt86M/TX9b7wFjUUwDQYJKoZIhvcNAQEL
+BQAwQzELMAkGA1UEBhMCQ04xHDAaBgNVBAoTE2lUcnVzQ2hpbmEgQ28uLEx0ZC4x
+FjAUBgNVBAMTDXZUcnVzIFJvb3QgQ0EwHhcNMTgwNzMxMDcyNDA1WhcNNDMwNzMx
+MDcyNDA1WjBDMQswCQYDVQQGEwJDTjEcMBoGA1UEChMTaVRydXNDaGluYSBDby4s
+THRkLjEWMBQGA1UEAxMNdlRydXMgUm9vdCBDQTCCAiIwDQYJKoZIhvcNAQEBBQAD
+ggIPADCCAgoCggIBAL1VfGHTuB0EYgWgrmy3cLRB6ksDXhA/kFocizuwZotsSKYc
+IrrVQJLuM7IjWcmOvFjai57QGfIvWcaMY1q6n6MLsLOaXLoRuBLpDLvPbmyAhykU
+AyyNJJrIZIO1aqwTLDPxn9wsYTwaP3BVm60AUn/PBLn+NvqcwBauYv6WTEN+VRS+
+GrPSbcKvdmaVayqwlHeFXgQPYh1jdfdr58tbmnDsPmcF8P4HCIDPKNsFxhQnL4Z9
+8Cfe/+Z+M0jnCx5Y0ScrUw5XSmXX+6KAYPxMvDVTAWqXcoKv8R1w6Jz1717CbMdH
+flqUhSZNO7rrTOiwCcJlwp2dCZtOtZcFrPUGoPc2BX70kLJrxLT5ZOrpGgrIDajt
+J8nU57O5q4IikCc9Kuh8kO+8T/3iCiSn3mUkpF3qwHYw03dQ+A0Em5Q2AXPKBlim
+0zvc+gRGE1WKyURHuFE5Gi7oNOJ5y1lKCn+8pu8fA2dqWSslYpPZUxlmPCdiKYZN
+pGvu/9ROutW04o5IWgAZCfEF2c6Rsffr6TlP9m8EQ5pV9T4FFL2/s1m02I4zhKOQ
+UqqzApVg+QxMaPnu1RcN+HFXtSXkKe5lXa/R7jwXC1pDxaWG6iSe4gUH3DRCEpHW
+OXSuTEGC2/KmSNGzm/MzqvOmwMVO9fSddmPmAsYiS8GVP1BkLFTltvA8Kc9XAgMB
+AAGjQjBAMB0GA1UdDgQWBBRUYnBj8XWEQ1iO0RYgscasGrz2iTAPBgNVHRMBAf8E
+BTADAQH/MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAKbqSSaet
+8PFww+SX8J+pJdVrnjT+5hpk9jprUrIQeBqfTNqK2uwcN1LgQkv7bHbKJAs5EhWd
+nxEt/Hlk3ODg9d3gV8mlsnZwUKT+twpw1aA08XXXTUm6EdGz2OyC/+sOxL9kLX1j
+bhd47F18iMjrjld22VkE+rxSH0Ws8HqA7Oxvdq6R2xCOBNyS36D25q5J08FsEhvM
+Kar5CKXiNxTKsbhm7xqC5PD48acWabfbqWE8n/Uxy+QARsIvdLGx14HuqCaVvIiv
+TDUHKgLKeBRtRytAVunLKmChZwOgzoy8sHJnxDHO2zTlJQNgJXtxmOTAGytfdELS
+S8VZCAeHvsXDf+eW2eHcKJfWjwXj9ZtOyh1QRwVTsMo554WgicEFOwE30z9J4nfr
+I8iIZjs9OXYhRvHsXyO466JmdXTBQPfYaJqT4i2pLr0cox7IdMakLXogqzu4sEb9
+b91fUlV1YvCXoHzXOP0l382gmxDPi7g4Xl7FtKYCNqEeXxzP4padKar9mK5S4fNB
+UvupLnKWnyfjqnN9+BojZns7q2WwMgFLFT49ok8MKzWixtlnEjUwzXYuFrOZnk1P
+Ti07NEPhmg4NpGaXutIcSkwsKouLgU9xGqndXHt7CMUADTdA43x7VF8vhV929ven
+sBxXVsFy6K2ir40zSbofitzmdHxghm+Hl3s=
+-----END CERTIFICATE-----
+
+# Issuer: CN=ISRG Root X2 O=Internet Security Research Group
+# Subject: CN=ISRG Root X2 O=Internet Security Research Group
+# Label: "ISRG Root X2"
+# Serial: 87493402998870891108772069816698636114
+# MD5 Fingerprint: d3:9e:c4:1e:23:3c:a6:df:cf:a3:7e:6d:e0:14:e6:e5
+# SHA1 Fingerprint: bd:b1:b9:3c:d5:97:8d:45:c6:26:14:55:f8:db:95:c7:5a:d1:53:af
+# SHA256 Fingerprint: 69:72:9b:8e:15:a8:6e:fc:17:7a:57:af:b7:17:1d:fc:64:ad:d2:8c:2f:ca:8c:f1:50:7e:34:45:3c:cb:14:70
+-----BEGIN CERTIFICATE-----
+MIICGzCCAaGgAwIBAgIQQdKd0XLq7qeAwSxs6S+HUjAKBggqhkjOPQQDAzBPMQsw
+CQYDVQQGEwJVUzEpMCcGA1UEChMgSW50ZXJuZXQgU2VjdXJpdHkgUmVzZWFyY2gg
+R3JvdXAxFTATBgNVBAMTDElTUkcgUm9vdCBYMjAeFw0yMDA5MDQwMDAwMDBaFw00
+MDA5MTcxNjAwMDBaME8xCzAJBgNVBAYTAlVTMSkwJwYDVQQKEyBJbnRlcm5ldCBT
+ZWN1cml0eSBSZXNlYXJjaCBHcm91cDEVMBMGA1UEAxMMSVNSRyBSb290IFgyMHYw
+EAYHKoZIzj0CAQYFK4EEACIDYgAEzZvVn4CDCuwJSvMWSj5cz3es3mcFDR0HttwW
++1qLFNvicWDEukWVEYmO6gbf9yoWHKS5xcUy4APgHoIYOIvXRdgKam7mAHf7AlF9
+ItgKbppbd9/w+kHsOdx1ymgHDB/qo0IwQDAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0T
+AQH/BAUwAwEB/zAdBgNVHQ4EFgQUfEKWrt5LSDv6kviejM9ti6lyN5UwCgYIKoZI
+zj0EAwMDaAAwZQIwe3lORlCEwkSHRhtFcP9Ymd70/aTSVaYgLXTWNLxBo1BfASdW
+tL4ndQavEi51mI38AjEAi/V3bNTIZargCyzuFJ0nN6T5U6VR5CmD1/iQMVtCnwr1
+/q4AaOeMSQ+2b1tbFfLn
+-----END CERTIFICATE-----
+
+# Issuer: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd.
+# Subject: CN=HiPKI Root CA - G1 O=Chunghwa Telecom Co., Ltd.
+# Label: "HiPKI Root CA - G1"
+# Serial: 60966262342023497858655262305426234976
+# MD5 Fingerprint: 69:45:df:16:65:4b:e8:68:9a:8f:76:5f:ff:80:9e:d3
+# SHA1 Fingerprint: 6a:92:e4:a8:ee:1b:ec:96:45:37:e3:29:57:49:cd:96:e3:e5:d2:60
+# SHA256 Fingerprint: f0:15:ce:3c:c2:39:bf:ef:06:4b:e9:f1:d2:c4:17:e1:a0:26:4a:0a:94:be:1f:0c:8d:12:18:64:eb:69:49:cc
+-----BEGIN CERTIFICATE-----
+MIIFajCCA1KgAwIBAgIQLd2szmKXlKFD6LDNdmpeYDANBgkqhkiG9w0BAQsFADBP
+MQswCQYDVQQGEwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0
+ZC4xGzAZBgNVBAMMEkhpUEtJIFJvb3QgQ0EgLSBHMTAeFw0xOTAyMjIwOTQ2MDRa
+Fw0zNzEyMzExNTU5NTlaME8xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3
+YSBUZWxlY29tIENvLiwgTHRkLjEbMBkGA1UEAwwSSGlQS0kgUm9vdCBDQSAtIEcx
+MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA9B5/UnMyDHPkvRN0o9Qw
+qNCuS9i233VHZvR85zkEHmpwINJaR3JnVfSl6J3VHiGh8Ge6zCFovkRTv4354twv
+Vcg3Px+kwJyz5HdcoEb+d/oaoDjq7Zpy3iu9lFc6uux55199QmQ5eiY29yTw1S+6
+lZgRZq2XNdZ1AYDgr/SEYYwNHl98h5ZeQa/rh+r4XfEuiAU+TCK72h8q3VJGZDnz
+Qs7ZngyzsHeXZJzA9KMuH5UHsBffMNsAGJZMoYFL3QRtU6M9/Aes1MU3guvklQgZ
+KILSQjqj2FPseYlgSGDIcpJQ3AOPgz+yQlda22rpEZfdhSi8MEyr48KxRURHH+CK
+FgeW0iEPU8DtqX7UTuybCeyvQqww1r/REEXgphaypcXTT3OUM3ECoWqj1jOXTyFj
+HluP2cFeRXF3D4FdXyGarYPM+l7WjSNfGz1BryB1ZlpK9p/7qxj3ccC2HTHsOyDr
+y+K49a6SsvfhhEvyovKTmiKe0xRvNlS9H15ZFblzqMF8b3ti6RZsR1pl8w4Rm0bZ
+/W3c1pzAtH2lsN0/Vm+h+fbkEkj9Bn8SV7apI09bA8PgcSojt/ewsTu8mL3WmKgM
+a/aOEmem8rJY5AIJEzypuxC00jBF8ez3ABHfZfjcK0NVvxaXxA/VLGGEqnKG/uY6
+fsI/fe78LxQ+5oXdUG+3Se0CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNV
+HQ4EFgQU8ncX+l6o/vY9cdVouslGDDjYr7AwDgYDVR0PAQH/BAQDAgGGMA0GCSqG
+SIb3DQEBCwUAA4ICAQBQUfB13HAE4/+qddRxosuej6ip0691x1TPOhwEmSKsxBHi
+7zNKpiMdDg1H2DfHb680f0+BazVP6XKlMeJ45/dOlBhbQH3PayFUhuaVevvGyuqc
+SE5XCV0vrPSltJczWNWseanMX/mF+lLFjfiRFOs6DRfQUsJ748JzjkZ4Bjgs6Fza
+ZsT0pPBWGTMpWmWSBUdGSquEwx4noR8RkpkndZMPvDY7l1ePJlsMu5wP1G4wB9Tc
+XzZoZjmDlicmisjEOf6aIW/Vcobpf2Lll07QJNBAsNB1CI69aO4I1258EHBGG3zg
+iLKecoaZAeO/n0kZtCW+VmWuF2PlHt/o/0elv+EmBYTksMCv5wiZqAxeJoBF1Pho
+L5aPruJKHJwWDBNvOIf2u8g0X5IDUXlwpt/L9ZlNec1OvFefQ05rLisY+GpzjLrF
+Ne85akEez3GoorKGB1s6yeHvP2UEgEcyRHCVTjFnanRbEEV16rCf0OY1/k6fi8wr
+kkVbbiVghUbN0aqwdmaTd5a+g744tiROJgvM7XpWGuDpWsZkrUx6AEhEL7lAuxM+
+vhV4nYWBSipX3tUZQ9rbyltHhoMLP7YNdnhzeSJesYAfz77RP1YQmCuVh6EfnWQU
+YDksswBVLuT1sw5XxJFBAJw/6KXf6vb/yPCtbVKoF6ubYfwSUTXkJf2vqmqGOQ==
+-----END CERTIFICATE-----
+
+# Issuer: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4
+# Subject: CN=GlobalSign O=GlobalSign OU=GlobalSign ECC Root CA - R4
+# Label: "GlobalSign ECC Root CA - R4"
+# Serial: 159662223612894884239637590694
+# MD5 Fingerprint: 26:29:f8:6d:e1:88:bf:a2:65:7f:aa:c4:cd:0f:7f:fc
+# SHA1 Fingerprint: 6b:a0:b0:98:e1:71:ef:5a:ad:fe:48:15:80:77:10:f4:bd:6f:0b:28
+# SHA256 Fingerprint: b0:85:d7:0b:96:4f:19:1a:73:e4:af:0d:54:ae:7a:0e:07:aa:fd:af:9b:71:dd:08:62:13:8a:b7:32:5a:24:a2
+-----BEGIN CERTIFICATE-----
+MIIB3DCCAYOgAwIBAgINAgPlfvU/k/2lCSGypjAKBggqhkjOPQQDAjBQMSQwIgYD
+VQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0gUjQxEzARBgNVBAoTCkdsb2Jh
+bFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wHhcNMTIxMTEzMDAwMDAwWhcNMzgw
+MTE5MDMxNDA3WjBQMSQwIgYDVQQLExtHbG9iYWxTaWduIEVDQyBSb290IENBIC0g
+UjQxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2JhbFNpZ24wWTAT
+BgcqhkjOPQIBBggqhkjOPQMBBwNCAAS4xnnTj2wlDp8uORkcA6SumuU5BwkWymOx
+uYb4ilfBV85C+nOh92VC/x7BALJucw7/xyHlGKSq2XE/qNS5zowdo0IwQDAOBgNV
+HQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUVLB7rUW44kB/
++wpu+74zyTyjhNUwCgYIKoZIzj0EAwIDRwAwRAIgIk90crlgr/HmnKAWBVBfw147
+bmF0774BxL4YSFlhgjICICadVGNA3jdgUM/I2O2dgq43mLyjj0xMqTQrbO/7lZsm
+-----END CERTIFICATE-----
+
+# Issuer: CN=GTS Root R1 O=Google Trust Services LLC
+# Subject: CN=GTS Root R1 O=Google Trust Services LLC
+# Label: "GTS Root R1"
+# Serial: 159662320309726417404178440727
+# MD5 Fingerprint: 05:fe:d0:bf:71:a8:a3:76:63:da:01:e0:d8:52:dc:40
+# SHA1 Fingerprint: e5:8c:1c:c4:91:3b:38:63:4b:e9:10:6e:e3:ad:8e:6b:9d:d9:81:4a
+# SHA256 Fingerprint: d9:47:43:2a:bd:e7:b7:fa:90:fc:2e:6b:59:10:1b:12:80:e0:e1:c7:e4:e4:0f:a3:c6:88:7f:ff:57:a7:f4:cf
+-----BEGIN CERTIFICATE-----
+MIIFVzCCAz+gAwIBAgINAgPlk28xsBNJiGuiFzANBgkqhkiG9w0BAQwFADBHMQsw
+CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU
+MBIGA1UEAxMLR1RTIFJvb3QgUjEwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw
+MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp
+Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEBAQUA
+A4ICDwAwggIKAoICAQC2EQKLHuOhd5s73L+UPreVp0A8of2C+X0yBoJx9vaMf/vo
+27xqLpeXo4xL+Sv2sfnOhB2x+cWX3u+58qPpvBKJXqeqUqv4IyfLpLGcY9vXmX7w
+Cl7raKb0xlpHDU0QM+NOsROjyBhsS+z8CZDfnWQpJSMHobTSPS5g4M/SCYe7zUjw
+TcLCeoiKu7rPWRnWr4+wB7CeMfGCwcDfLqZtbBkOtdh+JhpFAz2weaSUKK0Pfybl
+qAj+lug8aJRT7oM6iCsVlgmy4HqMLnXWnOunVmSPlk9orj2XwoSPwLxAwAtcvfaH
+szVsrBhQf4TgTM2S0yDpM7xSma8ytSmzJSq0SPly4cpk9+aCEI3oncKKiPo4Zor8
+Y/kB+Xj9e1x3+naH+uzfsQ55lVe0vSbv1gHR6xYKu44LtcXFilWr06zqkUspzBmk
+MiVOKvFlRNACzqrOSbTqn3yDsEB750Orp2yjj32JgfpMpf/VjsPOS+C12LOORc92
+wO1AK/1TD7Cn1TsNsYqiA94xrcx36m97PtbfkSIS5r762DL8EGMUUXLeXdYWk70p
+aDPvOmbsB4om3xPXV2V4J95eSRQAogB/mqghtqmxlbCluQ0WEdrHbEg8QOB+DVrN
+VjzRlwW5y0vtOUucxD/SVRNuJLDWcfr0wbrM7Rv1/oFB2ACYPTrIrnqYNxgFlQID
+AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E
+FgQU5K8rJnEaK0gnhS9SZizv8IkTcT4wDQYJKoZIhvcNAQEMBQADggIBAJ+qQibb
+C5u+/x6Wki4+omVKapi6Ist9wTrYggoGxval3sBOh2Z5ofmmWJyq+bXmYOfg6LEe
+QkEzCzc9zolwFcq1JKjPa7XSQCGYzyI0zzvFIoTgxQ6KfF2I5DUkzps+GlQebtuy
+h6f88/qBVRRiClmpIgUxPoLW7ttXNLwzldMXG+gnoot7TiYaelpkttGsN/H9oPM4
+7HLwEXWdyzRSjeZ2axfG34arJ45JK3VmgRAhpuo+9K4l/3wV3s6MJT/KYnAK9y8J
+ZgfIPxz88NtFMN9iiMG1D53Dn0reWVlHxYciNuaCp+0KueIHoI17eko8cdLiA6Ef
+MgfdG+RCzgwARWGAtQsgWSl4vflVy2PFPEz0tv/bal8xa5meLMFrUKTX5hgUvYU/
+Z6tGn6D/Qqc6f1zLXbBwHSs09dR2CQzreExZBfMzQsNhFRAbd03OIozUhfJFfbdT
+6u9AWpQKXCBfTkBdYiJ23//OYb2MI3jSNwLgjt7RETeJ9r/tSQdirpLsQBqvFAnZ
+0E6yove+7u7Y/9waLd64NnHi/Hm3lCXRSHNboTXns5lndcEZOitHTtNCjv0xyBZm
+2tIMPNuzjsmhDYAPexZ3FL//2wmUspO8IFgV6dtxQ/PeEMMA3KgqlbbC1j+Qa3bb
+bP6MvPJwNQzcmRk13NfIRmPVNnGuV/u3gm3c
+-----END CERTIFICATE-----
+
+# Issuer: CN=GTS Root R2 O=Google Trust Services LLC
+# Subject: CN=GTS Root R2 O=Google Trust Services LLC
+# Label: "GTS Root R2"
+# Serial: 159662449406622349769042896298
+# MD5 Fingerprint: 1e:39:c0:53:e6:1e:29:82:0b:ca:52:55:36:5d:57:dc
+# SHA1 Fingerprint: 9a:44:49:76:32:db:de:fa:d0:bc:fb:5a:7b:17:bd:9e:56:09:24:94
+# SHA256 Fingerprint: 8d:25:cd:97:22:9d:bf:70:35:6b:da:4e:b3:cc:73:40:31:e2:4c:f0:0f:af:cf:d3:2d:c7:6e:b5:84:1c:7e:a8
+-----BEGIN CERTIFICATE-----
+MIIFVzCCAz+gAwIBAgINAgPlrsWNBCUaqxElqjANBgkqhkiG9w0BAQwFADBHMQsw
+CQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEU
+MBIGA1UEAxMLR1RTIFJvb3QgUjIwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAw
+MDAwWjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZp
+Y2VzIExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEBAQUA
+A4ICDwAwggIKAoICAQDO3v2m++zsFDQ8BwZabFn3GTXd98GdVarTzTukk3LvCvpt
+nfbwhYBboUhSnznFt+4orO/LdmgUud+tAWyZH8QiHZ/+cnfgLFuv5AS/T3KgGjSY
+6Dlo7JUle3ah5mm5hRm9iYz+re026nO8/4Piy33B0s5Ks40FnotJk9/BW9BuXvAu
+MC6C/Pq8tBcKSOWIm8Wba96wyrQD8Nr0kLhlZPdcTK3ofmZemde4wj7I0BOdre7k
+RXuJVfeKH2JShBKzwkCX44ofR5GmdFrS+LFjKBC4swm4VndAoiaYecb+3yXuPuWg
+f9RhD1FLPD+M2uFwdNjCaKH5wQzpoeJ/u1U8dgbuak7MkogwTZq9TwtImoS1mKPV
++3PBV2HdKFZ1E66HjucMUQkQdYhMvI35ezzUIkgfKtzra7tEscszcTJGr61K8Yzo
+dDqs5xoic4DSMPclQsciOzsSrZYuxsN2B6ogtzVJV+mSSeh2FnIxZyuWfoqjx5RW
+Ir9qS34BIbIjMt/kmkRtWVtd9QCgHJvGeJeNkP+byKq0rxFROV7Z+2et1VsRnTKa
+G73VululycslaVNVJ1zgyjbLiGH7HrfQy+4W+9OmTN6SpdTi3/UGVN4unUu0kzCq
+gc7dGtxRcw1PcOnlthYhGXmy5okLdWTK1au8CcEYof/UVKGFPP0UJAOyh9OktwID
+AQABo0IwQDAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4E
+FgQUu//KjiOfT5nK2+JopqUVJxce2Q4wDQYJKoZIhvcNAQEMBQADggIBAB/Kzt3H
+vqGf2SdMC9wXmBFqiN495nFWcrKeGk6c1SuYJF2ba3uwM4IJvd8lRuqYnrYb/oM8
+0mJhwQTtzuDFycgTE1XnqGOtjHsB/ncw4c5omwX4Eu55MaBBRTUoCnGkJE+M3DyC
+B19m3H0Q/gxhswWV7uGugQ+o+MePTagjAiZrHYNSVc61LwDKgEDg4XSsYPWHgJ2u
+NmSRXbBoGOqKYcl3qJfEycel/FVL8/B/uWU9J2jQzGv6U53hkRrJXRqWbTKH7QMg
+yALOWr7Z6v2yTcQvG99fevX4i8buMTolUVVnjWQye+mew4K6Ki3pHrTgSAai/Gev
+HyICc/sgCq+dVEuhzf9gR7A/Xe8bVr2XIZYtCtFenTgCR2y59PYjJbigapordwj6
+xLEokCZYCDzifqrXPW+6MYgKBesntaFJ7qBFVHvmJ2WZICGoo7z7GJa7Um8M7YNR
+TOlZ4iBgxcJlkoKM8xAfDoqXvneCbT+PHV28SSe9zE8P4c52hgQjxcCMElv924Sg
+JPFI/2R80L5cFtHvma3AH/vLrrw4IgYmZNralw4/KBVEqE8AyvCazM90arQ+POuV
+7LXTWtiBmelDGDfrs7vRWGJB82bSj6p4lVQgw1oudCvV0b4YacCs1aTPObpRhANl
+6WLAYv7YTVWW4tAR+kg0Eeye7QUd5MjWHYbL
+-----END CERTIFICATE-----
+
+# Issuer: CN=GTS Root R3 O=Google Trust Services LLC
+# Subject: CN=GTS Root R3 O=Google Trust Services LLC
+# Label: "GTS Root R3"
+# Serial: 159662495401136852707857743206
+# MD5 Fingerprint: 3e:e7:9d:58:02:94:46:51:94:e5:e0:22:4a:8b:e7:73
+# SHA1 Fingerprint: ed:e5:71:80:2b:c8:92:b9:5b:83:3c:d2:32:68:3f:09:cd:a0:1e:46
+# SHA256 Fingerprint: 34:d8:a7:3e:e2:08:d9:bc:db:0d:95:65:20:93:4b:4e:40:e6:94:82:59:6e:8b:6f:73:c8:42:6b:01:0a:6f:48
+-----BEGIN CERTIFICATE-----
+MIICCTCCAY6gAwIBAgINAgPluILrIPglJ209ZjAKBggqhkjOPQQDAzBHMQswCQYD
+VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG
+A1UEAxMLR1RTIFJvb3QgUjMwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw
+WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz
+IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjMwdjAQBgcqhkjOPQIBBgUrgQQAIgNi
+AAQfTzOHMymKoYTey8chWEGJ6ladK0uFxh1MJ7x/JlFyb+Kf1qPKzEUURout736G
+jOyxfi//qXGdGIRFBEFVbivqJn+7kAHjSxm65FSWRQmx1WyRRK2EE46ajA2ADDL2
+4CejQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW
+BBTB8Sa6oC2uhYHP0/EqEr24Cmf9vDAKBggqhkjOPQQDAwNpADBmAjEA9uEglRR7
+VKOQFhG/hMjqb2sXnh5GmCCbn9MN2azTL818+FsuVbu/3ZL3pAzcMeGiAjEA/Jdm
+ZuVDFhOD3cffL74UOO0BzrEXGhF16b0DjyZ+hOXJYKaV11RZt+cRLInUue4X
+-----END CERTIFICATE-----
+
+# Issuer: CN=GTS Root R4 O=Google Trust Services LLC
+# Subject: CN=GTS Root R4 O=Google Trust Services LLC
+# Label: "GTS Root R4"
+# Serial: 159662532700760215368942768210
+# MD5 Fingerprint: 43:96:83:77:19:4d:76:b3:9d:65:52:e4:1d:22:a5:e8
+# SHA1 Fingerprint: 77:d3:03:67:b5:e0:0c:15:f6:0c:38:61:df:7c:e1:3b:92:46:4d:47
+# SHA256 Fingerprint: 34:9d:fa:40:58:c5:e2:63:12:3b:39:8a:e7:95:57:3c:4e:13:13:c8:3f:e6:8f:93:55:6c:d5:e8:03:1b:3c:7d
+-----BEGIN CERTIFICATE-----
+MIICCTCCAY6gAwIBAgINAgPlwGjvYxqccpBQUjAKBggqhkjOPQQDAzBHMQswCQYD
+VQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2VzIExMQzEUMBIG
+A1UEAxMLR1RTIFJvb3QgUjQwHhcNMTYwNjIyMDAwMDAwWhcNMzYwNjIyMDAwMDAw
+WjBHMQswCQYDVQQGEwJVUzEiMCAGA1UEChMZR29vZ2xlIFRydXN0IFNlcnZpY2Vz
+IExMQzEUMBIGA1UEAxMLR1RTIFJvb3QgUjQwdjAQBgcqhkjOPQIBBgUrgQQAIgNi
+AATzdHOnaItgrkO4NcWBMHtLSZ37wWHO5t5GvWvVYRg1rkDdc/eJkTBa6zzuhXyi
+QHY7qca4R9gq55KRanPpsXI5nymfopjTX15YhmUPoYRlBtHci8nHc8iMai/lxKvR
+HYqjQjBAMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQW
+BBSATNbrdP9JNqPV2Py1PsVq8JQdjDAKBggqhkjOPQQDAwNpADBmAjEA6ED/g94D
+9J+uHXqnLrmvT/aDHQ4thQEd0dlq7A/Cr8deVl5c1RxYIigL9zC2L7F8AjEA8GE8
+p/SgguMh1YQdc4acLa/KNJvxn7kjNuK8YAOdgLOaVsjh4rsUecrNIdSUtUlD
+-----END CERTIFICATE-----
+
+# Issuer: CN=Telia Root CA v2 O=Telia Finland Oyj
+# Subject: CN=Telia Root CA v2 O=Telia Finland Oyj
+# Label: "Telia Root CA v2"
+# Serial: 7288924052977061235122729490515358
+# MD5 Fingerprint: 0e:8f:ac:aa:82:df:85:b1:f4:dc:10:1c:fc:99:d9:48
+# SHA1 Fingerprint: b9:99:cd:d1:73:50:8a:c4:47:05:08:9c:8c:88:fb:be:a0:2b:40:cd
+# SHA256 Fingerprint: 24:2b:69:74:2f:cb:1e:5b:2a:bf:98:89:8b:94:57:21:87:54:4e:5b:4d:99:11:78:65:73:62:1f:6a:74:b8:2c
+-----BEGIN CERTIFICATE-----
+MIIFdDCCA1ygAwIBAgIPAWdfJ9b+euPkrL4JWwWeMA0GCSqGSIb3DQEBCwUAMEQx
+CzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZMBcGA1UE
+AwwQVGVsaWEgUm9vdCBDQSB2MjAeFw0xODExMjkxMTU1NTRaFw00MzExMjkxMTU1
+NTRaMEQxCzAJBgNVBAYTAkZJMRowGAYDVQQKDBFUZWxpYSBGaW5sYW5kIE95ajEZ
+MBcGA1UEAwwQVGVsaWEgUm9vdCBDQSB2MjCCAiIwDQYJKoZIhvcNAQEBBQADggIP
+ADCCAgoCggIBALLQPwe84nvQa5n44ndp586dpAO8gm2h/oFlH0wnrI4AuhZ76zBq
+AMCzdGh+sq/H1WKzej9Qyow2RCRj0jbpDIX2Q3bVTKFgcmfiKDOlyzG4OiIjNLh9
+vVYiQJ3q9HsDrWj8soFPmNB06o3lfc1jw6P23pLCWBnglrvFxKk9pXSW/q/5iaq9
+lRdU2HhE8Qx3FZLgmEKnpNaqIJLNwaCzlrI6hEKNfdWV5Nbb6WLEWLN5xYzTNTOD
+n3WhUidhOPFZPY5Q4L15POdslv5e2QJltI5c0BE0312/UqeBAMN/mUWZFdUXyApT
+7GPzmX3MaRKGwhfwAZ6/hLzRUssbkmbOpFPlob/E2wnW5olWK8jjfN7j/4nlNW4o
+6GwLI1GpJQXrSPjdscr6bAhR77cYbETKJuFzxokGgeWKrLDiKca5JLNrRBH0pUPC
+TEPlcDaMtjNXepUugqD0XBCzYYP2AgWGLnwtbNwDRm41k9V6lS/eINhbfpSQBGq6
+WT0EBXWdN6IOLj3rwaRSg/7Qa9RmjtzG6RJOHSpXqhC8fF6CfaamyfItufUXJ63R
+DolUK5X6wK0dmBR4M0KGCqlztft0DbcbMBnEWg4cJ7faGND/isgFuvGqHKI3t+ZI
+pEYslOqodmJHixBTB0hXbOKSTbauBcvcwUpej6w9GU7C7WB1K9vBykLVAgMBAAGj
+YzBhMB8GA1UdIwQYMBaAFHKs5DN5qkWH9v2sHZ7Wxy+G2CQ5MB0GA1UdDgQWBBRy
+rOQzeapFh/b9rB2e1scvhtgkOTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw
+AwEB/zANBgkqhkiG9w0BAQsFAAOCAgEAoDtZpwmUPjaE0n4vOaWWl/oRrfxn83EJ
+8rKJhGdEr7nv7ZbsnGTbMjBvZ5qsfl+yqwE2foH65IRe0qw24GtixX1LDoJt0nZi
+0f6X+J8wfBj5tFJ3gh1229MdqfDBmgC9bXXYfef6xzijnHDoRnkDry5023X4blMM
+A8iZGok1GTzTyVR8qPAs5m4HeW9q4ebqkYJpCh3DflminmtGFZhb069GHWLIzoBS
+SRE/yQQSwxN8PzuKlts8oB4KtItUsiRnDe+Cy748fdHif64W1lZYudogsYMVoe+K
+TTJvQS8TUoKU1xrBeKJR3Stwbbca+few4GeXVtt8YVMJAygCQMez2P2ccGrGKMOF
+6eLtGpOg3kuYooQ+BXcBlj37tCAPnHICehIv1aO6UXivKitEZU61/Qrowc15h2Er
+3oBXRb9n8ZuRXqWk7FlIEA04x7D6w0RtBPV4UBySllva9bguulvP5fBqnUsvWHMt
+Ty3EHD70sz+rFQ47GUGKpMFXEmZxTPpT41frYpUJnlTd0cI8Vzy9OK2YZLe4A5pT
+VmBds9hCG1xLEooc6+t9xnppxyd/pPiL8uSUZodL6ZQHCRJ5irLrdATczvREWeAW
+ysUsWNc8e89ihmpQfTU2Zqf7N+cox9jQraVplI/owd8k+BsHMYeB2F326CjYSlKA
+rBPuUBQemMc=
+-----END CERTIFICATE-----
+
+# Issuer: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH
+# Subject: CN=D-TRUST BR Root CA 1 2020 O=D-Trust GmbH
+# Label: "D-TRUST BR Root CA 1 2020"
+# Serial: 165870826978392376648679885835942448534
+# MD5 Fingerprint: b5:aa:4b:d5:ed:f7:e3:55:2e:8f:72:0a:f3:75:b8:ed
+# SHA1 Fingerprint: 1f:5b:98:f0:e3:b5:f7:74:3c:ed:e6:b0:36:7d:32:cd:f4:09:41:67
+# SHA256 Fingerprint: e5:9a:aa:81:60:09:c2:2b:ff:5b:25:ba:d3:7d:f3:06:f0:49:79:7c:1f:81:d8:5a:b0:89:e6:57:bd:8f:00:44
+-----BEGIN CERTIFICATE-----
+MIIC2zCCAmCgAwIBAgIQfMmPK4TX3+oPyWWa00tNljAKBggqhkjOPQQDAzBIMQsw
+CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS
+VVNUIEJSIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTA5NDUwMFoXDTM1MDIxMTA5
+NDQ1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG
+A1UEAxMZRC1UUlVTVCBCUiBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB
+BAAiA2IABMbLxyjR+4T1mu9CFCDhQ2tuda38KwOE1HaTJddZO0Flax7mNCq7dPYS
+zuht56vkPE4/RAiLzRZxy7+SmfSk1zxQVFKQhYN4lGdnoxwJGT11NIXe7WB9xwy0
+QVK5buXuQqOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFHOREKv/
+VbNafAkl1bK6CKBrqx9tMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g
+PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2JyX3Jvb3Rf
+Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l
+dC9DTj1ELVRSVVNUJTIwQlIlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1
+c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO
+PQQDAwNpADBmAjEAlJAtE/rhY/hhY+ithXhUkZy4kzg+GkHaQBZTQgjKL47xPoFW
+wKrY7RjEsK70PvomAjEA8yjixtsrmfu3Ubgko6SUeho/5jbiA1czijDLgsfWFBHV
+dWNbFJWcHwHP2NVypw87
+-----END CERTIFICATE-----
+
+# Issuer: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH
+# Subject: CN=D-TRUST EV Root CA 1 2020 O=D-Trust GmbH
+# Label: "D-TRUST EV Root CA 1 2020"
+# Serial: 126288379621884218666039612629459926992
+# MD5 Fingerprint: 8c:2d:9d:70:9f:48:99:11:06:11:fb:e9:cb:30:c0:6e
+# SHA1 Fingerprint: 61:db:8c:21:59:69:03:90:d8:7c:9c:12:86:54:cf:9d:3d:f4:dd:07
+# SHA256 Fingerprint: 08:17:0d:1a:a3:64:53:90:1a:2f:95:92:45:e3:47:db:0c:8d:37:ab:aa:bc:56:b8:1a:a1:00:dc:95:89:70:db
+-----BEGIN CERTIFICATE-----
+MIIC2zCCAmCgAwIBAgIQXwJB13qHfEwDo6yWjfv/0DAKBggqhkjOPQQDAzBIMQsw
+CQYDVQQGEwJERTEVMBMGA1UEChMMRC1UcnVzdCBHbWJIMSIwIAYDVQQDExlELVRS
+VVNUIEVWIFJvb3QgQ0EgMSAyMDIwMB4XDTIwMDIxMTEwMDAwMFoXDTM1MDIxMTA5
+NTk1OVowSDELMAkGA1UEBhMCREUxFTATBgNVBAoTDEQtVHJ1c3QgR21iSDEiMCAG
+A1UEAxMZRC1UUlVTVCBFViBSb290IENBIDEgMjAyMDB2MBAGByqGSM49AgEGBSuB
+BAAiA2IABPEL3YZDIBnfl4XoIkqbz52Yv7QFJsnL46bSj8WeeHsxiamJrSc8ZRCC
+/N/DnU7wMyPE0jL1HLDfMxddxfCxivnvubcUyilKwg+pf3VlSSowZ/Rk99Yad9rD
+wpdhQntJraOCAQ0wggEJMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFH8QARY3
+OqQo5FD4pPfsazK2/umLMA4GA1UdDwEB/wQEAwIBBjCBxgYDVR0fBIG+MIG7MD6g
+PKA6hjhodHRwOi8vY3JsLmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X2V2X3Jvb3Rf
+Y2FfMV8yMDIwLmNybDB5oHegdYZzbGRhcDovL2RpcmVjdG9yeS5kLXRydXN0Lm5l
+dC9DTj1ELVRSVVNUJTIwRVYlMjBSb290JTIwQ0ElMjAxJTIwMjAyMCxPPUQtVHJ1
+c3QlMjBHbWJILEM9REU/Y2VydGlmaWNhdGVyZXZvY2F0aW9ubGlzdDAKBggqhkjO
+PQQDAwNpADBmAjEAyjzGKnXCXnViOTYAYFqLwZOZzNnbQTs7h5kXO9XMT8oi96CA
+y/m0sRtW9XLS/BnRAjEAkfcwkz8QRitxpNA7RJvAKQIFskF3UfN5Wp6OFKBOQtJb
+gfM0agPnIjhQW+0ZT0MW
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc.
+# Subject: CN=DigiCert TLS ECC P384 Root G5 O=DigiCert, Inc.
+# Label: "DigiCert TLS ECC P384 Root G5"
+# Serial: 13129116028163249804115411775095713523
+# MD5 Fingerprint: d3:71:04:6a:43:1c:db:a6:59:e1:a8:a3:aa:c5:71:ed
+# SHA1 Fingerprint: 17:f3:de:5e:9f:0f:19:e9:8e:f6:1f:32:26:6e:20:c4:07:ae:30:ee
+# SHA256 Fingerprint: 01:8e:13:f0:77:25:32:cf:80:9b:d1:b1:72:81:86:72:83:fc:48:c6:e1:3b:e9:c6:98:12:85:4a:49:0c:1b:05
+-----BEGIN CERTIFICATE-----
+MIICGTCCAZ+gAwIBAgIQCeCTZaz32ci5PhwLBCou8zAKBggqhkjOPQQDAzBOMQsw
+CQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJjAkBgNVBAMTHURp
+Z2lDZXJ0IFRMUyBFQ0MgUDM4NCBSb290IEc1MB4XDTIxMDExNTAwMDAwMFoXDTQ2
+MDExNDIzNTk1OVowTjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ
+bmMuMSYwJAYDVQQDEx1EaWdpQ2VydCBUTFMgRUNDIFAzODQgUm9vdCBHNTB2MBAG
+ByqGSM49AgEGBSuBBAAiA2IABMFEoc8Rl1Ca3iOCNQfN0MsYndLxf3c1TzvdlHJS
+7cI7+Oz6e2tYIOyZrsn8aLN1udsJ7MgT9U7GCh1mMEy7H0cKPGEQQil8pQgO4CLp
+0zVozptjn4S1mU1YoI71VOeVyaNCMEAwHQYDVR0OBBYEFMFRRVBZqz7nLFr6ICIS
+B4CIfBFqMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MAoGCCqGSM49
+BAMDA2gAMGUCMQCJao1H5+z8blUD2WdsJk6Dxv3J+ysTvLd6jLRl0mlpYxNjOyZQ
+LgGheQaRnUi/wr4CMEfDFXuxoJGZSZOoPHzoRgaLLPIxAJSdYsiJvRmEFOml+wG4
+DXZDjC5Ty3zfDBeWUA==
+-----END CERTIFICATE-----
+
+# Issuer: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc.
+# Subject: CN=DigiCert TLS RSA4096 Root G5 O=DigiCert, Inc.
+# Label: "DigiCert TLS RSA4096 Root G5"
+# Serial: 11930366277458970227240571539258396554
+# MD5 Fingerprint: ac:fe:f7:34:96:a9:f2:b3:b4:12:4b:e4:27:41:6f:e1
+# SHA1 Fingerprint: a7:88:49:dc:5d:7c:75:8c:8c:de:39:98:56:b3:aa:d0:b2:a5:71:35
+# SHA256 Fingerprint: 37:1a:00:dc:05:33:b3:72:1a:7e:eb:40:e8:41:9e:70:79:9d:2b:0a:0f:2c:1d:80:69:31:65:f7:ce:c4:ad:75
+-----BEGIN CERTIFICATE-----
+MIIFZjCCA06gAwIBAgIQCPm0eKj6ftpqMzeJ3nzPijANBgkqhkiG9w0BAQwFADBN
+MQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIEluYy4xJTAjBgNVBAMT
+HERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwHhcNMjEwMTE1MDAwMDAwWhcN
+NDYwMTE0MjM1OTU5WjBNMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQs
+IEluYy4xJTAjBgNVBAMTHERpZ2lDZXJ0IFRMUyBSU0E0MDk2IFJvb3QgRzUwggIi
+MA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCz0PTJeRGd/fxmgefM1eS87IE+
+ajWOLrfn3q/5B03PMJ3qCQuZvWxX2hhKuHisOjmopkisLnLlvevxGs3npAOpPxG0
+2C+JFvuUAT27L/gTBaF4HI4o4EXgg/RZG5Wzrn4DReW+wkL+7vI8toUTmDKdFqgp
+wgscONyfMXdcvyej/Cestyu9dJsXLfKB2l2w4SMXPohKEiPQ6s+d3gMXsUJKoBZM
+pG2T6T867jp8nVid9E6P/DsjyG244gXazOvswzH016cpVIDPRFtMbzCe88zdH5RD
+nU1/cHAN1DrRN/BsnZvAFJNY781BOHW8EwOVfH/jXOnVDdXifBBiqmvwPXbzP6Po
+sMH976pXTayGpxi0KcEsDr9kvimM2AItzVwv8n/vFfQMFawKsPHTDU9qTXeXAaDx
+Zre3zu/O7Oyldcqs4+Fj97ihBMi8ez9dLRYiVu1ISf6nL3kwJZu6ay0/nTvEF+cd
+Lvvyz6b84xQslpghjLSR6Rlgg/IwKwZzUNWYOwbpx4oMYIwo+FKbbuH2TbsGJJvX
+KyY//SovcfXWJL5/MZ4PbeiPT02jP/816t9JXkGPhvnxd3lLG7SjXi/7RgLQZhNe
+XoVPzthwiHvOAbWWl9fNff2C+MIkwcoBOU+NosEUQB+cZtUMCUbW8tDRSHZWOkPL
+tgoRObqME2wGtZ7P6wIDAQABo0IwQDAdBgNVHQ4EFgQUUTMc7TZArxfTJc1paPKv
+TiM+s0EwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcN
+AQEMBQADggIBAGCmr1tfV9qJ20tQqcQjNSH/0GEwhJG3PxDPJY7Jv0Y02cEhJhxw
+GXIeo8mH/qlDZJY6yFMECrZBu8RHANmfGBg7sg7zNOok992vIGCukihfNudd5N7H
+PNtQOa27PShNlnx2xlv0wdsUpasZYgcYQF+Xkdycx6u1UQ3maVNVzDl92sURVXLF
+O4uJ+DQtpBflF+aZfTCIITfNMBc9uPK8qHWgQ9w+iUuQrm0D4ByjoJYJu32jtyoQ
+REtGBzRj7TG5BO6jm5qu5jF49OokYTurWGT/u4cnYiWB39yhL/btp/96j1EuMPik
+AdKFOV8BmZZvWltwGUb+hmA+rYAQCd05JS9Yf7vSdPD3Rh9GOUrYU9DzLjtxpdRv
+/PNn5AeP3SYZ4Y1b+qOTEZvpyDrDVWiakuFSdjjo4bq9+0/V77PnSIMx8IIh47a+
+p6tv75/fTM8BuGJqIz3nCU2AG3swpMPdB380vqQmsvZB6Akd4yCYqjdP//fx4ilw
+MUc/dNAUFvohigLVigmUdy7yWSiLfFCSCmZ4OIN1xLVaqBHG5cGdZlXPU8Sv13WF
+qUITVuwhd4GTWgzqltlJyqEI8pc7bZsEGCREjnwB8twl2F6GmrE52/WRMmrRpnCK
+ovfepEWFJqgejF0pW8hL2JpqA15w8oVPbEtoL8pU9ozaMv7Da4M/OMZ+
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certainly Root R1 O=Certainly
+# Subject: CN=Certainly Root R1 O=Certainly
+# Label: "Certainly Root R1"
+# Serial: 188833316161142517227353805653483829216
+# MD5 Fingerprint: 07:70:d4:3e:82:87:a0:fa:33:36:13:f4:fa:33:e7:12
+# SHA1 Fingerprint: a0:50:ee:0f:28:71:f4:27:b2:12:6d:6f:50:96:25:ba:cc:86:42:af
+# SHA256 Fingerprint: 77:b8:2c:d8:64:4c:43:05:f7:ac:c5:cb:15:6b:45:67:50:04:03:3d:51:c6:0c:62:02:a8:e0:c3:34:67:d3:a0
+-----BEGIN CERTIFICATE-----
+MIIFRzCCAy+gAwIBAgIRAI4P+UuQcWhlM1T01EQ5t+AwDQYJKoZIhvcNAQELBQAw
+PTELMAkGA1UEBhMCVVMxEjAQBgNVBAoTCUNlcnRhaW5seTEaMBgGA1UEAxMRQ2Vy
+dGFpbmx5IFJvb3QgUjEwHhcNMjEwNDAxMDAwMDAwWhcNNDYwNDAxMDAwMDAwWjA9
+MQswCQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0
+YWlubHkgUm9vdCBSMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANA2
+1B/q3avk0bbm+yLA3RMNansiExyXPGhjZjKcA7WNpIGD2ngwEc/csiu+kr+O5MQT
+vqRoTNoCaBZ0vrLdBORrKt03H2As2/X3oXyVtwxwhi7xOu9S98zTm/mLvg7fMbed
+aFySpvXl8wo0tf97ouSHocavFwDvA5HtqRxOcT3Si2yJ9HiG5mpJoM610rCrm/b0
+1C7jcvk2xusVtyWMOvwlDbMicyF0yEqWYZL1LwsYpfSt4u5BvQF5+paMjRcCMLT5
+r3gajLQ2EBAHBXDQ9DGQilHFhiZ5shGIXsXwClTNSaa/ApzSRKft43jvRl5tcdF5
+cBxGX1HpyTfcX35pe0HfNEXgO4T0oYoKNp43zGJS4YkNKPl6I7ENPT2a/Z2B7yyQ
+wHtETrtJ4A5KVpK8y7XdeReJkd5hiXSSqOMyhb5OhaRLWcsrxXiOcVTQAjeZjOVJ
+6uBUcqQRBi8LjMFbvrWhsFNunLhgkR9Za/kt9JQKl7XsxXYDVBtlUrpMklZRNaBA
+2CnbrlJ2Oy0wQJuK0EJWtLeIAaSHO1OWzaMWj/Nmqhexx2DgwUMFDO6bW2BvBlyH
+Wyf5QBGenDPBt+U1VwV/J84XIIwc/PH72jEpSe31C4SnT8H2TsIonPru4K8H+zMR
+eiFPCyEQtkA6qyI6BJyLm4SGcprSp6XEtHWRqSsjAgMBAAGjQjBAMA4GA1UdDwEB
+/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBTgqj8ljZ9EXME66C6u
+d0yEPmcM9DANBgkqhkiG9w0BAQsFAAOCAgEAuVevuBLaV4OPaAszHQNTVfSVcOQr
+PbA56/qJYv331hgELyE03fFo8NWWWt7CgKPBjcZq91l3rhVkz1t5BXdm6ozTaw3d
+8VkswTOlMIAVRQdFGjEitpIAq5lNOo93r6kiyi9jyhXWx8bwPWz8HA2YEGGeEaIi
+1wrykXprOQ4vMMM2SZ/g6Q8CRFA3lFV96p/2O7qUpUzpvD5RtOjKkjZUbVwlKNrd
+rRT90+7iIgXr0PK3aBLXWopBGsaSpVo7Y0VPv+E6dyIvXL9G+VoDhRNCX8reU9di
+taY1BMJH/5n9hN9czulegChB8n3nHpDYT3Y+gjwN/KUD+nsa2UUeYNrEjvn8K8l7
+lcUq/6qJ34IxD3L/DCfXCh5WAFAeDJDBlrXYFIW7pw0WwfgHJBu6haEaBQmAupVj
+yTrsJZ9/nbqkRxWbRHDxakvWOF5D8xh+UG7pWijmZeZ3Gzr9Hb4DJqPb1OG7fpYn
+Kx3upPvaJVQTA945xsMfTZDsjxtK0hzthZU4UHlG1sGQUDGpXJpuHfUzVounmdLy
+yCwzk5Iwx06MZTMQZBf9JBeW0Y3COmor6xOLRPIh80oat3df1+2IpHLlOR+Vnb5n
+wXARPbv0+Em34yaXOp/SX3z7wJl8OSngex2/DaeP0ik0biQVy96QXr8axGbqwua6
+OV+KmalBWQewLK8=
+-----END CERTIFICATE-----
+
+# Issuer: CN=Certainly Root E1 O=Certainly
+# Subject: CN=Certainly Root E1 O=Certainly
+# Label: "Certainly Root E1"
+# Serial: 8168531406727139161245376702891150584
+# MD5 Fingerprint: 0a:9e:ca:cd:3e:52:50:c6:36:f3:4b:a3:ed:a7:53:e9
+# SHA1 Fingerprint: f9:e1:6d:dc:01:89:cf:d5:82:45:63:3e:c5:37:7d:c2:eb:93:6f:2b
+# SHA256 Fingerprint: b4:58:5f:22:e4:ac:75:6a:4e:86:12:a1:36:1c:5d:9d:03:1a:93:fd:84:fe:bb:77:8f:a3:06:8b:0f:c4:2d:c2
+-----BEGIN CERTIFICATE-----
+MIIB9zCCAX2gAwIBAgIQBiUzsUcDMydc+Y2aub/M+DAKBggqhkjOPQQDAzA9MQsw
+CQYDVQQGEwJVUzESMBAGA1UEChMJQ2VydGFpbmx5MRowGAYDVQQDExFDZXJ0YWlu
+bHkgUm9vdCBFMTAeFw0yMTA0MDEwMDAwMDBaFw00NjA0MDEwMDAwMDBaMD0xCzAJ
+BgNVBAYTAlVTMRIwEAYDVQQKEwlDZXJ0YWlubHkxGjAYBgNVBAMTEUNlcnRhaW5s
+eSBSb290IEUxMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAE3m/4fxzf7flHh4axpMCK
++IKXgOqPyEpeKn2IaKcBYhSRJHpcnqMXfYqGITQYUBsQ3tA3SybHGWCA6TS9YBk2
+QNYphwk8kXr2vBMj3VlOBF7PyAIcGFPBMdjaIOlEjeR2o0IwQDAOBgNVHQ8BAf8E
+BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQU8ygYy2R17ikq6+2uI1g4
+hevIIgcwCgYIKoZIzj0EAwMDaAAwZQIxALGOWiDDshliTd6wT99u0nCK8Z9+aozm
+ut6Dacpps6kFtZaSF4fC0urQe87YQVt8rgIwRt7qy12a7DLCZRawTDBcMPPaTnOG
+BtjOiQRINzf43TNRnXCve1XYAS59BWQOhriR
+-----END CERTIFICATE-----
+
+# Issuer: CN=E-Tugra Global Root CA RSA v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center
+# Subject: CN=E-Tugra Global Root CA RSA v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center
+# Label: "E-Tugra Global Root CA RSA v3"
+# Serial: 75951268308633135324246244059508261641472512052
+# MD5 Fingerprint: 22:be:10:f6:c2:f8:03:88:73:5f:33:29:47:28:47:a4
+# SHA1 Fingerprint: e9:a8:5d:22:14:52:1c:5b:aa:0a:b4:be:24:6a:23:8a:c9:ba:e2:a9
+# SHA256 Fingerprint: ef:66:b0:b1:0a:3c:db:9f:2e:36:48:c7:6b:d2:af:18:ea:d2:bf:e6:f1:17:65:5e:28:c4:06:0d:a1:a3:f4:c2
+-----BEGIN CERTIFICATE-----
+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
+-----END CERTIFICATE-----
+
+# Issuer: CN=E-Tugra Global Root CA ECC v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center
+# Subject: CN=E-Tugra Global Root CA ECC v3 O=E-Tugra EBG A.S. OU=E-Tugra Trust Center
+# Label: "E-Tugra Global Root CA ECC v3"
+# Serial: 218504919822255052842371958738296604628416471745
+# MD5 Fingerprint: 46:bc:81:bb:f1:b5:1e:f7:4b:96:bc:14:e2:e7:27:64
+# SHA1 Fingerprint: 8a:2f:af:57:53:b1:b0:e6:a1:04:ec:5b:6a:69:71:6d:f6:1c:e2:84
+# SHA256 Fingerprint: 87:3f:46:85:fa:7f:56:36:25:25:2e:6d:36:bc:d7:f1:6f:c2:49:51:f2:64:e4:7e:1b:95:4f:49:08:cd:ca:13
+-----BEGIN CERTIFICATE-----
+MIICpTCCAiqgAwIBAgIUJkYZdzHhT28oNt45UYbm1JeIIsEwCgYIKoZIzj0EAwMw
+gYAxCzAJBgNVBAYTAlRSMQ8wDQYDVQQHEwZBbmthcmExGTAXBgNVBAoTEEUtVHVn
+cmEgRUJHIEEuUy4xHTAbBgNVBAsTFEUtVHVncmEgVHJ1c3QgQ2VudGVyMSYwJAYD
+VQQDEx1FLVR1Z3JhIEdsb2JhbCBSb290IENBIEVDQyB2MzAeFw0yMDAzMTgwOTQ2
+NThaFw00NTAzMTIwOTQ2NThaMIGAMQswCQYDVQQGEwJUUjEPMA0GA1UEBxMGQW5r
+YXJhMRkwFwYDVQQKExBFLVR1Z3JhIEVCRyBBLlMuMR0wGwYDVQQLExRFLVR1Z3Jh
+IFRydXN0IENlbnRlcjEmMCQGA1UEAxMdRS1UdWdyYSBHbG9iYWwgUm9vdCBDQSBF
+Q0MgdjMwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASOmCm/xxAeJ9urA8woLNheSBkQ
+KczLWYHMjLiSF4mDKpL2w6QdTGLVn9agRtwcvHbB40fQWxPa56WzZkjnIZpKT4YK
+fWzqTTKACrJ6CZtpS5iB4i7sAnCWH/31Rs7K3IKjYzBhMA8GA1UdEwEB/wQFMAMB
+Af8wHwYDVR0jBBgwFoAU/4Ixcj75xGZsrTie0bBRiKWQzPUwHQYDVR0OBBYEFP+C
+MXI++cRmbK04ntGwUYilkMz1MA4GA1UdDwEB/wQEAwIBBjAKBggqhkjOPQQDAwNp
+ADBmAjEA5gVYaWHlLcoNy/EZCL3W/VGSGn5jVASQkZo1kTmZ+gepZpO6yGjUij/6
+7W4WAie3AjEA3VoXK3YdZUKWpqxdinlW2Iob35reX8dQj7FbcQwm32pAAOwzkSFx
+vmjkI6TZraE3
+-----END CERTIFICATE-----
+
+# Issuer: CN=Security Communication RootCA3 O=SECOM Trust Systems CO.,LTD.
+# Subject: CN=Security Communication RootCA3 O=SECOM Trust Systems CO.,LTD.
+# Label: "Security Communication RootCA3"
+# Serial: 16247922307909811815
+# MD5 Fingerprint: 1c:9a:16:ff:9e:5c:e0:4d:8a:14:01:f4:35:5d:29:26
+# SHA1 Fingerprint: c3:03:c8:22:74:92:e5:61:a2:9c:5f:79:91:2b:1e:44:13:91:30:3a
+# SHA256 Fingerprint: 24:a5:5c:2a:b0:51:44:2d:06:17:76:65:41:23:9a:4a:d0:32:d7:c5:51:75:aa:34:ff:de:2f:bc:4f:5c:52:94
+-----BEGIN CERTIFICATE-----
+MIIFfzCCA2egAwIBAgIJAOF8N0D9G/5nMA0GCSqGSIb3DQEBDAUAMF0xCzAJBgNV
+BAYTAkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMScw
+JQYDVQQDEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTMwHhcNMTYwNjE2
+MDYxNzE2WhcNMzgwMTE4MDYxNzE2WjBdMQswCQYDVQQGEwJKUDElMCMGA1UEChMc
+U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UEAxMeU2VjdXJpdHkg
+Q29tbXVuaWNhdGlvbiBSb290Q0EzMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIIC
+CgKCAgEA48lySfcw3gl8qUCBWNO0Ot26YQ+TUG5pPDXC7ltzkBtnTCHsXzW7OT4r
+CmDvu20rhvtxosis5FaU+cmvsXLUIKx00rgVrVH+hXShuRD+BYD5UpOzQD11EKzA
+lrenfna84xtSGc4RHwsENPXY9Wk8d/Nk9A2qhd7gCVAEF5aEt8iKvE1y/By7z/MG
+TfmfZPd+pmaGNXHIEYBMwXFAWB6+oHP2/D5Q4eAvJj1+XCO1eXDe+uDRpdYMQXF7
+9+qMHIjH7Iv10S9VlkZ8WjtYO/u62C21Jdp6Ts9EriGmnpjKIG58u4iFW/vAEGK7
+8vknR+/RiTlDxN/e4UG/VHMgly1s2vPUB6PmudhvrvyMGS7TZ2crldtYXLVqAvO4
+g160a75BflcJdURQVc1aEWEhCmHCqYj9E7wtiS/NYeCVvsq1e+F7NGcLH7YMx3we
+GVPKp7FKFSBWFHA9K4IsD50VHUeAR/94mQ4xr28+j+2GaR57GIgUssL8gjMunEst
++3A7caoreyYn8xrC3PsXuKHqy6C0rtOUfnrQq8PsOC0RLoi/1D+tEjtCrI8Cbn3M
+0V9hvqG8OmpI6iZVIhZdXw3/JzOfGAN0iltSIEdrRU0id4xVJ/CvHozJgyJUt5rQ
+T9nO/NkuHJYosQLTA70lUhw0Zk8jq/R3gpYd0VcwCBEF/VfR2ccCAwEAAaNCMEAw
+HQYDVR0OBBYEFGQUfPxYchamCik0FW8qy7z8r6irMA4GA1UdDwEB/wQEAwIBBjAP
+BgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBDAUAA4ICAQDcAiMI4u8hOscNtybS
+YpOnpSNyByCCYN8Y11StaSWSntkUz5m5UoHPrmyKO1o5yGwBQ8IibQLwYs1OY0PA
+FNr0Y/Dq9HHuTofjcan0yVflLl8cebsjqodEV+m9NU1Bu0soo5iyG9kLFwfl9+qd
+9XbXv8S2gVj/yP9kaWJ5rW4OH3/uHWnlt3Jxs/6lATWUVCvAUm2PVcTJ0rjLyjQI
+UYWg9by0F1jqClx6vWPGOi//lkkZhOpn2ASxYfQAW0q3nHE3GYV5v4GwxxMOdnE+
+OoAGrgYWp421wsTL/0ClXI2lyTrtcoHKXJg80jQDdwj98ClZXSEIx2C/pHF7uNke
+gr4Jr2VvKKu/S7XuPghHJ6APbw+LP6yVGPO5DtxnVW5inkYO0QR4ynKudtml+LLf
+iAlhi+8kTtFZP1rUPcmTPCtk9YENFpb3ksP+MW/oKjJ0DvRMmEoYDjBU1cXrvMUV
+nuiZIesnKwkK2/HmcBhWuwzkvvnoEKQTkrgc4NtnHVMDpCKn3F2SEDzq//wbEBrD
+2NCcnWXL0CsnMQMeNuE9dnUM/0Umud1RvCPHX9jYhxBAEg09ODfnRDwYwFMJZI//
+1ZqmfHAuc1Uh6N//g7kdPjIe1qZ9LPFm6Vwdp6POXiUyK+OVrCoHzrQoeIY8Laad
+TdJ0MN1kURXbg4NR16/9M51NZg==
+-----END CERTIFICATE-----
+
+# Issuer: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD.
+# Subject: CN=Security Communication ECC RootCA1 O=SECOM Trust Systems CO.,LTD.
+# Label: "Security Communication ECC RootCA1"
+# Serial: 15446673492073852651
+# MD5 Fingerprint: 7e:43:b0:92:68:ec:05:43:4c:98:ab:5d:35:2e:7e:86
+# SHA1 Fingerprint: b8:0e:26:a9:bf:d2:b2:3b:c0:ef:46:c9:ba:c7:bb:f6:1d:0d:41:41
+# SHA256 Fingerprint: e7:4f:bd:a5:5b:d5:64:c4:73:a3:6b:44:1a:a7:99:c8:a6:8e:07:74:40:e8:28:8b:9f:a1:e5:0e:4b:ba:ca:11
+-----BEGIN CERTIFICATE-----
+MIICODCCAb6gAwIBAgIJANZdm7N4gS7rMAoGCCqGSM49BAMDMGExCzAJBgNVBAYT
+AkpQMSUwIwYDVQQKExxTRUNPTSBUcnVzdCBTeXN0ZW1zIENPLixMVEQuMSswKQYD
+VQQDEyJTZWN1cml0eSBDb21tdW5pY2F0aW9uIEVDQyBSb290Q0ExMB4XDTE2MDYx
+NjA1MTUyOFoXDTM4MDExODA1MTUyOFowYTELMAkGA1UEBhMCSlAxJTAjBgNVBAoT
+HFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xKzApBgNVBAMTIlNlY3VyaXR5
+IENvbW11bmljYXRpb24gRUNDIFJvb3RDQTEwdjAQBgcqhkjOPQIBBgUrgQQAIgNi
+AASkpW9gAwPDvTH00xecK4R1rOX9PVdu12O/5gSJko6BnOPpR27KkBLIE+Cnnfdl
+dB9sELLo5OnvbYUymUSxXv3MdhDYW72ixvnWQuRXdtyQwjWpS4g8EkdtXP9JTxpK
+ULGjQjBAMB0GA1UdDgQWBBSGHOf+LaVKiwj+KBH6vqNm+GBZLzAOBgNVHQ8BAf8E
+BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjAVXUI9/Lbu
+9zuxNuie9sRGKEkz0FhDKmMpzE2xtHqiuQ04pV1IKv3LsnNdo4gIxwwCMQDAqy0O
+be0YottT6SXbVQjgUMzfRGEWgqtJsLKB7HOHeLRMsmIbEvoWTSVLY70eN9k=
+-----END CERTIFICATE-----
+
+# Issuer: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY
+# Subject: CN=BJCA Global Root CA1 O=BEIJING CERTIFICATE AUTHORITY
+# Label: "BJCA Global Root CA1"
+# Serial: 113562791157148395269083148143378328608
+# MD5 Fingerprint: 42:32:99:76:43:33:36:24:35:07:82:9b:28:f9:d0:90
+# SHA1 Fingerprint: d5:ec:8d:7b:4c:ba:79:f4:e7:e8:cb:9d:6b:ae:77:83:10:03:21:6a
+# SHA256 Fingerprint: f3:89:6f:88:fe:7c:0a:88:27:66:a7:fa:6a:d2:74:9f:b5:7a:7f:3e:98:fb:76:9c:1f:a7:b0:9c:2c:44:d5:ae
+-----BEGIN CERTIFICATE-----
+MIIFdDCCA1ygAwIBAgIQVW9l47TZkGobCdFsPsBsIDANBgkqhkiG9w0BAQsFADBU
+MQswCQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRI
+T1JJVFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0ExMB4XDTE5MTIxOTAz
+MTYxN1oXDTQ0MTIxMjAzMTYxN1owVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJF
+SUpJTkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2Jh
+bCBSb290IENBMTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAPFmCL3Z
+xRVhy4QEQaVpN3cdwbB7+sN3SJATcmTRuHyQNZ0YeYjjlwE8R4HyDqKYDZ4/N+AZ
+spDyRhySsTphzvq3Rp4Dhtczbu33RYx2N95ulpH3134rhxfVizXuhJFyV9xgw8O5
+58dnJCNPYwpj9mZ9S1WnP3hkSWkSl+BMDdMJoDIwOvqfwPKcxRIqLhy1BDPapDgR
+at7GGPZHOiJBhyL8xIkoVNiMpTAK+BcWyqw3/XmnkRd4OJmtWO2y3syJfQOcs4ll
+5+M7sSKGjwZteAf9kRJ/sGsciQ35uMt0WwfCyPQ10WRjeulumijWML3mG90Vr4Tq
+nMfK9Q7q8l0ph49pczm+LiRvRSGsxdRpJQaDrXpIhRMsDQa4bHlW/KNnMoH1V6XK
+V0Jp6VwkYe/iMBhORJhVb3rCk9gZtt58R4oRTklH2yiUAguUSiz5EtBP6DF+bHq/
+pj+bOT0CFqMYs2esWz8sgytnOYFcuX6U1WTdno9uruh8W7TXakdI136z1C2OVnZO
+z2nxbkRs1CTqjSShGL+9V/6pmTW12xB3uD1IutbB5/EjPtffhZ0nPNRAvQoMvfXn
+jSXWgXSHRtQpdaJCbPdzied9v3pKH9MiyRVVz99vfFXQpIsHETdfg6YmV6YBW37+
+WGgHqel62bno/1Afq8K0wM7o6v0PvY1NuLxxAgMBAAGjQjBAMB0GA1UdDgQWBBTF
+7+3M2I0hxkjk49cULqcWk+WYATAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQE
+AwIBBjANBgkqhkiG9w0BAQsFAAOCAgEAUoKsITQfI/Ki2Pm4rzc2IInRNwPWaZ+4
+YRC6ojGYWUfo0Q0lHhVBDOAqVdVXUsv45Mdpox1NcQJeXyFFYEhcCY5JEMEE3Kli
+awLwQ8hOnThJdMkycFRtwUf8jrQ2ntScvd0g1lPJGKm1Vrl2i5VnZu69mP6u775u
++2D2/VnGKhs/I0qUJDAnyIm860Qkmss9vk/Ves6OF8tiwdneHg56/0OGNFK8YT88
+X7vZdrRTvJez/opMEi4r89fO4aL/3Xtw+zuhTaRjAv04l5U/BXCga99igUOLtFkN
+SoxUnMW7gZ/NfaXvCyUeOiDbHPwfmGcCCtRzRBPbUYQaVQNW4AB+dAb/OMRyHdOo
+P2gxXdMJxy6MW2Pg6Nwe0uxhHvLe5e/2mXZgLR6UcnHGCyoyx5JO1UbXHfmpGQrI
++pXObSOYqgs4rZpWDW+N8TEAiMEXnM0ZNjX+VVOg4DwzX5Ze4jLp3zO7Bkqp2IRz
+znfSxqxx4VyjHQy7Ct9f4qNx2No3WqB4K/TUfet27fJhcKVlmtOJNBir+3I+17Q9
+eVzYH6Eze9mCUAyTF6ps3MKCuwJXNq+YJyo5UOGwifUll35HaBC07HPKs5fRJNz2
+YqAo07WjuGS3iGJCz51TzZm+ZGiPTx4SSPfSKcOYKMryMguTjClPPGAyzQWWYezy
+r/6zcCwupvI=
+-----END CERTIFICATE-----
+
+# Issuer: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY
+# Subject: CN=BJCA Global Root CA2 O=BEIJING CERTIFICATE AUTHORITY
+# Label: "BJCA Global Root CA2"
+# Serial: 58605626836079930195615843123109055211
+# MD5 Fingerprint: 5e:0a:f6:47:5f:a6:14:e8:11:01:95:3f:4d:01:eb:3c
+# SHA1 Fingerprint: f4:27:86:eb:6e:b8:6d:88:31:67:02:fb:ba:66:a4:53:00:aa:7a:a6
+# SHA256 Fingerprint: 57:4d:f6:93:1e:27:80:39:66:7b:72:0a:fd:c1:60:0f:c2:7e:b6:6d:d3:09:29:79:fb:73:85:64:87:21:28:82
+-----BEGIN CERTIFICATE-----
+MIICJTCCAaugAwIBAgIQLBcIfWQqwP6FGFkGz7RK6zAKBggqhkjOPQQDAzBUMQsw
+CQYDVQQGEwJDTjEmMCQGA1UECgwdQkVJSklORyBDRVJUSUZJQ0FURSBBVVRIT1JJ
+VFkxHTAbBgNVBAMMFEJKQ0EgR2xvYmFsIFJvb3QgQ0EyMB4XDTE5MTIxOTAzMTgy
+MVoXDTQ0MTIxMjAzMTgyMVowVDELMAkGA1UEBhMCQ04xJjAkBgNVBAoMHUJFSUpJ
+TkcgQ0VSVElGSUNBVEUgQVVUSE9SSVRZMR0wGwYDVQQDDBRCSkNBIEdsb2JhbCBS
+b290IENBMjB2MBAGByqGSM49AgEGBSuBBAAiA2IABJ3LgJGNU2e1uVCxA/jlSR9B
+IgmwUVJY1is0j8USRhTFiy8shP8sbqjV8QnjAyEUxEM9fMEsxEtqSs3ph+B99iK+
++kpRuDCK/eHeGBIK9ke35xe/J4rUQUyWPGCWwf0VHKNCMEAwHQYDVR0OBBYEFNJK
+sVF/BvDRgh9Obl+rg/xI1LCRMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQD
+AgEGMAoGCCqGSM49BAMDA2gAMGUCMBq8W9f+qdJUDkpd0m2xQNz0Q9XSSpkZElaA
+94M04TVOSG0ED1cxMDAtsaqdAzjbBgIxAMvMh1PLet8gUXOQwKhbYdDFUDn9hf7B
+43j4ptZLvZuHjw/l1lOWqzzIQNph91Oj9w==
+-----END CERTIFICATE-----
diff --git a/env/Lib/site-packages/pip/_vendor/certifi/core.py b/env/Lib/site-packages/pip/_vendor/certifi/core.py
index b8140cf1..c3e54660 100644
--- a/env/Lib/site-packages/pip/_vendor/certifi/core.py
+++ b/env/Lib/site-packages/pip/_vendor/certifi/core.py
@@ -1,34 +1,20 @@
-# -*- coding: utf-8 -*-
-
 """
 certifi.py
 ~~~~~~~~~~
 
 This module returns the installation location of cacert.pem or its contents.
 """
-import os
-
+import sys
 
-class _PipPatchedCertificate(Exception):
-    pass
 
+if sys.version_info >= (3, 11):
 
-try:
-    # Return a certificate file on disk for a standalone pip zipapp running in
-    # an isolated build environment to use. Passing --cert to the standalone
-    # pip does not work since requests calls where() unconditionally on import.
-    _PIP_STANDALONE_CERT = os.environ.get("_PIP_STANDALONE_CERT")
-    if _PIP_STANDALONE_CERT:
-        def where():
-            return _PIP_STANDALONE_CERT
-        raise _PipPatchedCertificate()
-
-    from importlib.resources import path as get_path, read_text
+    from importlib.resources import as_file, files
 
     _CACERT_CTX = None
     _CACERT_PATH = None
 
-    def where():
+    def where() -> str:
         # This is slightly terrible, but we want to delay extracting the file
         # in cases where we're inside of a zipimport situation until someone
         # actually calls where(), but we don't want to re-extract the file
@@ -47,30 +33,76 @@ try:
             # We also have to hold onto the actual context manager, because
             # it will do the cleanup whenever it gets garbage collected, so
             # we will also store that at the global level as well.
+            _CACERT_CTX = as_file(files("pip._vendor.certifi").joinpath("cacert.pem"))
+            _CACERT_PATH = str(_CACERT_CTX.__enter__())
+
+        return _CACERT_PATH
+
+    def contents() -> str:
+        return files("pip._vendor.certifi").joinpath("cacert.pem").read_text(encoding="ascii")
+
+elif sys.version_info >= (3, 7):
+
+    from importlib.resources import path as get_path, read_text
+
+    _CACERT_CTX = None
+    _CACERT_PATH = None
+
+    def where() -> str:
+        # This is slightly terrible, but we want to delay extracting the
+        # file in cases where we're inside of a zipimport situation until
+        # someone actually calls where(), but we don't want to re-extract
+        # the file on every call of where(), so we'll do it once then store
+        # it in a global variable.
+        global _CACERT_CTX
+        global _CACERT_PATH
+        if _CACERT_PATH is None:
+            # This is slightly janky, the importlib.resources API wants you
+            # to manage the cleanup of this file, so it doesn't actually
+            # return a path, it returns a context manager that will give
+            # you the path when you enter it and will do any cleanup when
+            # you leave it. In the common case of not needing a temporary
+            # file, it will just return the file system location and the
+            # __exit__() is a no-op.
+            #
+            # We also have to hold onto the actual context manager, because
+            # it will do the cleanup whenever it gets garbage collected, so
+            # we will also store that at the global level as well.
             _CACERT_CTX = get_path("pip._vendor.certifi", "cacert.pem")
             _CACERT_PATH = str(_CACERT_CTX.__enter__())
 
         return _CACERT_PATH
 
-except _PipPatchedCertificate:
-    pass
+    def contents() -> str:
+        return read_text("pip._vendor.certifi", "cacert.pem", encoding="ascii")
+
+else:
+    import os
+    import types
+    from typing import Union
+
+    Package = Union[types.ModuleType, str]
+    Resource = Union[str, "os.PathLike"]
 
-except ImportError:
     # This fallback will work for Python versions prior to 3.7 that lack the
     # importlib.resources module but relies on the existing `where` function
     # so won't address issues with environments like PyOxidizer that don't set
     # __file__ on modules.
-    def read_text(_module, _path, encoding="ascii"):
-        with open(where(), "r", encoding=encoding) as data:
+    def read_text(
+        package: Package,
+        resource: Resource,
+        encoding: str = 'utf-8',
+        errors: str = 'strict'
+    ) -> str:
+        with open(where(), encoding=encoding) as data:
             return data.read()
 
     # If we don't have importlib.resources, then we will just do the old logic
     # of assuming we're on the filesystem and munge the path directly.
-    def where():
+    def where() -> str:
         f = os.path.dirname(__file__)
 
         return os.path.join(f, "cacert.pem")
 
-
-def contents():
-    return read_text("certifi", "cacert.pem", encoding="ascii")
+    def contents() -> str:
+        return read_text("pip._vendor.certifi", "cacert.pem", encoding="ascii")
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__init__.py b/env/Lib/site-packages/pip/_vendor/chardet/__init__.py
index 80ad2546..fe581623 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/__init__.py
@@ -15,69 +15,101 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import List, Union
 
-from .universaldetector import UniversalDetector
+from .charsetgroupprober import CharSetGroupProber
+from .charsetprober import CharSetProber
 from .enums import InputState
-from .version import __version__, VERSION
-
+from .resultdict import ResultDict
+from .universaldetector import UniversalDetector
+from .version import VERSION, __version__
 
-__all__ = ['UniversalDetector', 'detect', 'detect_all', '__version__', 'VERSION']
+__all__ = ["UniversalDetector", "detect", "detect_all", "__version__", "VERSION"]
 
 
-def detect(byte_str):
+def detect(
+    byte_str: Union[bytes, bytearray], should_rename_legacy: bool = False
+) -> ResultDict:
     """
     Detect the encoding of the given byte string.
 
     :param byte_str:     The byte sequence to examine.
     :type byte_str:      ``bytes`` or ``bytearray``
+    :param should_rename_legacy:  Should we rename legacy encodings
+                                  to their more modern equivalents?
+    :type should_rename_legacy:   ``bool``
     """
     if not isinstance(byte_str, bytearray):
         if not isinstance(byte_str, bytes):
-            raise TypeError('Expected object of type bytes or bytearray, got: '
-                            '{}'.format(type(byte_str)))
-        else:
-            byte_str = bytearray(byte_str)
-    detector = UniversalDetector()
+            raise TypeError(
+                f"Expected object of type bytes or bytearray, got: {type(byte_str)}"
+            )
+        byte_str = bytearray(byte_str)
+    detector = UniversalDetector(should_rename_legacy=should_rename_legacy)
     detector.feed(byte_str)
     return detector.close()
 
 
-def detect_all(byte_str):
+def detect_all(
+    byte_str: Union[bytes, bytearray],
+    ignore_threshold: bool = False,
+    should_rename_legacy: bool = False,
+) -> List[ResultDict]:
     """
     Detect all the possible encodings of the given byte string.
 
-    :param byte_str:     The byte sequence to examine.
-    :type byte_str:      ``bytes`` or ``bytearray``
+    :param byte_str:          The byte sequence to examine.
+    :type byte_str:           ``bytes`` or ``bytearray``
+    :param ignore_threshold:  Include encodings that are below
+                              ``UniversalDetector.MINIMUM_THRESHOLD``
+                              in results.
+    :type ignore_threshold:   ``bool``
+    :param should_rename_legacy:  Should we rename legacy encodings
+                                  to their more modern equivalents?
+    :type should_rename_legacy:   ``bool``
     """
     if not isinstance(byte_str, bytearray):
         if not isinstance(byte_str, bytes):
-            raise TypeError('Expected object of type bytes or bytearray, got: '
-                            '{}'.format(type(byte_str)))
-        else:
-            byte_str = bytearray(byte_str)
+            raise TypeError(
+                f"Expected object of type bytes or bytearray, got: {type(byte_str)}"
+            )
+        byte_str = bytearray(byte_str)
 
-    detector = UniversalDetector()
+    detector = UniversalDetector(should_rename_legacy=should_rename_legacy)
     detector.feed(byte_str)
     detector.close()
 
-    if detector._input_state == InputState.HIGH_BYTE:
-        results = []
-        for prober in detector._charset_probers:
-            if prober.get_confidence() > detector.MINIMUM_THRESHOLD:
-                charset_name = prober.charset_name
-                lower_charset_name = prober.charset_name.lower()
+    if detector.input_state == InputState.HIGH_BYTE:
+        results: List[ResultDict] = []
+        probers: List[CharSetProber] = []
+        for prober in detector.charset_probers:
+            if isinstance(prober, CharSetGroupProber):
+                probers.extend(p for p in prober.probers)
+            else:
+                probers.append(prober)
+        for prober in probers:
+            if ignore_threshold or prober.get_confidence() > detector.MINIMUM_THRESHOLD:
+                charset_name = prober.charset_name or ""
+                lower_charset_name = charset_name.lower()
                 # Use Windows encoding name instead of ISO-8859 if we saw any
                 # extra Windows-specific bytes
-                if lower_charset_name.startswith('iso-8859'):
-                    if detector._has_win_bytes:
-                        charset_name = detector.ISO_WIN_MAP.get(lower_charset_name,
-                                                            charset_name)
-                results.append({
-                    'encoding': charset_name,
-                    'confidence': prober.get_confidence(),
-                    'language': prober.language,
-                })
+                if lower_charset_name.startswith("iso-8859") and detector.has_win_bytes:
+                    charset_name = detector.ISO_WIN_MAP.get(
+                        lower_charset_name, charset_name
+                    )
+                # Rename legacy encodings with superset encodings if asked
+                if should_rename_legacy:
+                    charset_name = detector.LEGACY_MAP.get(
+                        charset_name.lower(), charset_name
+                    )
+                results.append(
+                    {
+                        "encoding": charset_name,
+                        "confidence": prober.get_confidence(),
+                        "language": prober.language,
+                    }
+                )
         if len(results) > 0:
-            return sorted(results, key=lambda result: -result['confidence'])
+            return sorted(results, key=lambda result: -result["confidence"])
 
     return [detector.result]
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 242690e3905fc3d2bea64f9fed1f46a5a0a00a9d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1927
zcmYe~<>g{vU|^UdaWM5b4+Fzv5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^Yc5+98zVzHLki0x#whj_))clDhA55{_7sj5hA7Sy&R_;ju9u7q
z3=Eo#w**7;GRsnniW75OQcF^kOY(~}8E<iU<`tBd1eYY1q-rwV;*O68smRRFi;us>
z9_AVp?CI~P$yx+*)h)IZu(n%V5IR0FC#Q&ofq|ijm4SgF8Dt5}BOv7<L1&OhJQx@l
zN*HPwN*J4&iVeUlre>yMjS}V*#sw@TtThbHj0+i?8JigMI7%2nyjq45wq}M}#u~;2
z>@^Gv85tRB7#DCXWC&)^WU5-srJ$go0P%rBNk*zdYF=`FN@iZVLVg;UpPpHknx~Ld
zS(2(yTvC*om#)VJ)?!tVSd^FxmWVGdDY60?qY#pj3Kmf)PAx1=%}Y*ID9Kkytw_wx
z%uCgSXe+5KfT%&}Qb<SunO~fcppah#<s=prB~~URfc5+`cC9E#O)g1IQOHlqN=+^S
zyA5VeF-Q|gKUj;7LVA9Ql|pr`Cg&}#%;L<v;*!L?<kVZ7a22;$LCoS?oFSD3sjfvu
z`9-(b((;RP6H9KffE)*j9hS7z)RbGS$vOGOpqS(U=>fU;76&A{@{3k76bUmhF#Kw8
zwu%WYPAw{qNzF;gEQ;~ZOLZyAEK60;RS5O-1V?&^W3Ym!pNqerYp|zdOt7o3YjB8b
zkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#lc4B&JaZEvGfqr~hYF<iy
zk$!SUVo^$JiGF;1W?p7Ve7s&kWf2<#1A{auZ3ux<3_BMi7b6=Z+kXyb4n{UcE=I6C
zN`eAuU}s=p04JzBR7+5xgq6iv!j;9H%~W(HouQVghB1rBg&{Vgmbr#`0q;VF8pbTX
zY?h+98s;qiS{4wwKwu$5Eo%+y0>Kofg^We>Y8bPGz@+d3ks8(-mW52UEHz9EL~B@}
zCNO7-r7+K71|{RdxDxRire?+zmTZ=yD<u*&OpqL#!rsdi46;iyoiUg}lcQ=QI2l0`
zd16iuIAIs$7Z+zH<sedgF*sReq$&)8BwxhAz`#(&ky)ItYhht(smXkc1C}vwaV6*H
zrDdjovezw+oW#8J(!})Cm!POeiDXa-0xCIzK`8@NO4cx>FiJ9TgY&&#kr=3`0VQBf
z##?Mfsl}x^CE)Z7Aw(D$7;bUc<Rs=Mr6k$~GB7ZF23b%g14;d$!b;C3CqFqcr`S#p
zrc9IZ7ISuLrKVI7C&+M+okiRr77vKv1rdB80_3V9eh^ClWDQSzCaBPiF9wyGMa&=}
zP7hCak9eoZ5Z7A*@t`DMoLUlJP?VpPT2y?CFFmy+9w`h2eLej=eM5cYLp*|9gFXCx
zTyF8e^yDSxrru)B$uCbWy2Vvol2}wyT%K8yaf>fLBe6KXJTosIl(CC%aeD^)$A^3R
z#rrx2++t2oExE;(SWu9fmr^7Sau0J(YThlj;{2kL)RZDgQ2EbRBna{VD97DmhXh~o
zEjEY~i<Cfmguu4KT@P{zBy2%}UIYr@B2XUG1x1eqC~%Q8E)yu@axn2QvM_Qn@`183
zGbmGYFf#pTVPauqVq{}v`OC%1!zjQ6HpNeq>y}_CtU`iBQhpJnC}T~{E6pv21S~tW
zK0?$qx7g!Bu^Ar^E+)W+AvqK7)>|Alx%nxjIjMFap<+<n@-Xr+3NUjpa|i(dn1u?@

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5freq.cpython-39.pyc
deleted file mode 100644
index 22e5a3a5b405fb49e0ecd07504788eb717f34775..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/big5prober.cpython-39.pyc
deleted file mode 100644
index 908c06840f9601d6728b3f573ba3eeeafc3e19ca..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1161
zcmYe~<>g{vU|^UdaWM5R8w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj
z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##<6j
zndzo3nZ+eVnMtK3nfZB+d5Jld#hJyLjJJ55Jl##>gMH(D{asvrl97D?Vl#sXkS|Oa
z7#LC+q8L*cqL|tl(il@1Q<z#fqL@=zQkYX%S{RxcqgYc}Ag*p^jACnNU}1;?xtjeJ
z7sz^u6O%zcfEvjFVuQ>F;bI*I28I%b62=;aW~K#93mF(0N|;Mnni*>t;#o`Bni*;s
z;@N8$7I1)MQW%06G#ULgId8ERmlmWJ6|pfeFx=vZkI&4@EQyaV0vTAu3KHW?28Ty{
zac&VPK5mJoAcaDFA}AQDQj2b}7Nr)amaJsF#ZsJ_leUua7H52Xa!z7#aeVwrhF?w2
zRxzQ)sYS&xsW~Z`MKS()sV+sCWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llWuD-6p
zA+A9RW-$Q)J~4?Vx;gpjnZ+fU*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<@nxxb
zDfvbE$r*`7DXAs;Ntx-U1>ktqE2u2uU|?WS2E_x2!NADJ$i>LPSS5@ISv{EVF@hKr
z%+4UKpb$u53}(<|^1H<X(pe<Hz`#(%10ujIFd+yEHy)5Hic?GC^AdAYH9?x0K(WSD
zB@WUDiAz0XHN@G<?hHzi#i_V0=EzCROD|1KPt`@T6xo|Fc})&bgoB(HAAgH0K0Y@;
zr8FlsKK>R@e0*VPVh%(G9B#Kb3X1XzQj1C|i-bXb6$SZ_7aGIKsX00E@el`r{m%zd
z0ty6hs!{?u1C-G@7<t&37`d347{TJ8#K)hT1Pua6JQab$=#~&9$rXdLU@jyJf)nH|
v0gz(k^an|jY`ICv#l^Yc^a?f_$t_?9f!uP7!v^9(I~kCJK#72d5e%6Dn}Qkd

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/chardistribution.cpython-39.pyc
deleted file mode 100644
index 9989d318ab19c9f0fcddb06abe28dfb173338e4c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6247
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
NBH$??42EI?k^rk?1tS0e

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetgroupprober.cpython-39.pyc
deleted file mode 100644
index 03d093d9005783303a25d07060ac0d6458c6a480..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2288
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
E0AGCYzyJUM

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/charsetprober.cpython-39.pyc
deleted file mode 100644
index 1c50be04f05e5e4f40fe090c5e70ac24ac090267..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3510
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
PYcZ(Q;b7!o;$a2=iDZZj

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/codingstatemachine.cpython-39.pyc
deleted file mode 100644
index 73c3104c8aa11cf93fbf43d878fb193edb95a7cd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2937
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
UH$SB`C)G{{<X?~_985gS00B-Em;e9(

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index aa6765a02e38059e3e96530c3401f8a2bb91bf79..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 426
zcmYe~<>g{vU|^UdaWHiQ3j@Pr5C<7EF)%PVFfcF_`!Fytq%fo~<}gGtq%veNrZ8nQ
z6zQcfM=_<aL@}qbq_U<lMX{x_MzN=IWN}7u=1HZnL@}i>M=_^zrLutKSio}JQJg7^
z!3>(LFG2SBX)?WJW?*0_Vq{=o2yxToxy4*uS$vD9EVZaOGe0jrGcPUw7IQ$P5r{Cp
z#avucbc?+-FEcqmCG{3haY<2TUV3~<WkG83EzXkEiV`sU7E4NIa>*^u%#zfi%#zgH
z;#;gql_jagw^+fvl?+AvAS*${uR3R|n9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw
z*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3f
znBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk{38A2jKrdp)Dr#V{M>@X61{@TTO2mI`6;D2
Zsdi$ZPzDhk%v_8tj4X^CAj||~0RS9jc0&LF

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/cp949prober.cpython-39.pyc
deleted file mode 100644
index 692bdcf85197f2c73c3b4f755b64164563a32aae..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1168
zcmYe~<>g{vU|^UdaWK`Moq^#oh=Yt-7#J8F7#J9eT^JY`QW#Pga~N_NqZk=MY^EHh
zT;?cdFq=7tC6_gd70hPIVasKYVrOJ<XGmd9VQXPXVM}FgW{%=WVGm}|<ao)*z`&r%
zcuUeX)Y&`8C9}AsC^M<FBr`wHF)uNvvN*F?lkt|2bAC!@UV3mzVo9oRVsb`iUaBVJ
zEivEHoRUnZ%92#)jKreg)RKUr{G`+(O~zY%&H<Jtmhr*9@xJ~pu0F}gegLtVK?KMj
zCJYP=sSHt!DGX6e?F?y*DU2yhEgVtIsVphXDJ(4v&5Tj3sVoq8H#0`DwKK3VM1kDR
zev2Dy2gJ%`kSCyKGJx113qZJ7hk=2igrS77hM}2h0n<VTMurmR5|(Dh8ish*61HZB
z8isiG8ioZNAej_~U<OS_KTXbCti`1TsYOL>3=9mnIO5|o^D;}~<BLEB7O{fFIFrHQ
z5nr5J#027trXYn|d?F~|s#1$?u@<Ekr<SZ_yv0(Snv=GY@fK%%d~!}=adCY7N`_y}
z&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip
z!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g`tfC{
zc`5lt`pFrIMJcHz`pE^BCYA-@h|(*lEaG5bU{D6d1c<@F$j8XV%)wYCf)uuTF#lr&
zGAN*(L3%;SGKDdiL6gbv7Ash5kpKe&LlF;%0JFe^ASkGKKn^KREs4)d%uUq>=>~-$
z15=d*SR*7p^^g@2XD^#~eo<;-9&U>{auV~>OB2&m^^q(^@hD7zCI=|eLGFu>zr__F
zpPQdjnv)tIe~TwRzOXbg2O<Lwx?3CtMfnA(MJ1I*!XVFzg1pEJjpgLjoSgW0h>O4h
zzz0$S3I%Y=QUbXHl;1fRc{rFDxtN(4!Q!9<C;$oo<U|EYXF`y4R}9LBxsZGaPL;R#
zbCW<iic?D<QCkFxl3Q%KNy){<x!^PlHX6w-U<ZNRa*M+T;z2tZkb^+!fQJzbnE~{b
B88rX^

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/enums.cpython-39.pyc
deleted file mode 100644
index 8ed9d05f14db8ab8feed48ad39c53b63daca2f7c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2675
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
M7vL1&7vKbu062<>6951J

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escprober.cpython-39.pyc
deleted file mode 100644
index 482622ef89f18580c9b0e89515439e2b6d1ef4ea..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/escsm.cpython-39.pyc
deleted file mode 100644
index 7ab2666fb5a0482417f6bcb912a5958ded1428ab..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7109
zcmYe~<>g{vU|^UdaWIunlY!weh=Yth7#J8F7#J9eZ!j}3q%fo~<}l<kMlmunq%cJ>
zr7~tQr!r=-q<~0d%mNa{f>~1;v#?>9daxNOU|tGH9ZL!u$dnY;6jrDxM2;ne1(gpq
z7px!ZDmXjMAc`%8J&HY*DTOVSEtNfmBZV`CYYtl!M+$coCrCBe{UDR!dO)H`7$ips
zgWO99!_9!W9^^M94AKo(0TNGPh4>%DCV(;Y;!qD$$DHO6#g)Pn#huET!kfyK%ALXo
z4Hcdg{wQ9M-wB2aD6~-Ai^EQk8j!ujV31lchQvS2M6BTjNgW_lK{{YGh>Z<{<Utr&
z4xNuI2V=w3fPBlG<`Ko0A`r!&%9|pX%9qNYB9tNwPD=tQB2j`kLk(sYIt?-#8-}aH
z?r%`2poR}f1PO!81iKgHA`ni~h!RR+j}lH5OkqnEN)=8KO%VgTTO>t1m_bwGB_jg^
zgC^rG9^b^|jLf{$;F83WR1F4328JS#%u7&_P{ho@z%XD0$Qc7>`GER-L|Fck1(vv8
zvNA9*ykvrL!Rc?5fM&$efS`9kyaZ=IaOwmnOg2zK$%elqs^ap9(sg&zH8M6dy2b7c
zDo~44HQ8=)C+8#<7sr<*Cgr5w;(>6|5|c~vi*9ijgGyYe6kl>iVo`ifY95r&l9!m9
zdW$0`F)zI|F&$bigB*h28FZ1QPPxnu&+g#h9smLy!vkRNkhKz={zeIgqR}uIh%nIP
zB&m3N$;rULP{r*T?5}HNU}U80><4Mxf+LUOJP0-gOps|5DW&L3Y=tE@F*4mkk~R)_
z!3{4!Un0cNj1mAT2Gyb@McuGg3{Eto#6XlFqXjnugC-a0x$7lp#1N?{^$NJf;gwjB
zn3q~Sgqx-~3s88uMtVq5Nyli3N#d~6Xn8tXo`RYh1C$Ps%0};?TWsF>MX8B-eww1U
zSX1*#bBl{WV_Ub_Jfh;AeS&YX28TEXh1_Cw4GQuPy2a)h5*+XAdW+Q~Dn2;mmLN!x
zhhtE@kE>sNh@+E_>n(1OjBmWJzl*ESEnd%He^7JQ*$-?M4}u#Ua!Ufib4E2o2q6=U
zZj@I5icwwxAa}rw0!d;w3ZxF*DDNN?qr8KVjRHwxHwvT<YSc=GA}vrvf{0(W&Q>v@
z#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5!JdvW!LGip!6B|e
z3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1uF$I|g`tfC{c`5lt
z`k*10l++Ua)Z*mgT)l$ITO2mI`6;D2sdh4;>97t41_mA`78N;01x7hWF-9>)xnC@t
zEKE#{aQK^z9U>1>p};7^sKBW3gM}NH8juQ*X$p)A-&uIDtCC}sV^sLf!htFa09QDg
APXGV_

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/eucjpprober.cpython-39.pyc
deleted file mode 100644
index 66a43465cfa72e37b4ea0c7c5aa25508281a7ea8..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrfreq.cpython-39.pyc
deleted file mode 100644
index 73093afbbc99962912c07836236efb4ba88109d4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 12090
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
J0}B%iGXRmCTrmIu

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euckrprober.cpython-39.pyc
deleted file mode 100644
index bba6aabf201ccfced52dab02e77fc50e5fff7484..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1169
zcmYe~<>g{vU|^UdaWM4?8w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj
z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##@rE
zq0ZhxE}6w8MVU#ZC7Jnoj(LeWmBpFGnvA#jz>@L7zVW{PF0MYw$bJB^nLz}|A0`Y8
z45<uJj42FJOzjM5j46yMOf4Ky%&9CX%qc7_49$#Dtf?#zcQ-Rev9&X>Fhqge&3=m;
zYzM@Z$skWa&13+vK^A~;u?_<RLkU9(V+}(y(*mZ242%pV%q1+%j5Q4LtR-yC3^fe#
z>@^GvI6yKf48aVVjDDJ&w^)ly3sQ@U*cccXZgIrNXXa&=#K#wb3@l;=iE$=_gCxE<
zw+Iv^w?tEr!XZ8p6cAOZMYmXsQj1edRx;jVDNfBvTgiBfGd?~!C$YFVK7J*`uV!bf
zn9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe
z*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk
z{38A2jKrdp)Dr#F(&X%-0&v{w6;u{+FfcGEgJJ^2U|{59<YMGttP(*ATRoWnF#;JB
z(9R&epfE^b3}(<|@~dKV4RzM_4k{90U|=ZX0TEypm=FYo9S_JQ#i=Fnd5O8Hnjq~=
zpqOK-l0dc;SrJhd-(vI5FG@|!!)-A~PGVkqX<~Y+E|R4vK7}dJ<N(Dw$bIqgx47ct
zbMsS5b5i5uZ}G&(7nUaGKxDvScZ;K-D8C@JsHCz;2;^B2kQaHO(VU!`lM^2gaS=EG
z_&`cPp#V-=N+5TDGCT((4;vFB7c&zhSR9lB`E!$?K>&%XB2XaR5`v_=Vo+Ahg=9r=
ys=OrtQjDAkA?cDWHz~QeI2W8~!A2vw1?(V@TW)dKKs;zC19A{3A@DGQAu|A*-y5<3

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwfreq.cpython-39.pyc
deleted file mode 100644
index 1c4f7f75f2ddff3142de5583b5879734e5d31dfe..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 27210
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
ISeRLu0DL^!B>(^b

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/euctwprober.cpython-39.pyc
deleted file mode 100644
index dc5d84ccb7b24e0ef47cd9a2760cae61c886d391..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1169
zcmYe~<>g{vU|^UdaWM5V8w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj
z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##@rE
zq0S-UE}6w8MVU#ZC7Jnoj(LeWmBpFGnvA#jz>@L7zVW{PF0MYw$bJB^nLz}|A0`Y8
z45<uJj42FJOzjM5j46yMOf4Ky%&9CX%qc7_49$#Dtf?#zcQ-Rev9&X>Fhqge&3=m;
zYzM@Z$skWa&13+vK^A~;u?_<RLkU9(V+}(y(*mZ242%pV%q1+%j5Q4LtR-yC3^fe#
z>@^GvI6yKf48aVVjDDJ&w^)ly3sQ@U*cccXZgIrNXXa&=#K#wb3@l;=iE$=_gCxE<
zw+Iv^w?tEr!XZ8p6cAOZMYmXsQj1edRx;jVDNfBvTgiBfGd?~!C$YFVK7J*`uV!bf
zn9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw*Pvj}5XWEzPd^ubKi6PS$CzMOU)SIe
z*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3fnBvTmRNaEa<m|-s)Z&<e%mV%Rvedkk
z{38A2jKrdp)Dr#F(&Uoz0&v{w6;u{+FfcGEfnoy0U|{59<YMGttP(*ATRoWnF#;JB
z(9R&epfE^b3}(<|@~dKV4RzKH2`>_0U|=ZX0TEypm=FYo9S_JQ#i=Fnd5O8H8X)aV
zpqOK-l0dc;SrJhd-(m|%%q&mL!)-A~PGVkqX<~XRC`}YYEk*GuOo1i`DAqyli;us>
z6(66QpHiBW8Xtd)CqBNgG%*Jv0}i`e90f)B1*t_Pl|@1z&x(M&$P10;<kXy;_;`qm
zzyZJqQUVGEaMDr)c^;JEIT(4^m>9X3nHa(1pcKfTn*<F4NL&?x+<Qw1lJ1H@Suq!q
z6~U?UmH<dGaw3GJOSask<l^F7aH0hpjpP=vgFtS%#bE>Spq&iJL7;@d!w7~<0IBI5
AAOHXW

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312freq.cpython-39.pyc
deleted file mode 100644
index 92164a591727d598f99c59a54c72a5a654e51f86..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 19134
zcmYe~<>g{vU|^UdaWM6D00YBg5C<7EGB7YWFfcF_3otM+q%cG=q%cM?rZ7b@r7#CG
zXtJcAJp%%7>@zp;F)(O=h|G3228PVHObiT}i&+^MGHo~+7&1fn85lC}^D!`FN`bh6
zAnpo~x^`X$hRkLz28PV%AjPjigbhe<IS&Iv=3EX2hD=LN28Ndp7#J8b|AF-0XJlZ=
zTo2NFn3;hgGYX_`2T1G=$k0M|28PUO+#o|i#2=9H;UMEHL9$FBVh+gARFK|$0S1Q5
zQy^9uNXaiz28PTAkhUHWaUA593m_d#AO~@ST<-&7Ie{ctKuQ9685myv1Uc;oNZlon
zs{%nT_zxo9fw-<99ikv^8px5;SQr>G*+52p1KBGHQu0QKfg$rK$W`+|ic>&h8X#{~
zf|Rg<Y}*N9>40R#L1FL(WH}c|!WE=0m5G7j<xY?@rh@$ok_ZCncmuL%GswIekhUO@
zFaLuqS_5J|1ewAFVnu+6cObo4Ab+@m3}^v4R|;gjHb_SRNQ{w>f#Ky0kVVr$hBAYQ
zM_^a6F)+Ne21#51c`z4b@@<f|9FVq$AhEL`#r+^+0yhK0%jqD+av*LhNY(?SZapYI
z=71c20>o+rxgZYYf^0zshD<XM_by1W6375IkO5agvMWKZKL>LCcMuT=^6DdyL>Gv=
z0u=T)IT#pT-UR8e2L(w2$c|EwgbK)!h9Kjwf=u}Yk~j*|t02O_kQoZ%z6N>55F~a7
zWch56)6zkDb3hKd4RSaO$RC^_d*^_ZxP$Dt12WkN6ga0rL?KA_E66AX5H|p%cLzwF
z4@lw$$bi?Nu-^u<QUWAf36hW#WMFu?9pv!iAoraBIl~tudlKY~Y>*u@KzdC;ikE=g
z!Vhx69*~b7fGnB`;);R-q8p^d0YoH#v~2_trl6E_1Z4avkX}EKy7?d%n1i^+AUn2z
zOvwX@$%Dj7LAJSrT&f0geG*741EkIX6eKf29`pq{(hp?31W4=|$Vx7dwnz}`1jru`
zL5A)FWo%xM<@*^K7+!t_v37GYFuYU)vCe|j1%gbG1+mOQ{)hu<%K&-*I*3>ea)B4f
z$|)dj0LYQMK}vptY`X%|Q3R4$3o_+DNOloOhZKnW3goosAR+|hDqWBccaVe*NL?vN
zuQ13TFF>;ILB3Q0Nw9*HOamEe1JdCHQYQeCPyyL%2MTsRkfAp~>MB4^^8qOd2k8(3
z1=9;*28PT$kYYJdU_S@3LO`y12C^dxWau1_lJ_9liy+IZLCz2c>HQ5Vpmu`9)`N0@
z1SpsUK^Ap_LdYIu(R@(&8Gs~`Kt@@E0@ek@y$Nz83n&{L19A6*v^j&U3<hfhu|h#^
zu>%=j1CmV#>39vYd^(7=9VGD#WRW*J1H;QVAXB(N+*Xj@OCT?Ffz+vj9Bv9CmV#Wc
z4-^_wAmR&1T@ENnwt}q80NEx5GC%@k+ZB)!dr)%x3o==nhk@ax0*Dm~(l(EUf#Ky*
z5O)*E&}ksIYy_F21v143WZMjoOZR}x`vMY^1_i_~kPdc`*kh0>Z$ZRKkm4qgZ6`qz
ziXfvRKw>LFV!a^ar+~!vfm{^`GBh1zUO&ihk3a?-0ulQ`N<M;IPz2Jp7i82LP#9bQ
z=_my0Z35|-1(LWAGPDY0$6=5}4@j>u$g5Hy_gw?&xCN5f2{J$cq;4`uTP%p146?im
zWTh~O#R9U@92AI0Kxr)=B*6+wTrD6mXONZ4KuXj==_L^);Q<n>0hyNraw!+cw%H(U
zwje9FgA{jx+~)~W8~{>s7o_+)D2vyDSQa342_VbAf%KMxT;B__?E*+P1Z2Q$kV|)f
z9DW?6WFkoKY>>9sAd?S(B)ULWvVp`Vg2Wm@5&971{b&%k5R{%5fw)W{CFenQq=O7y
z1WIc)APHxX)9OJIQ$RXyfL!1QB0ND(I|`~p8$tG(g2X0(oTdRX>H|odK8WQ3GS3?%
z!37Gsg`m8^0P-{&$berUb(SD?2SMsQK}0iH0wh)g^5thxCASacmb;)Zy#eypJWvMX
z28o4()bWFe#UK~#2l;n0$oM!=rCA43!UWPL4RZZ_kjaNZo|ym&Fk6t02$0xpkVVEI
zZC^ny^#m0KUqE7lAoJQliTV%7r~@Fct^kQ$0};j`qKK7&;blEY_5#Rn_du+CkZs%`
z15SdJd;nQg4f3i4NGucNAZL*KE-^4Lyi^3~@Brz!0xFtMfVdw(+UA3NnFdk<Y8z(S
zf_%;nk}zauV0ak~Qui3-j~bBiE+9k2Kz68td^8mlBqboltss+EgOvOO8SoP%p#b7;
z0L6zM$U*Btxk3bFo-`=pD?uy)khTzz0b4=D29U{?puo8TGKB+VfHKIx8$pV<fGqa{
zh1zG3SRP31D9CsrkZm0x2g!r9-3A$I2NH7v5lW!s^A<$R1xX}=LiY{GM=wFH@&#Gx
z4KnWn$UGhpHyk9p0c81OP&9r85sDy_i$E+lkV~~etPdcUa)1bKkk}WH-U?7OdVq}b
z0y*~>$g5XC+>0RFnm~jRD6M&e#9o7R1c6Le0eMRv#I*z&H4S8F35d7>^42d9>k~-g
z63A7}!VC;A=YkCQ43d=s8M+PRtz#grAjsYcAfqOMysru(>OgvLf=o#O#r`yq-bWy9
z7eU&#fmrGwZDk;BVqjB1#9L56>;#2c4Tul|B^7m$UT%;xrh=5@feh6G$<75CumPmw
zIVgj<fehUSDymdLew!n}!0=KNq_++vu^6O;2c&m1$bC~m(dY#dQv)e}3S!BE!bK6p
zask<P38bzZWQP>U-e{1?^&s2$Kz?fn#m6I%I!O>q9Yh=i5zj$|Q8vh4d62g6AjO;@
z)-;guA9xuUULFF;9s`9bKZtb@WQQCmTyBC~x&lOGfMV4NBpVNEJMID5YY%b|Kghgv
zuo4jWF37p+Ag8s0Oz8nh>;Q#nA1K@Z1962wmTv)Rdjn#1fYix>B-Vk{O#<a}Q;<cm
zAkX{-Y2yZ|dk!-GA4r=7i2ECqIp2fSO$CMh8IU?dkbf6~WHmwNC4#sDAP1cSIp_h%
zfFB?UYmkHtNXJc(-guCb2O$5>2PMovkfHh@SCxXI=O~C+4I;8YmPdmmzJT=Bf(-2g
z8OjEd{R*=89Z2>%$aoQuL?6hu^&oA5ARTcab<Lola|e4BWO)^cbrIy%Cm_X*AjM%I
z!XISRDUhK;AlYvqb)6u+M?ey@Kw`Ndu~HECC&)@OkO6l<hQ0*J>Vm9P0dfC<v~2(x
z6$EnC8IZPGkPcoDs{o{=2&5wxlp^+l9O(iI5&@7lHjpW8Ad{bgh*l6c6Qn}~q?Zq5
z=yniyHpm&0Ama@|>heIcS3rtif(SuS=~Dudhy<x~2U-3PWaW2|9r_?v4JdDwfWqDY
z<o#BVGde*!j(`jm1evl2#Ek)&d=Vsj7^Lkz$nr9f#95G%Um&p!AZ{{9+Y%5V2C{M=
z$ffNdZFQh{a|CHq0;$^s(xwD*kRm8$TYxGIXOJ^2Kw``w#m7LbERX>cKp|uZa^C`w
zwj7WFb|B;LflTHHIV~2%>IQjh8%S{-C`lavndbv?iv~zrHz=*02D!i+M5KVM6bDs6
zWgvAfASL@i#C4GICqaZNh<gL%jAx*jxeOwngSa}NrlcT9n-NIeWstfSkPBvlY-<K_
zvp~%cU62wzki*}DLMRtxuQ$jPMi6%&C^LNqDai+UK>%d3HApchNcIOv@lBAAQb6W8
zfC3^B<Y{h@I$scB2=b~A$XgB|XBdGLZv<&82NBCbic3J+0zv733#3FJWc*H$c?uxe
z3n1A#5NkKc1??c${{Sgj35t|HkdO31+RlOO_yV#m9%QdF$oPw(Fz^St{wK&3e~>zN
zP-<!eiG2f!WrGZj2ASs%(vc6cXctJyb&wKWknzHx5^gPs%K)-`E68|7kWuqNVel2?
zBTo?bEJ*eyDCm}h(ndAN&?1nbO(1o8Ad@pdMfiM>BY8j)At2-BK`d5K;l>2ALmlLE
zACQ%aAnqoRwjUrJ4xp&$1&J*L8GjOF?+=g{-h!+=2vQOP64M76x)r320pzNqAmiVF
z+`<j=Y6FPy1-bM!h{yyf&H-t=3sNEg5_<tMsv5+y0O?f*8MO~2)&Wv-2V|usD6kiS
zoDmEX3jz_dK-FhC$bFMR+$fN`uOOBI$PQPKQR!d;WZO27><>`-0}aGwUIc}>4@mC?
zko(?&5<>yV_&uP|I12J$Fi5W?$QkoMPWuV++ZB++6Od7xL6PDBQoI|a&J)D-0m)i}
zEcXXFqY$Ly5lD6qh|mNnkpjhx7060A5HSJdRZ|e*1>&ZFOm+kra2%uqG-jBo337oe
z$S5CBd_;oWyb`2i5r~)ovgi#+NiN9vIUwWTfFz!QSf@e6ZIH>wK_(}I0%8qFM-a%X
zYe2471Sy^lQnCTW-3uaqgA&6zkVP6Gbq7E?Zh;Jl1%;X?NTL^{?i0wRpF#FM1DTQv
za&te(rJ^8i4@k*GP==TV(s2kRaRy{c0*Lhmq?j4xzFVNM?*_Sm4djnapg@cUh4_Au
zI%kj_8X#=}APF51u>j<cT9B*!L6)n7xIQ3m3`p@$kSRYvVzMA&Imn_0kO86~^P)iN
z?txe>psZ00a-=#)NejrRP!MYo$nqN?FB}A=x?><QKTwc>#%41&f|^IuLFOF>*|r^I
z$7+zFz97XHL3*Epj9(1$(Jm18J&4;5N_y8o0dW?@%>)_n6l8fih)@S9-UuRYg1BrT
zx4Z)>;R3aWmohLgybJ*8H2?)zF-SHOr0xeOdI~_?^&lb-WU>s%;eDWB`UK+EgLK4z
z#Abt>y9&f=1L<7{;wpk1o&hQfet_&a1+pU-q(lRxR}G|>3*-!Ekl(~X+MGb4p$TG{
zf~@QYvF3nkjZTnWX^?+6fDHHv(jft|<1@&pTOcKNASHi6R=x#!YZJ)I4InWdkd6*e
zc0LK>R)bvc2eS7b$ao2ml}w;ucLf=53~EKnf%JNT6f1+0&k~Sr$slzLLB{U{*~<Yk
zR0R}o??CEILC%;1Qc?j5XBm*+VnKF%2H9~AB$3U}!0_@TNby^c>=lp!S3wdhK&$|e
zq4Pn`5CgH8L3-IivPB?QodQ)3J|JxyK|~cuM+!)y1!UVykYZ&J>n|vEa)8`&0;D7w
zlzf6gE)W5UWq_3Mfw=A<9sfbb?*I|}AbVGVlq>)l5DE%TZIDZEgJPi)RI@Jzamztg
zDuE2x2~r#e(rX0Lp$0Oq3PhX%={N@>wu87{AkPGVxEDag5m5NGfl|aBka>GSTvd=n
z6v$*1kl*q_ZVmylyg^yW5X4#svST;M$^=m4g@ODw8>CJcWWWNDk`z!;unT19HV}6+
zNMbk0rP?5En?Z`NgTx#`Vm+XMcn4C~3o_~>$fZpnSrw4P7LbxokgMWBdW}K8i~$+Y
z1#;voPyzwXu)KT@vTY(rTM|fH14v04D3ZT}B=&<$z6vtA4HS7>K>^_i;^u)&kp~eA
zK}Bu_D6Opn>2L$-_zP0!4^kHmvV0-PEiXV_OAU~c6(BnpKn~&s$tr_n%|Y4J2;|%f
zkTxNZgVI3UBOu~DDCiVH?lS`s)u3+BS&&haK?X#E4Cn)O*n~i0-5@b-kTceTj9LJ4
z<Ux?wN{~7QkjYO##B`9@6_C9@Kz49~xZWTgsUX?UpnzQgB4&Xs4*}^_0ZD8J<)ao5
zApx=@1LPTYkTy;bHwcu~rh!;XL4*>>_@y9I=7N%A6v%xFAoJouVlzNaa{vYGF;Ln~
z1ewAPGVdM8mjWOwjX{bxfPym{#MK1Zn+0;|a*$i(Kw{h=i&8<Xi699vkPb(XDRH16
zJ^~V}2N@6!^5tug9e+V$8K6XH1(K)&5t<;P1td`e(z^=eszV^#<Urh+AftFdIxIlk
zEKr=^26^T_NShqU1%E&;Fa|k%F32KY5Vs1X?E{D?06Di3B)c5s^Xni}j6ke>P#Cy?
zbl8GSc>_v%dLWbMf`ZNxq$ClfEe%9W1}V`3vEo67wu1EXf%IyDY?}e{8xu&!V^A2Z
z2RUsQNXHzIZMq<WAEabENVXQFcO{5B1ElUINZWCcm=?&qZjh1^P?0ek<dzbUgc&H+
z6@s{@KrT20va%Uu{5ufq5r}ma6n=dmqk=(76hKC`fmr>Zpi>0drU`O5ABd;~aVLTd
zJp(dS5)?uVAV+3_v@HQ?TMl9!2B`}Jxxf=-$7B#|3W!JtIh+|3M@%4leLyA6J&=+u
zAX8dF+yao(TtKp0L98B-#4Zrg3o>36L@WjwzYyeRUl1_|q;5UPlx~olRY2+a9!SS!
z5U~wpuPew^N}vQ13Su1uiKT+vA`Ifzfc$X>#0mtNEDSPgDTs9dWc+WCTev|wwt*~~
z3esi>A`XDW?t+M8AYvJ)cvS&~ivlRDVnK$QfV`>(;{F9G*#Hu&0*P$}8UF+%mH=|q
zXOOqbK^83lnOqOzvVsU<5OEqLrU^=1svwpcNNh34&<h~*)`7HXfs9%Ka^F0VgawFY
z1PTp1P_hUH>17A8&VbbI1L-gXxj-4jS`7-O?;r_Akn!h1-d6^>N)Qwz`$1xRKt|mF
z8OjJU{t`%s8^}CykO8tFy*ePpcAx;$2Dyp{B+CL)w+UoX6sVzO3<{h=P-}A)h;<dD
zL<M9(H^_hnkVRo2i{65avIa>^2HCa%<RCv#sGSDs%?0W829-YHAd?q>bnF8arTriY
zQ;<=sKt}BXwLF4AVkRI{?tq-;36hlr`NIVih<8D(!yuEdfo%H&(sl-<ZVrg`0p$8$
zAkXxGw6TK-RS?%3<e(am<pLm6rh@b?2YIFwGyuC5WaTSRaWfgjvIM!W9i$`=<gH~O
z?njVOuR(U`f{Zc-S!4v_7J$?VfMzXOL3-^$hVBJ<wGO0X3COu?LBs)&k3NB1a0aBq
z86>+JL_~vR*MnGVLFU~DDR~ES^KOv0j6p821KIWjWIztc=Zqjb5<vc_0Li`tIp`9|
z&@CXbpCHA`ASE3j9e+Wxt3c)%fJ&N2AV>ZM+0hRo?tu*O0V!Ss()JJJj6jfoZ-Zom
zKtu;f%pT-O4Ul=cAhAgxA_3&w)1Y)}3{oNia@v28GsHn$HIVFP5Frh60UyZtVvxx$
zAa$!jMj3!CPXZBXAon?dl&l7EcY?U@L50E!kkceVI&48E?*RpgJjhTRP}|}v$TROj
zwyg&F{4GfFDG=8TWThmCxCe@gVvxyiKvw<*5wAd|1cSVA24vB4klsrmLoGmdM1fc*
zK>l3@BDR1OuK^kL3uMX*kbi%I2oVr>8%Xg{kn95x>oLes8IbG_keDCH_(LEcwSr7x
z1u5|X8QKM6d4VLRfOK2|xp^gsn*`D;0P=4-NQXE`_6^8Y(I6c=K&&YsLq$NuT#&=X
zL99BE;*B7ar-MwH1R@@T6wd-FNduYk6~t`>v7|scgg_D-L58w{{E+}Mzyu^~3)0&S
zQqm40Zi0v$P$1faBsxJZO$LeW1?i9mu_l2Gs0T@8f(-o*l2`>Ysug7A36N)&f`|>E
zu<rngO$Dhd2kGqsxp@+Z=m2R`1u3ZqDOm;Lrhu%B1BIkENXbW#wu>Nb`#`c$prU0p
zC<(ZMxSpWc-v=_F1XOaZ07*Or6)5^3)@hJYY#@`TgA!pSh@}P6Q4BIq4Mb>z^h$zc
zFM#~32{Kd!6dxNwvJXK9tOdE?2gofvAOo5};kO2)E)^vE66ERkVhjwKfgm@>g2XsL
z;lc?Dp?Hv(IY>+p6dDGgo>wx+X{8|JUxF<E15)e*vOF8atp~Yp7s$%HAZ{DTX$wGA
zmNG~iKd9=R2NDwi8PEc9=?jpd3qZ2RL9+HBZFfOU;$<K)4v_n%gAC0BNeF^iM?kKB
z1@h5EkVTvzi4P#ZwSnAn669PD5O)cPhy+<Q2Sk*DB$`2rUx3134v6~=q{IuP?K;S!
zc(A8ITs4r-SAi6N0kJqh7TpEedjP~;1yT|P5>o}0z}+C1&H$NL3^MN{$hKgRIvEgG
z6lAC%hzJ9@`8!D43y^IuLH^wXQhX0Y7=mn52ZhFcka?>?2DpKA#DHuQ1i85eB(@P`
zQ8-BPTTrB21Bumu8qw__ZNVS|!a=O#Aaz<Gd&NMkAdp*fK#BuEdX+&g*b4FyKZwu;
z*-;1z-A$mlyalT1I6<cD02$B<iYOBhF&U(78_2nbK>k<<GU^|Ql?XCrJIIt@AXf>1
z{MHVt-W@=Oo&uQ?0n(NUihWg3Ie8SsJqR+-0;I$kB%uRx<WG=9Ey%o0Al5OE#8Xfj
zN&z{j0%YYEkdMxR^eTf`GeE&)29me~3Z^?C^YlQj5(T-r9b|wb$f#2wiL)SWMIhEK
zkm4yIrv-s*O9AP42lBogNQX8^$#0O@IS_FI<h0o!v1(8tR)b9O01^K|E|3OE+y!x;
zft+y=L`(tcI14f=8Ds!6NF6Uo?=p~W_d#K`6eOVoQrrv5gPtG<T?L6HgB&gia@v28
z!+Sxjr6BYAK(e+V#rr^FULY&=Kr9`QIy;b2tROKN5NjpK4j+(?R1gsh^4kQEgZe=h
zIfJx)18MsWQhWlWL<<yo)*$!sg2dK?tW*FI8$d=CfRs!J>3s!?-~Av*27$u<BuK&%
zWZpthKs17s2!h1^gIH%lti2$g+k;qEAUnQ+LgO?@$48KDfgn57L2fAqx&9%DRSr@d
z4I++#4BZ8i&;_}^0mRh=NlXW+dj)C_`GV5MTaYOaK@vYe&fN)O#e&L`T9B+6NU;OR
zTf88n*g&$OARX&KiuZwJXM)7^L9%;5Vv9hs#UR_(fSlV2l5Ga5%LZ}n!LA3Hrvp-A
z3-YQVNQo~<Y%WN44#=o!ARYQ3iC~bD6i`ur804U%AhCRqm>I~tY>>KAkd9W6-mf4R
zbbzu@IH;*s4bmY8Qc?j5$#9U~GoT1K3kp9`P`JDXNpykSTmdp54kU34<ozCy-e`~=
z+91o#L0l`4x;r3KLP6@Lf$Uujic3Y1z4Jg8tpJH#1G!HRlwmzU@fHH|+hGt92_ja5
z(!oQJgapWV29OR1kX|K_Tbx0Qp^8D~v4dn^f(Rav5_eGVE(zp}W{@+?K}zaCZqWnT
z778+t0pzMekWmXk+8%&ddqKWz1SzftDLDob`voehwt$R^1R13da%n3lKHh-LTLf~X
zBgicsAd@eHlxTspS%D-hKp8?EWav?lZ8Jfk_5-Bt9Ed9ma;YPT6%S$=fYiMO$u@%Y
z9tIgz50c0PnKun2<_!}246<lG$f!vm#U&t?7RZ#<pwL|c(s2c(WCBR>OOTRdAc?IY
zb=yE*eF6%cXCNQV1IfC8bclnza2&*C0NG{-(z^}B{RAS)KuQ=vrf`9L{sd&aIw)p-
zf~u!5kWt$};c^UQ%2SZ+X^^%BAU9`&jA91q6$iN>29%^^K&9<wkhbk0+d4ssP!Xhr
z8zlPx)Q;5x$%cY#+Y2(~11M4&K*rAonal=aRe?fx9!N(F$bD%b#VbJE4v<loKwgyr
zx#b9`QS=sMUIWOsQ=qWA12SMU$bd~C^KOB}-htdF12W19q*n@LF9%4+I*{x)kfC!y
zzN`khj|F6&ElBSa&@k?K5LXSP<R8e&ccA1G2GVvGWYii^38Dm2q6o6%49KP5K@u$>
z+m3>Wk05OtATe7IcR$GTuOM|#!34-6OHfG4fDE_|@}&tVND@I6^Kp>L*Fjuekh(xn
z3vUugYz|28YLK=YAmejEu6hdc`DBo~RuK0Ci0ceevI#`20!f&Ih*}W05M+@HD3_Ul
zxNkurSqd^)0wi`5<lHkL11^DrsSM;_7LeY3pn!D)$-V$dl!7D@K`xjJ3Ly^=Hy>o)
zDUcW!NL>!d_1+-Gjv($oP#9bX8Fe4TtpdrKfPB6i#8m`o^8gW3LGjTF^6x8<t4u*k
z*g^Ry3#9iNC=e4shE4-<dqAP#1X5xJGTt9#Xd;L>0}@jPdG!z|J-2|2S_;yZ0?PZs
zAnsa_FEv0W&j6XC1|qhC42=V+%LVy29VF%oa+Ng5m-!%<J_Z@D0n+OZ^0W%b00)p5
zGf15$NUsz~Y&S@WBPdAZL2i)+rLY9h&~60Caz>ET%t1;XfE4S4ywwk~Lj^?q21VmX
zkhY~DZU)GdCXff0fh5{N+Fpa)5(;vz63FrpP;!(7nfwT(<R8eqOCTM&pvGMjNa8U_
zn<7Yp5yUzRa_I$-@r)pKOF^b6fVj;dLw!M3P6gR<2NYnfAOoI(WP3p|V+7(Bg0wvc
ziOmPuVF?mj4&pup5tFzX7+%f?iA@A~Pz+@6YmkIKh<F4dzJik82apm`km3Rm%K@Y~
z0%Y%Zkd7>n5)P0=CMYW6KtvMA-j|@jJ_`z=Jdi(FKtvg+=PwFU{2pY=J&?M5kVW~R
zz&Qw#kOy(gK*UE-7@P)aGXSyffW$08#CcFasDNDX4ipAyAZ{=yrmH|)QINfSARR6s
ziE5A|AAtfa0#s@K2id^{viuXsX<;B8#vr|sAjK>oy|+Mm&x2Twpd#`bNN*R&ee*zi
z=YeE@fgD~4VugZCnF~^E1#%EG$YdjsBeOuPwIEqGkPBErtZI;w*&yyZ5X%i@<w}s{
zi$I~)1`?A7nal`cT?gfgMv#@aKsu5^hGv4&WDrQ!8f1AkC{i*&O5TE$h=Gi{406kC
zkm5)X*B_MDDnQ)-ATLyb6i0zPZ38l(3}lof$b*|eF5m*GYXPy|gJeBHhPHufoQ)u^
z3CLt$P^NnXa`-inOYeh>S_3j531r)Jkc1eBSOl_{2jtv|Aa%b%-tPm&r89_o9AwcM
zka>-uvg8=Z6n~HbZ6GTxK(-wRiJb@OxC?Tm9!Og(NP+`oR2Ybx3^L#{NOnEQ1s_0S
z;vg{(kk~SiGeSTvxCqjA03^ErB+(A?ksU}KFGzM5$fAiL%Z)+mSV2j&4-`yqKzT+7
z#99P$?nw}l22wl;6t%xWdWAr)&jGnP1muEnkc0<_r3X^14pM9fYSkBjEWZpQ4uE7A
zg48L2{MG}~y94AZFA!@bNbDIX0zQI>GLRRHK*UUtd7nY<69p-*02#mpVi|$Nj)3&0
zgY+tZj5h%hYe7n$gJdUyyt)!(-T{z<`a$ZdL1I-P1G+#yKMG<k1Bq<~*>)JD<QGWn
z1SqUFgUn+B5ltYA?txhLASL`D<FA0y)qYSgHGy<^fh5*|OgRbC`xvC-0LbJOAXy7g
zQPm78W7mUpxPmOt0=0}{K-^s*y%r#C79bt+pfscaBBVg`Bn==X{2=oZK*U^7aN2>~
zk_7T<FeoZyL6LF}RF3ZfDV_^5{uU^`h=EMr3-Z1JNZTQh*i?|~e}lNLAUigK#2$c5
zP60_Q1DX5>B>N2{W(Z0Q6G4VP1^I0s$jUrW3m&vbEAukQ_-`QFPJ{G@fRu=Vlyrg0
z;=3Sir$Ckmf)dv)5Z4(Lp$kD`?I3%-L4-BPwrmh_5M<t4kWm*vmcIm<cMzl_9^|SR
zP)MeNj28xpm4k>EAntjPViu5RCWE-XAOrS;bm)O}6oCRK5o9teNa8q%SPe=RZ$J*8
z57My|6zt1E1}p>_^$(;Z9mL%M(slskNOh3nMIdzxKqj+-ydVw|TMY7Q2*_{ppfX}P
z$jv4o1M)$7?}HRi068N9WKku^&2vCv6(Du8Aax%>vKK%O5&{_?3TolSfy}c48Q%wT
z&{UAN*B~qZgT$CY+LS;6rVO&<8c6mwNR}Jq(t42W5|E)+L9CM?;w#8XKM*Sv6dJuC
zy?;PD3P43EAILT(kmb4{iTxluR)M@V2PDx3(q;v+=nTj$d?0m_Aa&P3cAN#tz5;n>
z1&C+_iFJT#oGy^waF9{FAieG&Z9X6a+CX|6LH>0I=`9DjARnao1IQo!AXDT)+I&Ik
zia>MaQ$ez`K=Hu?lHCtt1%k|b3}ShLJnaXvQWd0*7ZlDBAa#r&4>E&T2SMhUgRHy@
zA`(FoKR}l61?d$9br61o^!9;VuMRRf6QnHzq+}gPNiE1NejxW%f{eEZNtA$ynIPgP
z$aoi!x<4QXO#|tj0dmkckfBpR9?Su;{(@qm0c3e2h{Xc3jUAM0PlIGrK?Zn%qNf-n
zYXmY%3uJsHDEuyi#AboQ?-$4!?H~u;0vW{vviu=Pq7X!MfJ`|Fa)Bv`TMKe-F-VCD
zs8U}868i))U>3*#Q;=7kKz6(YsXGsH%MOrRltDUDK*kq?WNSf&UIiIi2U7PGWQrh&
zNCFu!3#85;#L@>PnpltlD?wuGKzd(+d>ISUYXmAcUV~(1L7qti$(n;qnE;Yq3u5_$
zBzQq_6a?bRfkHzWWU?H{lxUEfyFulyE69|+ATAHcGie|t!60qFLF!UK0p<oW;5$h6
z0H~?<52V8xBpU`&YzNZ2801J+kk~7bVkeN|-5|H{fDGUSxy2A9W(HE63ksa4AX9`v
zN;pBpA&^^^gTx+#)LjDUC;%CM9~59RAnr@Bt3bhN15#22B6fk4)PN)+K!$dJ4A=`&
z{2L@&401~<NJlKleX=02_n@HL22v*i(t8M`R|4cne~|2RkZsx^15SWE!wh0EfQS<y
zM=k=n{ud~)tw7v~ASI3<*)JfjEXbk@Alc_2)>n|_8X!BCgNR&^9gLv-VFI!|0F)bN
zf>@j&d-Fg^bOFftxgZDSgSh#iLU0{Oc0S1UxgeGph^PeBB+?+g^&mqnKm-FQy<7x|
z*?_o*K$gz}xylCQzGRR~ok6a;407K|kgOWW&~lKKyda5pASEgwdlf*=wFIeC0~xRh
zM7#hg(FCQ~1dt0lL3Z?jxN;x^?t>Js2T8btB$7a;xPt8c2GVN<k_`k&<bzCc0|oJV
zkS|YxoN*qcZ63(-#UOj#K<3qe^jd>te}Kd$fRwO;3^fK3CLmK(L6)Bb1%wsI(|bS$
zB!hg^2ePdIWUm=WZw$y@XOK~AK(YoP!V+Zp5|G$okX!bEY})~{_W{VFI*?H_K&Hrp
z2qloZ43L%cLF#^ji1Q$4yaB1x1Q}ls%3Di8+*crzw}34F4zfrK<bsJHLj^$wh=XML
zL1L<)5~LesJO@bI3y|VjAa(2@Vlzmc9?0G&ASKH{PO}8r%L7t;0%T<mNa7|)-CmGw
z`$0;CK(ezzEG3X)MUa)hL5g)iR&EDz(?LqSK%PzqX>$Wf`~q224+_q!Aj_|T4E+dV
zS%Z9;3DOY-vdtAl#DUVJBS^_Fkeh`-VmTlyO+i*(1QG8+#y<fWU;-l4L5jD46pMpo
zvq2WgfDHWua@t=I%LpX#1Vk(WIj9}Pk_AabfNV1dl?-B_NbUr=bOlIBHAvzxNSzai
zr~nyn3u+mqg4Ah%!~{VjEIc6YIglfdgX~oYY1<CswtzAsXoGxa2T0;5$fXRR_TNd6
zrv*Sh5(F8_3?k-%eB=VMHxtCo1{oj?V%-KwYzDEefr3*P#L@wU^LvouRFIfCh;<H>
z*(ZS9au4K%2cT+99>l#3vUdVVEDyx01t~578EOvVW`QJDfE=_46dG$l&00&4*i}%_
z{RFjcZh%bb0dZSE-hT<=8i4c$fGocPviAi@Y$`~}3y@v`kRxw^LdYK+GaxIcgWU`&
zK|X;Lhl2ESfqW?o((w$W*aoETC&=Vpkn9l<*9&CSLlCzFB;f~Ad;}D9njk_BWT+lU
z_8BOft^}E^1qy6okc1<s8UF+%Rs=FC7UXG7kd^B|E|molmq3QD1R3fMvZw_l8xL}G
z0f?0i(zYCAUKc1c@q$7~6=VuGNa8LiOP&L<?t_f70})9eZSkNa5C^I&>_L{xfZS&V
zvM3VdOBawjRgml&knAOpj@=+DFN2&R0`k^>km4qO1_sbHCqrf=NURg2t{Y_A6Oaq8
zgB63+?FO0G3vy%*D7G9yhW3M;_5tMF+aMi(Kr9!K4kwUNlR;cAkXs&r43!3P9YE?d
zKt`2;+;S46?j?x(71Y5`2O0VZq@*9DxE5qo8A$Ik5NisE)d$k?4W#!y$Yc?a#Cwof
z6Uh6lp!jG8v2KA3Wdg}IfVli1FH8a%a2mu_01>(%C3PUZ3qeLzg7m6_l4t|S@<SkB
z#)BMm5EKwwKt{2EOgRmT!OtLd>>xL1ft2`yjM@fLw+f`h9i&(rWby`(Q7j;P4}zM0
zUqFgKfy8cs)V&80Vj%O3L7uh-IfECJ!rVdXG(nE+1{oy>l6?j;ZyhKCq(Ls72C{7?
z$X;%cDJ>wy0w8r<AlaQDt`3Os1i7>sWaS=^GcJP6V+QGs0C62bN@74RI1FkJF@x+q
z0&+$G$dodW@ee`j=7S6f14%G~bl8F<=7DTm2qMftifup=CqRyj0CBlNsq-L6Rs^J1
z6y!(?kc2LX8wrwV0EyiO8NV6C+6>aW1EgdYC}5X>+>#7(eGf?D4#>&{AeUN#Qr#wy
zDY~F^Pztj51E|202Z`+mh0qp|L=ecA-#`}efeaM_`P>YoxB<j^1X4T;WM~G6RSR+k
zH%P)Bq@x^UfB;C_A&`zIASH<)^E5zW(?KjbP(&Gm9Jvc*WiLp_Igmf>K*R))n=ga(
zZUQO(3(~e6Bo+&@;~2<}2#~rWkdFdDgaJsM4k(D3L9WsUakD@M%mr~1K*6~T<jC(J
zQ_h3bNrAX}Ad~q(28e<r7(gcP0@<Mka&tIHi4#a{El5c{NTLR0lsTw84F$P=0w_2i
zfJ#hB5H}p8ZZ3$31bJ&Z$dP>@zg+}rD+d`h6GSk8Ol}1^LlWeINuY@002$v4(z^sC
zTME*91H?@N`J)S@xDcfGBFLrlKv9+iQt}q$f_4yVGN?M)4H^-#1-V59WbY!7_x(Vo
zc!88m0h#g~WKk%H`w-+vF^~bBAnpN>r};p(Ee1tTCdd?Tkc1A1*bX8lf}CaoGPDTf
zjB1eB3s7K-f(-QlaW{e_3P3(G1#yKz5{p6FY(d<sAUiIDJnahNT7nd>0}<9BdwD<s
zYXh=Z2;^o{kVUURp5_24&IDPs4rFo+$WSJbSOchfX9wvh00r?3kTziu@d>14HK@%{
z1d`njDna}}tScZx>p^<sK%wyu#A*T&tsrNt22~>7Aoq!a9P|=or4}fJq(SypgCw*;
z4%!RyM?c5_Es$*%AQlTKIKP9u$^^256GSkAB5Ehd<h3B~6OaK}AOoa9iXA}OazM$)
z4CJ))AazC{brvAjA&`>UAd9YmJR<@!`3=aW>LA(WAbVec#9n~JoIugN8KgrB#AOGW
z90OuK0I@!U3=IZ(CJbbrBuH-^NcJ&E_7BMTNg%PCAd_c+9C;XIUL(l(Fp$q5g4|pM
zlDGphB@U#QA7s=r5O*8MfUO`R9;B`oq}LrJQ3&c~Ed=?^6Qp+uh`0%|vKQ3wvH(ex
zfVdeTy}=;!c7TGt79<t~BG!V$EJ2%gr+`v+Fi1xp$oK$|OQ(Wj#tCGo97wS|$O}(F
zab65kcLU_<2$0FOAm^rmSRX*C<PXSOEFc5=K#n{GlHCjvyAP6`0dm@9kO8ki2IPT^
z_XHUq2g((DK@uS##YaK5Re+S70}(|avELxq9{~keJg7>L0Vz%bsoMjx&0ms%Au|9(
z1cHbl5D_fNz~HCJd`r>Y$;jByC_W@Iz|+~$C*H*~I3&o^DKx~>-!DGMF~rmVmLN=t
zqmz$oe6VMf>n%yBkh6zlP<)7gyjzfKV7z~ji)+wIh9c0R5@6z2le1M!XmM&$aZGAX
zN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7
zqKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#lc4B&JaZEvGfqr~hYF<iyk$!SUVo^$J
miGF$#$VX{KsfBt4mA5!-a`RJ4b5iX<Q^TNzPz)?gEKC3#NsJx<

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/gb2312prober.cpython-39.pyc
deleted file mode 100644
index 7d135e695847c53d86c4ce946c97a384a90bf099..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1177
zcmYe~<>g{vU|^UdaWM538w0~*5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#m>m!&XB^I!q&o&!j{U|%pAp$!XC_^$?=krfq_Aj
z@s^lxX--L|Q)Nl2b4FrOaB4|FQGQZtktX9UA?N&*%)IpAlEji!-^ApM%)C@h##>VE
zPDaLtMlPAfB}JJ@r6rm9d5(FBIhDnk#hQ$__#v|K!M^dn{w}UQ$;iF{v6(>x$R{QY
z3=F9ZQH&`JQB3U&X^bh1DNHRKQOv0<Da<J>Eey?!QLL#f5SKSIMzOUsurNe{T+V)r
z2Vx1tp~)bBKn-O8u|YO~aIp>p149Wz31baIGt&a5g$#@gCCnu(&5Sh+@vJ3m%?vdR
z@$5AW3phYBDGb33nv8y$oVQquOAAtqir5$!7;bUI$7kkcmc+*wfeb8S1&MJcgF_|0
zIJXECE4M^bkU}Cp5fl_vsYSO~i&BeIOI9-8Vku6|Nn6Qyi!(kxIVZ8WI6i(Q!><-+
ztC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ
z5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi>*g3JQ___EZz
zl>8$7<c!3kl++Ua^dwNs6@cScub{GsgMooT2^1F~1_L7>BNrnFW0fd!=<2~j03(<|
zLG29E3<`x5#$X0bCcj&35WPhL3=9lKJRkzh0uzFu(BlEQr8u=DJ})shRRg4*2^4os
zRgw^$kT}&tRz;l6?9QO{S)7X7YL1-5y!6t<^i)u~D27^#>RFfyO%71hgPa&2e~T+V
zJ~uz5G$%Da{uWPsd|_!~4nzhVez!OZit-Cmi%KesghBol1^JQ}8rR9GIXUt15GR4d
zfDfbu6cFI_r3msrDC2W5@~|;6axpV8g2h3}kUuvG8VHd1Dgrt9mJlTI6@#*5E+k8W
yljbb}kYePN2uYl5xk<^z#kt^=3pN_bEno+M+;WS<2I4_G8IXfOiGha^44DAk%^Ifw

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/hebrewprober.cpython-39.pyc
deleted file mode 100644
index c00756b966f3442fc6cbcc55997d0e580a79207a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jisfreq.cpython-39.pyc
deleted file mode 100644
index dd5e0198ea7365906b2425f44edb8914e42787d7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/jpcntx.cpython-39.pyc
deleted file mode 100644
index 2e0ac2242fba8ba4be81cde568bf387ed732e358..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 37635
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
W4jV`nVkZYO3{)nugb6qc$N~UKTQGb8

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langbulgarianmodel.cpython-39.pyc
deleted file mode 100644
index a2213cf6eeddafb3366e0e6a8ce9948521314d5c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langgreekmodel.cpython-39.pyc
deleted file mode 100644
index 967eb30becee3e0eeb1806594a6dd655a2c17abc..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhebrewmodel.cpython-39.pyc
deleted file mode 100644
index e01cd062929dc27b8282f4d35adfaabab5b2ce11..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langhungarianmodel.cpython-39.pyc
deleted file mode 100644
index df5dc55783115bfae52d945f12c3c1c6fc0d8cf2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langrussianmodel.cpython-39.pyc
deleted file mode 100644
index 035e6b2ac946b482d57c21a4f5fdfd19e195c0d4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 26385
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
N4UbVCECg_-3;>FN`p5tP

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langthaimodel.cpython-39.pyc
deleted file mode 100644
index 4444ac5e985a78c715efb7a6dbfc0ab5b9cd0d1d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/langturkishmodel.cpython-39.pyc
deleted file mode 100644
index da8c69bb71b5a4fb53608a6d63f0211c238305a7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 20597
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
VyFnoUN_`9*pftqF0^-B)F90E+x0(O|

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/latin1prober.cpython-39.pyc
deleted file mode 100644
index 22da5e306b250a224197ddaa93606c63542779c1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2982
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
N03${40h>AtF904{UeN#m

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcharsetprober.cpython-39.pyc
deleted file mode 100644
index 597ee0c4737ea0e4395d936f21e9b6e7aacab1d2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2289
zcmYe~<>g{vU|^UdaWFNMmx19ih=Yt-7#J8F7#J9e4Hy_0QW#Pga~N_NqZk=MY^EHh
zT;?d|T$U&nMh16=6y_9`7KRj-RK{lJDAp9#U<OULmy8Sy44RC$c%3s6i-J>20*dmJ
zQj0X1Zt;LvnR)5KC5a`ew|IOLlQS~&Qo+1rWcxvEkQ+dBaTo&wLn=cQV+unQQwn1g
za|(YuLmDI4Ud|{MFq<`nt%W0sHI*%eJ%yu%p_ws?J(VqmGldJx=1AdA;b~!r;!NR9
z;cH=t;%aALVTj@mX3!M4CFWb2Q<CXaS(1w4)+z-q1qB5K?2=$9zhowm>!29KW@cbu
z0O4XC1_p)_h7!gahGwQLrW(c+#$IsH)iA^}r!dqo#IvL@r7)#4)iA`frZ5CEXfpe0
zGT!3ONz6-+Ps_|HNiBK_GFFrA7He^7L26MED+2?=Esps3%)HE!`1o6*DVfD3MVU#Z
zC7Jno@rikfIh9qZMYlMU^HVbO(&LMBZ*j%vBo>#%CubyrLY<{JH7Bizje&t-CF3p5
z`1s_U#Ny)k_>~O5+MTUpLW@(2iepl9QZkET{PR*>iZaVm6?7Fs{XD~5gMvLn9D@}+
z{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6bqf-c
zvlG)(i(?8h3-sg5Qu9*si}XRxNl7iy&rJfcic?Dp!0AG-pt6XQfq_9Cl;Ai(K4%nS
zWMgDwtdhqb{(7*GNCu@dkOmM2u|dHP!o@a7QLun%Ap;{r4MP@lksOGG^I3}YY8bLu
zAp8`@6h@>dVe%_t2PI;*B9Mz9F~C}sTAW%^#Ld9KPz1_9MLggjE#d_U@PP;c5FrR6
zgcukYbU_{hsbOH`V`O9G0^=$f9G(Ijj^QJaube^VfSggn(8LHzFe@4TRx;ia_RBBv
z%q_@C%}vcKNlkGrD#|Y^5(Zfgb_SRLx#boQG`QpQ5_3~cL56{nD+5!NG7hI8t0&Gy
zMIs=3ML`5M7jS^mc4=aIswI-`xMCNk7A1p$vH&PTz+u6}2+d%O&5X^AE)20-YME*n
zvX~Yy*D%&FNir;CtYxlYE@8=H&1Nd{t6|7uTfm;eSi_LTQNxhMS;MrDg^{6zD~r2^
zA)bekq3}>44_GyCHd9er30D>$nmB(pQxOl?e1U}wwJbGEDNNZ+MT=?}Q<x+{=}It#
z*#<-lEfB6@$P%n!S;)l5Pzcfi5@D=iN@12@0FmMhtsosRdBzkLsD37}evuNcEYWPH
zqCYhZSwaiM7BYZX3&a<K%$CSzDf$C*TMa{&NHBvYt6!C(YO#W9u>vF`DP&}pD5Qdt
zfkI-5LQ-W(s)A}UI2jj#lF`fm|NsBjl)S}Sl$e*EdW$(HHLnPimTz(8rB;;07lX>=
zB2cM&i`6wK$Uo>7TTXs@dTP-v)|Aww()1#6Q0z*82v8Qg#pdT967TDJiw&al7Mo{C
zFo@6L<{#?k67Lyui#0gJF(~AgaC&M<d~#_~QEDEfNCH_5$`;^Ebc-b|H8tfHE7<y5
zoGz{*uFfHze(tyU)ALK>Q}gmm(=*~z5=#<q@qx|B&r8cpNzF@6y(JXv;U5&@92ycI
z;t}K;?BVa@qR9%*jJG&Io{ujsDZ0g&d5Z^DE`mIGivyIn<3UaUXAm#}$|Xf=3=9mm
zpyX)+E=>d&1sJ&)IT*SAvoLXhb1sAgiSaQCF-b5o{byt5W8z`tV&wVH#Kgf=C5<CH
zfjo$jjX+rtoR~o+Nex35!ve;I48aWGjHJl~4w@n@P+()pPhg2CkXu2fFfdlB;;<Pt
z#55WGG<iVv2&f#0kH5tgAD^3_Qks(*AAgG{KEALtF$XHc9v`2QpBx_#E|-fyW!Wu`
zf};F_)S{9~q;voZGO$~2@j`2r<kXy;`1m4lsDcS_u?P-dP!3iCxfx^}2O|p$9~%z`
z6C)Qh2y@7Si&#HRwp+ZQ2!dA*MIayEVol8}%`Gkhr8{s61uI6f1#A__mRlS)5HH!u
Nfvf_hW*$ZXW&n>CEbjmS

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcsgroupprober.cpython-39.pyc
deleted file mode 100644
index 5367772f25a5634e054459e30d5dd3c8e8855245..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1158
zcmYe~<>g{vU|^UdaWM4`I|IXG5C<8vFfcGUFfcF_H!v_Tq%fo~<}l<kMlmvi*i1Q0
zxy(__U^a6OOD<~^E11oa!<Ne)#SUh(=5XY4Msb4KY&l%H+)><MHhT_FE^ibsn9Y&H
zm&+f;4`y@b2;>Sz2{JOcGo)~(aJMj|aHldhGe-%f@B}kx^1ftbU|`T>yd~tEkysR*
zTH;=mUs@1Ql%JGZq{(=TD>TH-0>KOR@(hOaxLre?y#nA|9(N}rV?!f2A0+J^gy1>{
zSejVExm-?}>85ZVNNq?sgqw^USRghiz(91d90LPGDnk@w3PTiA3QIdf8e<Am3Udo*
z6mvTR3qur3FoP!REq-4o=U^mH_$4!eG($0n&B4IHzzm827X}7~5{44S8ir=3ET$U9
z6vkdgMurmRW`+`$W`+{hW`+{BW`+{>W`+`uW`+{ZW`+{3W`=Z*8isi88ioZt3mHHG
z9L%7}<fqAai#sPVFFigjGp8iANR#&#YjJ5oYEcn40|Ub?j`;Y@yv&mL_#%+KMIa9q
zu`)0)6tRH_b`Sw_R1qhL1xh`)*bBfhP<)HED784XM3d<jOL1yWS`iNe1H($jTb%Ln
z$vKI|#qseg8Gf}pTg8MHrxq2*q~@e#7RC7IrMeVlmZd7_DunuZhPeg>dxkg$D|q_3
z`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-aX2+!FmBsjECdCwImZa(yBqnDk
zrl%Ii6l50Y$Cst%rQ{dsCubxUrKFbV=O!f=r-RZ8#HD%#l|_6E3=CSJfE5FUHlq*|
z3nL2r!Nyf3ffhY_u%OXo^wVSog;ZW*Zfbn|Ew1?Z-29Z%91xo)KEALtF$W?8w&oTu
zGz5}Ub8_P2i$p*n2PT9-EKv{v3VKbDbHI_#2#yLrP2pQYATJcBmLR#l2&Ci|S7}L_
z1;jhxh`Pm9oRwJ&6#zxrE$-CP<g5ay2q*?`@uVk#Qaw}%6rW&4*+ozhP~_g?PA;%C
zv4o0%V)_<WQf9g-Q~(s~U`-|EP!UiP06Q1SUtrIH{B?`N1`;rKp!`q_@-Gh~8e|3l
DN3J3L

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/mbcssm.cpython-39.pyc
deleted file mode 100644
index 83f7161fe18171b5c7febcaae21f7700bb5ad73f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcharsetprober.cpython-39.pyc
deleted file mode 100644
index f04b346441caa82541f2812c58325aaae633f0c0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sbcsgroupprober.cpython-39.pyc
deleted file mode 100644
index 85e1d972af9dfa0554f1ff4ed7d33db1f6f48e74..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1727
zcmYe~<>g{vU|^UdaWM6&00YBg5C<8vFfcGUFfcF_&tYI-NMT4}%wfo7jACR2v6*t1
za+#x;!EELnmR!~-)?BtIHZY$hhdq}giX)dZiWAId&Ed-Bj^YNh*>ZStd82r9`J(u8
z`J?!A1)>CU1)~IWg`$MO^6WXnxgt>_U^YjNXs%e47?{nOBc3Y}CBewx&XB^D!rj7<
z!kx<4%p4_|!V}D($@`L#fq_Aj@s^NtMq*KLYKePMerZ8KQGQZtktX9U9*@+dqSSII
zpXrvAXRv>~g@vhQylK2ssE@m2kf)<xysy8DtIsW&a8ExM|M1{=LnBi|bXiTNTVim%
z=JD=9uCCrteG*9ejFDwD8E;7<$(hD`xH<*7hC{SzvfUE#bn>+@HH{An4Gu;)11xH0
zh9)Wjw;V&gx4)-Fd=Q#?Nnb~2=g1&WA0JO=G$|=0HyNVJfx<DwGdSMN$RIw%!_gD!
zRK{Bf>n-C$LW8_LgFWDK;=!4D={c!Rl_jarIDiCqGIELnv6(>xC{@WYFfgPtL@}l?
zL@~89q%o#2rZBZ|L@~EBurNfi1T$zd-{KE;at=m{%VbbAL-jL&k|#d{0|Usw;u#DK
z3?&RDj5Q3+ObeJ6GB7ffFgG*QGM2EEu%<B9Fg7#SGJ)AlU^a6N;{vuCrW)pjOpFXA
zEG6vCAe9_ok`qjFfk|#K$pa>N!6YA;<Oh=iU{VlF3N<s<FoH}>=dWRi7p`GgAOdnl
z3IoU^er_R}qPJL!OAAtqii8*#7;bUI$7kkcmc+*wft+6?$iTo*!~v2JEKV(n&&^Ls
z&517nr{CftK9D32h~NehydVOUbBj1ZEH)6q4kADSQp5^kfr6z-0Aw6H)R0@OMXAN9
zC7LX^Sc+3~(r)o)fU^YDj$5KR`RSR-i8=A8!Xjmv#ii(?D;aNb#>Xe;Bo-IP$FF4g
z)$VK+6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux#|%2s}^!JdvW!LGip
z!6B|e3T80@0X{K_Cb}Toi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F
z@{9D7GZKqZQcLuUlah<mLAe~_LA`>?A`u1#27OS<vH&F!Mm|P1Mixev|12zEl8KFx
z=|2lQ8zTl}1&J^*GBGl}WfQHEKudFau$a<h1;tukVs2`D{4K6{P$ZS+fY?0o@r9*{
zIS?7JD{k>Z11LE)Cnr9>NDdS!U;>ori{wFEP%_X1xt586fq{b&oGkn_rEUp<d{~@X
zg5<d(kdj+Gkhp>P7o2Qv3FRc_r6-l<q$d_-Cgy=tO%Xg5+~NbtrWd8AW<zA)DdiSF
zNCsjYL<*er1VExirNzZ?v%m=qoYcT651a<U$q$qyZ}EcEmt-VnLd*aqx?5l~N=l2e
zGmA4I!r)}cUz`N>7S#FR1P=-Vq_6=85GZVJaoFVMr<CTT+R1_f2&9aMk%v)$Nq~`u
LS%C$_=3xc^0F%NL

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/sjisprober.cpython-39.pyc
deleted file mode 100644
index 053a6cbc6f5de5073f9647c4821a5c41552f6cb1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/universaldetector.cpython-39.pyc
deleted file mode 100644
index ba21409ee701f0adbd4ac2a2e39e517ace8ba781..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/utf8prober.cpython-39.pyc
deleted file mode 100644
index b5f8a274e6f374bf861c728afa229521bc3ef729..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2019
zcmYe~<>g{vU|^UdaWM597X!m%5C<8vFfcGUFfcF_doVCCq%fo~<}l<kMlmvi*i1Q0
zxy(__xhzpEU_NsWYc5+98<@?K!=B3##lgtn&XB^I!q&o&!j{U|%pAp;!XC_^$?=kr
zfq_Aj@fNRhMq*KLYDqv*eo|_YCetk*5Gyk;J-8&XB=r`LZ(?#rW?m|or^$Fr$T>d+
zCJB`S84?=eW)UCk8}IAy;_8!(?0gWL8AO1*5W>K~kjfCnn8Fanl)@Or+|H23n8K98
z+`<vX0%o(Mu(ohSv8J-6u%)oKFf=npv8S@7aHMd8*&HccDcmg#QJg6}DZDKVQC#f|
zEDTZH!3>&wx41w~069IiC>>(m1N&r<A0ZqD1`r$M5D+fbVqjn>VJKm&VQ6Mrz_gHo
zk)edSgr%9Wh9RCcg`tKao~?#q0Xs-Mg&~+hlhIF;;}&aiX+dgH5jz6|!!3^Z_{_Y_
zlKA){Rt5%!A~uj1XEHcw;)`={@y6$s=EmnH#V2PZ78T!OElMp;Em_HUi={X<Cv7F;
zEzbD(<ebFf;`sQL48NM3tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW
z6+Hc1{QX>mJso3$U431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy?U
z5|gtN(^HFM3Nj1y<I7U>Qu2%RK`u&3EzvJ6NwX*b$GKiXWf3O>1A`hUhB!dM#mL9V
z#mL53C5#ADJ(!1ahp7@qnAR|4F+)N(1r)L@;IL%!dkL~bleGwB7dSYJctC*&$_7Q;
zAQmr(;0F<cAVLU4fRyNfTnGwl2CxgO1d!YZ4q^<)fg;@*qzjabQW%37G@1OWSW8RN
zbS;X&W`nH)v%mz%s#`puFe*+hiO);SO*I7RW&*jGsY)ElK4djSS$m5Cw~ZV*iFxUz
ziRr1PNVXw|K1@Ct>=KY`7#J8pega{z2d6MFFw`)*FvO<SGSx6-F)U!LVOq#o%Ur`;
z!j#3F%~YgQ!ji=bO4*DIg*k;RU~%?rrXrUTmMji5an5X}A{MYITniae7_(VHJQjv5
z?i40-1}27h?n00(PYFvFZ#Gj=Uk$?ozJ&}m3|aiyEJb}V^J*Bfc!C);nf+dZ99;y8
z3Qd6`P%Pi#%1f;%i7y6~Fhw9A++uYN3i1ys0_DwHY<~VB@xHFN*dPjSv3Z6BgZLb7
z{-J&@@tz^KSc5|xgF<czr>B<0Czlo#rRJ4@b6QSn9ykHrVg(z0i_^t5#ML>()6e}D
zA6RXEURq{KYF={cEuml!|DX`((2)2Lk094z4}TvQO_m})P(J2Jsw_#3FD@y%#h84H
z2bQV9ZUv_iFab^|ENQ8!DVCrplLJKwBL^c7BNrnFBO9FLV-#TGVdP`vV5;IrN<1Ka
zD2WCXLLkqBqf!r4&@<LDf+8S=DVw24tp>yfVFqCaONLs;6y_R635H;X8pdD-aHeAM
zOJC>yuu5dzd;6E53<50zKiF$BK|+Mr-_JGP*~2j?J|M{7Ns|fURkqT+oXqT0NWz5s
zs|b{neL&s<MHT}i3nLe!0LTlHNM1k<PfZ?Bk(ig5n;IW~iz_}pH$SB`2gK%yk1s4u
z%z?-hX@YVxsH_3!_*)zWMfnA(MJ1I*A|MGd5TOntKn}RY3oRs*Q*(0S<B{A5E*U@(
zPy{NAl|c>#@i-V+n0VNDSeY2Pm_e9B7%cCn$#shtnp+_SUJ)p?Z?UH4mF5<MlN=-s
z3PGY8oOE&_wO$dZbic)xo0ME!oC_}H!A2sv1s-U(IBX!Ewvz!l2voN5FbXj8F!Hbf
E0KwGADF6Tf

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/__pycache__/version.cpython-39.pyc
deleted file mode 100644
index 6b67d25af1395324763805ede852d3a9ce136ec1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 466
zcmYe~<>g{vU|^UdaWM500|Ucj5C<7EGcYhXFfcF_i!m@Tq%cG=q%cM?rZO&IN?}^a
z7{#2z9L%7}Qni^YBqOs}AvZszG$&OdwIZ{)q*x(8FQ-zWBwwL8Gq)foGp$mgD7B<0
zGqo%;FI}M|BUPa+wWv5VKTjdAG&d==NFhH>Avq(lC?&OoE3GI$SD`$!BqK9Vp*Xdq
zv_P+*QXw%fMFA`URi#i|npBXOoSm4STCB&#WtCW3l969zrQnj7r{I*6m<Lv-pplZ8
zr<VldI;7_&X6EQ6=jUp2Rk51r8R!|@V$}1~WVyv2AD@z+93Ov+J3b!ju=w~}ti=U6
znI*T_!(4-cJ^lSwG8C~fFhGc3_0Co?p~b01#WATlDVaqv{&}e`MVV!(3c3oRex6_*
zA&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylB
zsk$&v#S~-~=*O3(=B4Bp>4SZfTA~kin_fZXEe@MpaCqA>g5rmTfq{XAorMtqUKo-}

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py b/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py
index 38f32517..87d9f972 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/big5freq.py
@@ -42,9 +42,9 @@
 
 BIG5_TYPICAL_DISTRIBUTION_RATIO = 0.75
 
-#Char to FreqOrder table
+# Char to FreqOrder table
 BIG5_TABLE_SIZE = 5376
-
+# fmt: off
 BIG5_CHAR_TO_FREQ_ORDER = (
    1,1801,1506, 255,1431, 198,   9,  82,   6,5008, 177, 202,3681,1256,2821, 110, #   16
 3814,  33,3274, 261,  76,  44,2114,  16,2946,2187,1176, 659,3971,  26,3451,2653, #   32
@@ -383,4 +383,4 @@ BIG5_CHAR_TO_FREQ_ORDER = (
  890,3669,3943,5791,1878,3798,3439,5792,2186,2358,3440,1652,5793,5794,5795, 941, # 5360
 2299, 208,3546,4161,2020, 330,4438,3944,2906,2499,3799,4439,4811,5796,5797,5798, # 5376
 )
-
+# fmt: on
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py b/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py
index 98f99701..ef09c60e 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/big5prober.py
@@ -25,23 +25,23 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .mbcharsetprober import MultiByteCharSetProber
-from .codingstatemachine import CodingStateMachine
 from .chardistribution import Big5DistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .mbcharsetprober import MultiByteCharSetProber
 from .mbcssm import BIG5_SM_MODEL
 
 
 class Big5Prober(MultiByteCharSetProber):
-    def __init__(self):
-        super(Big5Prober, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(BIG5_SM_MODEL)
         self.distribution_analyzer = Big5DistributionAnalysis()
         self.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "Big5"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Chinese"
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py b/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py
index c0395f4a..176cb996 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/chardistribution.py
@@ -25,40 +25,58 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .euctwfreq import (EUCTW_CHAR_TO_FREQ_ORDER, EUCTW_TABLE_SIZE,
-                        EUCTW_TYPICAL_DISTRIBUTION_RATIO)
-from .euckrfreq import (EUCKR_CHAR_TO_FREQ_ORDER, EUCKR_TABLE_SIZE,
-                        EUCKR_TYPICAL_DISTRIBUTION_RATIO)
-from .gb2312freq import (GB2312_CHAR_TO_FREQ_ORDER, GB2312_TABLE_SIZE,
-                         GB2312_TYPICAL_DISTRIBUTION_RATIO)
-from .big5freq import (BIG5_CHAR_TO_FREQ_ORDER, BIG5_TABLE_SIZE,
-                       BIG5_TYPICAL_DISTRIBUTION_RATIO)
-from .jisfreq import (JIS_CHAR_TO_FREQ_ORDER, JIS_TABLE_SIZE,
-                      JIS_TYPICAL_DISTRIBUTION_RATIO)
-
-
-class CharDistributionAnalysis(object):
+from typing import Tuple, Union
+
+from .big5freq import (
+    BIG5_CHAR_TO_FREQ_ORDER,
+    BIG5_TABLE_SIZE,
+    BIG5_TYPICAL_DISTRIBUTION_RATIO,
+)
+from .euckrfreq import (
+    EUCKR_CHAR_TO_FREQ_ORDER,
+    EUCKR_TABLE_SIZE,
+    EUCKR_TYPICAL_DISTRIBUTION_RATIO,
+)
+from .euctwfreq import (
+    EUCTW_CHAR_TO_FREQ_ORDER,
+    EUCTW_TABLE_SIZE,
+    EUCTW_TYPICAL_DISTRIBUTION_RATIO,
+)
+from .gb2312freq import (
+    GB2312_CHAR_TO_FREQ_ORDER,
+    GB2312_TABLE_SIZE,
+    GB2312_TYPICAL_DISTRIBUTION_RATIO,
+)
+from .jisfreq import (
+    JIS_CHAR_TO_FREQ_ORDER,
+    JIS_TABLE_SIZE,
+    JIS_TYPICAL_DISTRIBUTION_RATIO,
+)
+from .johabfreq import JOHAB_TO_EUCKR_ORDER_TABLE
+
+
+class CharDistributionAnalysis:
     ENOUGH_DATA_THRESHOLD = 1024
     SURE_YES = 0.99
     SURE_NO = 0.01
     MINIMUM_DATA_THRESHOLD = 3
 
-    def __init__(self):
+    def __init__(self) -> None:
         # Mapping table to get frequency order from char order (get from
         # GetOrder())
-        self._char_to_freq_order = None
-        self._table_size = None  # Size of above table
+        self._char_to_freq_order: Tuple[int, ...] = tuple()
+        self._table_size = 0  # Size of above table
         # This is a constant value which varies from language to language,
         # used in calculating confidence.  See
         # http://www.mozilla.org/projects/intl/UniversalCharsetDetection.html
         # for further detail.
-        self.typical_distribution_ratio = None
-        self._done = None
-        self._total_chars = None
-        self._freq_chars = None
+        self.typical_distribution_ratio = 0.0
+        self._done = False
+        self._total_chars = 0
+        self._freq_chars = 0
         self.reset()
 
-    def reset(self):
+    def reset(self) -> None:
         """reset analyser, clear any state"""
         # If this flag is set to True, detection is done and conclusion has
         # been made
@@ -67,7 +85,7 @@ class CharDistributionAnalysis(object):
         # The number of characters whose frequency order is less than 512
         self._freq_chars = 0
 
-    def feed(self, char, char_len):
+    def feed(self, char: Union[bytes, bytearray], char_len: int) -> None:
         """feed a character with known length"""
         if char_len == 2:
             # we only care about 2-bytes character in our distribution analysis
@@ -81,7 +99,7 @@ class CharDistributionAnalysis(object):
                 if 512 > self._char_to_freq_order[order]:
                     self._freq_chars += 1
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         """return confidence based on existing data"""
         # if we didn't receive any character in our consideration range,
         # return negative answer
@@ -89,20 +107,21 @@ class CharDistributionAnalysis(object):
             return self.SURE_NO
 
         if self._total_chars != self._freq_chars:
-            r = (self._freq_chars / ((self._total_chars - self._freq_chars)
-                 * self.typical_distribution_ratio))
+            r = self._freq_chars / (
+                (self._total_chars - self._freq_chars) * self.typical_distribution_ratio
+            )
             if r < self.SURE_YES:
                 return r
 
         # normalize confidence (we don't want to be 100% sure)
         return self.SURE_YES
 
-    def got_enough_data(self):
+    def got_enough_data(self) -> bool:
         # It is not necessary to receive all data to draw conclusion.
         # For charset detection, certain amount of data is enough
         return self._total_chars > self.ENOUGH_DATA_THRESHOLD
 
-    def get_order(self, byte_str):
+    def get_order(self, _: Union[bytes, bytearray]) -> int:
         # We do not handle characters based on the original encoding string,
         # but convert this encoding string to a number, here called order.
         # This allows multiple encodings of a language to share one frequency
@@ -111,13 +130,13 @@ class CharDistributionAnalysis(object):
 
 
 class EUCTWDistributionAnalysis(CharDistributionAnalysis):
-    def __init__(self):
-        super(EUCTWDistributionAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._char_to_freq_order = EUCTW_CHAR_TO_FREQ_ORDER
         self._table_size = EUCTW_TABLE_SIZE
         self.typical_distribution_ratio = EUCTW_TYPICAL_DISTRIBUTION_RATIO
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
         # for euc-TW encoding, we are interested
         #   first  byte range: 0xc4 -- 0xfe
         #   second byte range: 0xa1 -- 0xfe
@@ -125,18 +144,17 @@ class EUCTWDistributionAnalysis(CharDistributionAnalysis):
         first_char = byte_str[0]
         if first_char >= 0xC4:
             return 94 * (first_char - 0xC4) + byte_str[1] - 0xA1
-        else:
-            return -1
+        return -1
 
 
 class EUCKRDistributionAnalysis(CharDistributionAnalysis):
-    def __init__(self):
-        super(EUCKRDistributionAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER
         self._table_size = EUCKR_TABLE_SIZE
         self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
         # for euc-KR encoding, we are interested
         #   first  byte range: 0xb0 -- 0xfe
         #   second byte range: 0xa1 -- 0xfe
@@ -144,18 +162,32 @@ class EUCKRDistributionAnalysis(CharDistributionAnalysis):
         first_char = byte_str[0]
         if first_char >= 0xB0:
             return 94 * (first_char - 0xB0) + byte_str[1] - 0xA1
-        else:
-            return -1
+        return -1
+
+
+class JOHABDistributionAnalysis(CharDistributionAnalysis):
+    def __init__(self) -> None:
+        super().__init__()
+        self._char_to_freq_order = EUCKR_CHAR_TO_FREQ_ORDER
+        self._table_size = EUCKR_TABLE_SIZE
+        self.typical_distribution_ratio = EUCKR_TYPICAL_DISTRIBUTION_RATIO
+
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
+        first_char = byte_str[0]
+        if 0x88 <= first_char < 0xD4:
+            code = first_char * 256 + byte_str[1]
+            return JOHAB_TO_EUCKR_ORDER_TABLE.get(code, -1)
+        return -1
 
 
 class GB2312DistributionAnalysis(CharDistributionAnalysis):
-    def __init__(self):
-        super(GB2312DistributionAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._char_to_freq_order = GB2312_CHAR_TO_FREQ_ORDER
         self._table_size = GB2312_TABLE_SIZE
         self.typical_distribution_ratio = GB2312_TYPICAL_DISTRIBUTION_RATIO
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
         # for GB2312 encoding, we are interested
         #  first  byte range: 0xb0 -- 0xfe
         #  second byte range: 0xa1 -- 0xfe
@@ -163,18 +195,17 @@ class GB2312DistributionAnalysis(CharDistributionAnalysis):
         first_char, second_char = byte_str[0], byte_str[1]
         if (first_char >= 0xB0) and (second_char >= 0xA1):
             return 94 * (first_char - 0xB0) + second_char - 0xA1
-        else:
-            return -1
+        return -1
 
 
 class Big5DistributionAnalysis(CharDistributionAnalysis):
-    def __init__(self):
-        super(Big5DistributionAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._char_to_freq_order = BIG5_CHAR_TO_FREQ_ORDER
         self._table_size = BIG5_TABLE_SIZE
         self.typical_distribution_ratio = BIG5_TYPICAL_DISTRIBUTION_RATIO
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
         # for big5 encoding, we are interested
         #   first  byte range: 0xa4 -- 0xfe
         #   second byte range: 0x40 -- 0x7e , 0xa1 -- 0xfe
@@ -183,28 +214,26 @@ class Big5DistributionAnalysis(CharDistributionAnalysis):
         if first_char >= 0xA4:
             if second_char >= 0xA1:
                 return 157 * (first_char - 0xA4) + second_char - 0xA1 + 63
-            else:
-                return 157 * (first_char - 0xA4) + second_char - 0x40
-        else:
-            return -1
+            return 157 * (first_char - 0xA4) + second_char - 0x40
+        return -1
 
 
 class SJISDistributionAnalysis(CharDistributionAnalysis):
-    def __init__(self):
-        super(SJISDistributionAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER
         self._table_size = JIS_TABLE_SIZE
         self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
         # for sjis encoding, we are interested
         #   first  byte range: 0x81 -- 0x9f , 0xe0 -- 0xfe
         #   second byte range: 0x40 -- 0x7e,  0x81 -- oxfe
         # no validation needed here. State machine has done that
         first_char, second_char = byte_str[0], byte_str[1]
-        if (first_char >= 0x81) and (first_char <= 0x9F):
+        if 0x81 <= first_char <= 0x9F:
             order = 188 * (first_char - 0x81)
-        elif (first_char >= 0xE0) and (first_char <= 0xEF):
+        elif 0xE0 <= first_char <= 0xEF:
             order = 188 * (first_char - 0xE0 + 31)
         else:
             return -1
@@ -215,19 +244,18 @@ class SJISDistributionAnalysis(CharDistributionAnalysis):
 
 
 class EUCJPDistributionAnalysis(CharDistributionAnalysis):
-    def __init__(self):
-        super(EUCJPDistributionAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._char_to_freq_order = JIS_CHAR_TO_FREQ_ORDER
         self._table_size = JIS_TABLE_SIZE
         self.typical_distribution_ratio = JIS_TYPICAL_DISTRIBUTION_RATIO
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> int:
         # for euc-JP encoding, we are interested
         #   first  byte range: 0xa0 -- 0xfe
         #   second byte range: 0xa1 -- 0xfe
         # no validation needed here. State machine has done that
         char = byte_str[0]
         if char >= 0xA0:
-            return 94 * (char - 0xA1) + byte_str[1] - 0xa1
-        else:
-            return -1
+            return 94 * (char - 0xA1) + byte_str[1] - 0xA1
+        return -1
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py b/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py
index 5812cef0..6def56b4 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/charsetgroupprober.py
@@ -25,29 +25,30 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .enums import ProbingState
+from typing import List, Optional, Union
+
 from .charsetprober import CharSetProber
+from .enums import LanguageFilter, ProbingState
 
 
 class CharSetGroupProber(CharSetProber):
-    def __init__(self, lang_filter=None):
-        super(CharSetGroupProber, self).__init__(lang_filter=lang_filter)
+    def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None:
+        super().__init__(lang_filter=lang_filter)
         self._active_num = 0
-        self.probers = []
-        self._best_guess_prober = None
+        self.probers: List[CharSetProber] = []
+        self._best_guess_prober: Optional[CharSetProber] = None
 
-    def reset(self):
-        super(CharSetGroupProber, self).reset()
+    def reset(self) -> None:
+        super().reset()
         self._active_num = 0
         for prober in self.probers:
-            if prober:
-                prober.reset()
-                prober.active = True
-                self._active_num += 1
+            prober.reset()
+            prober.active = True
+            self._active_num += 1
         self._best_guess_prober = None
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> Optional[str]:
         if not self._best_guess_prober:
             self.get_confidence()
             if not self._best_guess_prober:
@@ -55,17 +56,15 @@ class CharSetGroupProber(CharSetProber):
         return self._best_guess_prober.charset_name
 
     @property
-    def language(self):
+    def language(self) -> Optional[str]:
         if not self._best_guess_prober:
             self.get_confidence()
             if not self._best_guess_prober:
                 return None
         return self._best_guess_prober.language
 
-    def feed(self, byte_str):
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
         for prober in self.probers:
-            if not prober:
-                continue
             if not prober.active:
                 continue
             state = prober.feed(byte_str)
@@ -75,7 +74,7 @@ class CharSetGroupProber(CharSetProber):
                 self._best_guess_prober = prober
                 self._state = ProbingState.FOUND_IT
                 return self.state
-            elif state == ProbingState.NOT_ME:
+            if state == ProbingState.NOT_ME:
                 prober.active = False
                 self._active_num -= 1
                 if self._active_num <= 0:
@@ -83,22 +82,22 @@ class CharSetGroupProber(CharSetProber):
                     return self.state
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         state = self.state
         if state == ProbingState.FOUND_IT:
             return 0.99
-        elif state == ProbingState.NOT_ME:
+        if state == ProbingState.NOT_ME:
             return 0.01
         best_conf = 0.0
         self._best_guess_prober = None
         for prober in self.probers:
-            if not prober:
-                continue
             if not prober.active:
-                self.logger.debug('%s not active', prober.charset_name)
+                self.logger.debug("%s not active", prober.charset_name)
                 continue
             conf = prober.get_confidence()
-            self.logger.debug('%s %s confidence = %s', prober.charset_name, prober.language, conf)
+            self.logger.debug(
+                "%s %s confidence = %s", prober.charset_name, prober.language, conf
+            )
             if best_conf < conf:
                 best_conf = conf
                 self._best_guess_prober = prober
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py b/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py
index eac4e598..a103ca11 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/charsetprober.py
@@ -28,54 +28,62 @@
 
 import logging
 import re
+from typing import Optional, Union
 
-from .enums import ProbingState
+from .enums import LanguageFilter, ProbingState
 
+INTERNATIONAL_WORDS_PATTERN = re.compile(
+    b"[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?"
+)
 
-class CharSetProber(object):
+
+class CharSetProber:
 
     SHORTCUT_THRESHOLD = 0.95
 
-    def __init__(self, lang_filter=None):
-        self._state = None
+    def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None:
+        self._state = ProbingState.DETECTING
+        self.active = True
         self.lang_filter = lang_filter
         self.logger = logging.getLogger(__name__)
 
-    def reset(self):
+    def reset(self) -> None:
         self._state = ProbingState.DETECTING
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> Optional[str]:
         return None
 
-    def feed(self, buf):
-        pass
+    @property
+    def language(self) -> Optional[str]:
+        raise NotImplementedError
+
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
+        raise NotImplementedError
 
     @property
-    def state(self):
+    def state(self) -> ProbingState:
         return self._state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         return 0.0
 
     @staticmethod
-    def filter_high_byte_only(buf):
-        buf = re.sub(b'([\x00-\x7F])+', b' ', buf)
+    def filter_high_byte_only(buf: Union[bytes, bytearray]) -> bytes:
+        buf = re.sub(b"([\x00-\x7F])+", b" ", buf)
         return buf
 
     @staticmethod
-    def filter_international_words(buf):
+    def filter_international_words(buf: Union[bytes, bytearray]) -> bytearray:
         """
         We define three types of bytes:
         alphabet: english alphabets [a-zA-Z]
         international: international characters [\x80-\xFF]
         marker: everything else [^a-zA-Z\x80-\xFF]
-
         The input buffer can be thought to contain a series of words delimited
         by markers. This function works to filter all words that contain at
         least one international character. All contiguous sequences of markers
         are replaced by a single space ascii character.
-
         This filter applies to all scripts which do not use English characters.
         """
         filtered = bytearray()
@@ -83,8 +91,7 @@ class CharSetProber(object):
         # This regex expression filters out only words that have at-least one
         # international character. The word may include one marker character at
         # the end.
-        words = re.findall(b'[a-zA-Z]*[\x80-\xFF]+[a-zA-Z]*[^a-zA-Z\x80-\xFF]?',
-                           buf)
+        words = INTERNATIONAL_WORDS_PATTERN.findall(buf)
 
         for word in words:
             filtered.extend(word[:-1])
@@ -94,20 +101,17 @@ class CharSetProber(object):
             # similarly across all languages and may thus have similar
             # frequencies).
             last_char = word[-1:]
-            if not last_char.isalpha() and last_char < b'\x80':
-                last_char = b' '
+            if not last_char.isalpha() and last_char < b"\x80":
+                last_char = b" "
             filtered.extend(last_char)
 
         return filtered
 
     @staticmethod
-    def filter_with_english_letters(buf):
+    def remove_xml_tags(buf: Union[bytes, bytearray]) -> bytes:
         """
         Returns a copy of ``buf`` that retains only the sequences of English
         alphabet and high byte characters that are not between <> characters.
-        Also retains English alphabet and high byte characters immediately
-        before occurrences of >.
-
         This filter can be applied to all scripts which contain both English
         characters and extended ASCII characters, but is currently only used by
         ``Latin1Prober``.
@@ -115,26 +119,24 @@ class CharSetProber(object):
         filtered = bytearray()
         in_tag = False
         prev = 0
+        buf = memoryview(buf).cast("c")
 
-        for curr in range(len(buf)):
-            # Slice here to get bytes instead of an int with Python 3
-            buf_char = buf[curr:curr + 1]
-            # Check if we're coming out of or entering an HTML tag
-            if buf_char == b'>':
-                in_tag = False
-            elif buf_char == b'<':
-                in_tag = True
+        for curr, buf_char in enumerate(buf):
+            # Check if we're coming out of or entering an XML tag
 
-            # If current character is not extended-ASCII and not alphabetic...
-            if buf_char < b'\x80' and not buf_char.isalpha():
-                # ...and we're not in a tag
+            # https://github.com/python/typeshed/issues/8182
+            if buf_char == b">":  # type: ignore[comparison-overlap]
+                prev = curr + 1
+                in_tag = False
+            # https://github.com/python/typeshed/issues/8182
+            elif buf_char == b"<":  # type: ignore[comparison-overlap]
                 if curr > prev and not in_tag:
                     # Keep everything after last non-extended-ASCII,
                     # non-alphabetic character
                     filtered.extend(buf[prev:curr])
                     # Output a space to delimit stretch we kept
-                    filtered.extend(b' ')
-                prev = curr + 1
+                    filtered.extend(b" ")
+                in_tag = True
 
         # If we're not in a tag...
         if not in_tag:
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py b/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py
index 8b137891..e69de29b 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/cli/__init__.py
@@ -1 +0,0 @@
-
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 4dc854ddc02c16c1da3beebcc0db9d85c3155dac..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 223
zcmYe~<>g{vU|^UdaWIvUfq~&Mh=Ytlf({G}48<%A3=Am@!3>&=ek&P@K*9*(SBtY%
zOlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9K
zYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZuS!!NN
uevy81Mq*J)YKeYwPNsf*d}dx|NqoFsLFFwDo80`A(wtN~kn28!d;tKK?mPDY

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/cli/__pycache__/chardetect.cpython-39.pyc
deleted file mode 100644
index 51cff09663700751e744603566aab3f8423a8f17..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py b/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py
index 6d6f93aa..43f6e144 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/cli/chardetect.py
@@ -12,17 +12,21 @@ If no paths are provided, it takes its input from stdin.
 
 """
 
-from __future__ import absolute_import, print_function, unicode_literals
 
 import argparse
 import sys
+from typing import Iterable, List, Optional
 
-from pip._vendor.chardet import __version__
-from pip._vendor.chardet.compat import PY2
-from pip._vendor.chardet.universaldetector import UniversalDetector
+from .. import __version__
+from ..universaldetector import UniversalDetector
 
 
-def description_of(lines, name='stdin'):
+def description_of(
+    lines: Iterable[bytes],
+    name: str = "stdin",
+    minimal: bool = False,
+    should_rename_legacy: bool = False,
+) -> Optional[str]:
     """
     Return a string describing the probable encoding of a file or
     list of strings.
@@ -31,8 +35,11 @@ def description_of(lines, name='stdin'):
     :type lines: Iterable of bytes
     :param name: Name of file or collection of lines
     :type name: str
+    :param should_rename_legacy:  Should we rename legacy encodings to
+                                  their more modern equivalents?
+    :type should_rename_legacy:   ``bool``
     """
-    u = UniversalDetector()
+    u = UniversalDetector(should_rename_legacy=should_rename_legacy)
     for line in lines:
         line = bytearray(line)
         u.feed(line)
@@ -41,16 +48,14 @@ def description_of(lines, name='stdin'):
             break
     u.close()
     result = u.result
-    if PY2:
-        name = name.decode(sys.getfilesystemencoding(), 'ignore')
-    if result['encoding']:
-        return '{}: {} with confidence {}'.format(name, result['encoding'],
-                                                     result['confidence'])
-    else:
-        return '{}: no result'.format(name)
+    if minimal:
+        return result["encoding"]
+    if result["encoding"]:
+        return f'{name}: {result["encoding"]} with confidence {result["confidence"]}'
+    return f"{name}: no result"
 
 
-def main(argv=None):
+def main(argv: Optional[List[str]] = None) -> None:
     """
     Handles command line arguments and gets things started.
 
@@ -60,25 +65,48 @@ def main(argv=None):
     """
     # Get command line arguments
     parser = argparse.ArgumentParser(
-        description="Takes one or more file paths and reports their detected \
-                     encodings")
-    parser.add_argument('input',
-                        help='File whose encoding we would like to determine. \
-                              (default: stdin)',
-                        type=argparse.FileType('rb'), nargs='*',
-                        default=[sys.stdin if PY2 else sys.stdin.buffer])
-    parser.add_argument('--version', action='version',
-                        version='%(prog)s {}'.format(__version__))
+        description=(
+            "Takes one or more file paths and reports their detected encodings"
+        )
+    )
+    parser.add_argument(
+        "input",
+        help="File whose encoding we would like to determine. (default: stdin)",
+        type=argparse.FileType("rb"),
+        nargs="*",
+        default=[sys.stdin.buffer],
+    )
+    parser.add_argument(
+        "--minimal",
+        help="Print only the encoding to standard output",
+        action="store_true",
+    )
+    parser.add_argument(
+        "-l",
+        "--legacy",
+        help="Rename legacy encodings to more modern ones.",
+        action="store_true",
+    )
+    parser.add_argument(
+        "--version", action="version", version=f"%(prog)s {__version__}"
+    )
     args = parser.parse_args(argv)
 
     for f in args.input:
         if f.isatty():
-            print("You are running chardetect interactively. Press " +
-                  "CTRL-D twice at the start of a blank line to signal the " +
-                  "end of your input. If you want help, run chardetect " +
-                  "--help\n", file=sys.stderr)
-        print(description_of(f, f.name))
-
-
-if __name__ == '__main__':
+            print(
+                "You are running chardetect interactively. Press "
+                "CTRL-D twice at the start of a blank line to signal the "
+                "end of your input. If you want help, run chardetect "
+                "--help\n",
+                file=sys.stderr,
+            )
+        print(
+            description_of(
+                f, f.name, minimal=args.minimal, should_rename_legacy=args.legacy
+            )
+        )
+
+
+if __name__ == "__main__":
     main()
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py b/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py
index 68fba44f..8ed4a877 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/codingstatemachine.py
@@ -27,10 +27,11 @@
 
 import logging
 
+from .codingstatemachinedict import CodingStateMachineDict
 from .enums import MachineState
 
 
-class CodingStateMachine(object):
+class CodingStateMachine:
     """
     A state machine to verify a byte sequence for a particular encoding. For
     each byte the detector receives, it will feed that byte to every active
@@ -52,37 +53,38 @@ class CodingStateMachine(object):
                  negative answer for this encoding. Detector will exclude this
                  encoding from consideration from here on.
     """
-    def __init__(self, sm):
+
+    def __init__(self, sm: CodingStateMachineDict) -> None:
         self._model = sm
         self._curr_byte_pos = 0
         self._curr_char_len = 0
-        self._curr_state = None
+        self._curr_state = MachineState.START
+        self.active = True
         self.logger = logging.getLogger(__name__)
         self.reset()
 
-    def reset(self):
+    def reset(self) -> None:
         self._curr_state = MachineState.START
 
-    def next_state(self, c):
+    def next_state(self, c: int) -> int:
         # for each byte we get its class
         # if it is first byte, we also get byte length
-        byte_class = self._model['class_table'][c]
+        byte_class = self._model["class_table"][c]
         if self._curr_state == MachineState.START:
             self._curr_byte_pos = 0
-            self._curr_char_len = self._model['char_len_table'][byte_class]
+            self._curr_char_len = self._model["char_len_table"][byte_class]
         # from byte's class and state_table, we get its next state
-        curr_state = (self._curr_state * self._model['class_factor']
-                      + byte_class)
-        self._curr_state = self._model['state_table'][curr_state]
+        curr_state = self._curr_state * self._model["class_factor"] + byte_class
+        self._curr_state = self._model["state_table"][curr_state]
         self._curr_byte_pos += 1
         return self._curr_state
 
-    def get_current_charlen(self):
+    def get_current_charlen(self) -> int:
         return self._curr_char_len
 
-    def get_coding_state_machine(self):
-        return self._model['name']
+    def get_coding_state_machine(self) -> str:
+        return self._model["name"]
 
     @property
-    def language(self):
-        return self._model['language']
+    def language(self) -> str:
+        return self._model["language"]
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/compat.py b/env/Lib/site-packages/pip/_vendor/chardet/compat.py
deleted file mode 100644
index 8941572b..00000000
--- a/env/Lib/site-packages/pip/_vendor/chardet/compat.py
+++ /dev/null
@@ -1,36 +0,0 @@
-######################## BEGIN LICENSE BLOCK ########################
-# Contributor(s):
-#   Dan Blanchard
-#   Ian Cordasco
-#
-# This library is free software; you can redistribute it and/or
-# modify it under the terms of the GNU Lesser General Public
-# License as published by the Free Software Foundation; either
-# version 2.1 of the License, or (at your option) any later version.
-#
-# This library is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
-# Lesser General Public License for more details.
-#
-# You should have received a copy of the GNU Lesser General Public
-# License along with this library; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
-# 02110-1301  USA
-######################### END LICENSE BLOCK #########################
-
-import sys
-
-
-if sys.version_info < (3, 0):
-    PY2 = True
-    PY3 = False
-    string_types = (str, unicode)
-    text_type = unicode
-    iteritems = dict.iteritems
-else:
-    PY2 = False
-    PY3 = True
-    string_types = (bytes, str)
-    text_type = str
-    iteritems = dict.items
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py b/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py
index efd793ab..fa7307ed 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/cp949prober.py
@@ -32,8 +32,8 @@ from .mbcssm import CP949_SM_MODEL
 
 
 class CP949Prober(MultiByteCharSetProber):
-    def __init__(self):
-        super(CP949Prober, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(CP949_SM_MODEL)
         # NOTE: CP949 is a superset of EUC-KR, so the distribution should be
         #       not different.
@@ -41,9 +41,9 @@ class CP949Prober(MultiByteCharSetProber):
         self.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "CP949"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Korean"
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/enums.py b/env/Lib/site-packages/pip/_vendor/chardet/enums.py
index 04512072..5e3e1982 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/enums.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/enums.py
@@ -4,21 +4,26 @@ All of the Enums that are used throughout the chardet package.
 :author: Dan Blanchard (dan.blanchard@gmail.com)
 """
 
+from enum import Enum, Flag
 
-class InputState(object):
+
+class InputState:
     """
     This enum represents the different states a universal detector can be in.
     """
+
     PURE_ASCII = 0
     ESC_ASCII = 1
     HIGH_BYTE = 2
 
 
-class LanguageFilter(object):
+class LanguageFilter(Flag):
     """
     This enum represents the different language filters we can apply to a
     ``UniversalDetector``.
     """
+
+    NONE = 0x00
     CHINESE_SIMPLIFIED = 0x01
     CHINESE_TRADITIONAL = 0x02
     JAPANESE = 0x04
@@ -29,46 +34,50 @@ class LanguageFilter(object):
     CJK = CHINESE | JAPANESE | KOREAN
 
 
-class ProbingState(object):
+class ProbingState(Enum):
     """
     This enum represents the different states a prober can be in.
     """
+
     DETECTING = 0
     FOUND_IT = 1
     NOT_ME = 2
 
 
-class MachineState(object):
+class MachineState:
     """
     This enum represents the different states a state machine can be in.
     """
+
     START = 0
     ERROR = 1
     ITS_ME = 2
 
 
-class SequenceLikelihood(object):
+class SequenceLikelihood:
     """
     This enum represents the likelihood of a character following the previous one.
     """
+
     NEGATIVE = 0
     UNLIKELY = 1
     LIKELY = 2
     POSITIVE = 3
 
     @classmethod
-    def get_num_categories(cls):
+    def get_num_categories(cls) -> int:
         """:returns: The number of likelihood categories in the enum."""
         return 4
 
 
-class CharacterCategory(object):
+class CharacterCategory:
     """
     This enum represents the different categories language models for
     ``SingleByteCharsetProber`` put characters into.
 
     Anything less than CONTROL is considered a letter.
     """
+
     UNDEFINED = 255
     LINE_BREAK = 254
     SYMBOL = 253
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/escprober.py b/env/Lib/site-packages/pip/_vendor/chardet/escprober.py
index c70493f2..fd713830 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/escprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/escprober.py
@@ -25,11 +25,17 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import Optional, Union
+
 from .charsetprober import CharSetProber
 from .codingstatemachine import CodingStateMachine
-from .enums import LanguageFilter, ProbingState, MachineState
-from .escsm import (HZ_SM_MODEL, ISO2022CN_SM_MODEL, ISO2022JP_SM_MODEL,
-                    ISO2022KR_SM_MODEL)
+from .enums import LanguageFilter, MachineState, ProbingState
+from .escsm import (
+    HZ_SM_MODEL,
+    ISO2022CN_SM_MODEL,
+    ISO2022JP_SM_MODEL,
+    ISO2022KR_SM_MODEL,
+)
 
 
 class EscCharSetProber(CharSetProber):
@@ -39,8 +45,8 @@ class EscCharSetProber(CharSetProber):
     identify these encodings.
     """
 
-    def __init__(self, lang_filter=None):
-        super(EscCharSetProber, self).__init__(lang_filter=lang_filter)
+    def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None:
+        super().__init__(lang_filter=lang_filter)
         self.coding_sm = []
         if self.lang_filter & LanguageFilter.CHINESE_SIMPLIFIED:
             self.coding_sm.append(CodingStateMachine(HZ_SM_MODEL))
@@ -49,17 +55,15 @@ class EscCharSetProber(CharSetProber):
             self.coding_sm.append(CodingStateMachine(ISO2022JP_SM_MODEL))
         if self.lang_filter & LanguageFilter.KOREAN:
             self.coding_sm.append(CodingStateMachine(ISO2022KR_SM_MODEL))
-        self.active_sm_count = None
-        self._detected_charset = None
-        self._detected_language = None
-        self._state = None
+        self.active_sm_count = 0
+        self._detected_charset: Optional[str] = None
+        self._detected_language: Optional[str] = None
+        self._state = ProbingState.DETECTING
         self.reset()
 
-    def reset(self):
-        super(EscCharSetProber, self).reset()
+    def reset(self) -> None:
+        super().reset()
         for coding_sm in self.coding_sm:
-            if not coding_sm:
-                continue
             coding_sm.active = True
             coding_sm.reset()
         self.active_sm_count = len(self.coding_sm)
@@ -67,23 +71,20 @@ class EscCharSetProber(CharSetProber):
         self._detected_language = None
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> Optional[str]:
         return self._detected_charset
 
     @property
-    def language(self):
+    def language(self) -> Optional[str]:
         return self._detected_language
 
-    def get_confidence(self):
-        if self._detected_charset:
-            return 0.99
-        else:
-            return 0.00
+    def get_confidence(self) -> float:
+        return 0.99 if self._detected_charset else 0.00
 
-    def feed(self, byte_str):
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
         for c in byte_str:
             for coding_sm in self.coding_sm:
-                if not coding_sm or not coding_sm.active:
+                if not coding_sm.active:
                     continue
                 coding_state = coding_sm.next_state(c)
                 if coding_state == MachineState.ERROR:
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/escsm.py b/env/Lib/site-packages/pip/_vendor/chardet/escsm.py
index 0069523a..11d4adf7 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/escsm.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/escsm.py
@@ -12,7 +12,7 @@
 # This library is free software; you can redistribute it and/or
 # modify it under the terms of the GNU Lesser General Public
 # License as published by the Free Software Foundation; either
-# version 2.1 of the License, or (at your option) any later version.
+# version 2.1 of the License,  or (at your option) any later version.
 #
 # This library is distributed in the hope that it will be useful,
 # but WITHOUT ANY WARRANTY; without even the implied warranty of
@@ -20,227 +20,242 @@
 # Lesser General Public License for more details.
 #
 # You should have received a copy of the GNU Lesser General Public
-# License along with this library; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+# License along with this library; if not,  write to the Free Software
+# Foundation,  Inc.,  51 Franklin St,  Fifth Floor,  Boston,  MA
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from .codingstatemachinedict import CodingStateMachineDict
 from .enums import MachineState
 
+# fmt: off
 HZ_CLS = (
-1,0,0,0,0,0,0,0,  # 00 - 07
-0,0,0,0,0,0,0,0,  # 08 - 0f
-0,0,0,0,0,0,0,0,  # 10 - 17
-0,0,0,1,0,0,0,0,  # 18 - 1f
-0,0,0,0,0,0,0,0,  # 20 - 27
-0,0,0,0,0,0,0,0,  # 28 - 2f
-0,0,0,0,0,0,0,0,  # 30 - 37
-0,0,0,0,0,0,0,0,  # 38 - 3f
-0,0,0,0,0,0,0,0,  # 40 - 47
-0,0,0,0,0,0,0,0,  # 48 - 4f
-0,0,0,0,0,0,0,0,  # 50 - 57
-0,0,0,0,0,0,0,0,  # 58 - 5f
-0,0,0,0,0,0,0,0,  # 60 - 67
-0,0,0,0,0,0,0,0,  # 68 - 6f
-0,0,0,0,0,0,0,0,  # 70 - 77
-0,0,0,4,0,5,2,0,  # 78 - 7f
-1,1,1,1,1,1,1,1,  # 80 - 87
-1,1,1,1,1,1,1,1,  # 88 - 8f
-1,1,1,1,1,1,1,1,  # 90 - 97
-1,1,1,1,1,1,1,1,  # 98 - 9f
-1,1,1,1,1,1,1,1,  # a0 - a7
-1,1,1,1,1,1,1,1,  # a8 - af
-1,1,1,1,1,1,1,1,  # b0 - b7
-1,1,1,1,1,1,1,1,  # b8 - bf
-1,1,1,1,1,1,1,1,  # c0 - c7
-1,1,1,1,1,1,1,1,  # c8 - cf
-1,1,1,1,1,1,1,1,  # d0 - d7
-1,1,1,1,1,1,1,1,  # d8 - df
-1,1,1,1,1,1,1,1,  # e0 - e7
-1,1,1,1,1,1,1,1,  # e8 - ef
-1,1,1,1,1,1,1,1,  # f0 - f7
-1,1,1,1,1,1,1,1,  # f8 - ff
+    1, 0, 0, 0, 0, 0, 0, 0,  # 00 - 07
+    0, 0, 0, 0, 0, 0, 0, 0,  # 08 - 0f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 10 - 17
+    0, 0, 0, 1, 0, 0, 0, 0,  # 18 - 1f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 20 - 27
+    0, 0, 0, 0, 0, 0, 0, 0,  # 28 - 2f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 30 - 37
+    0, 0, 0, 0, 0, 0, 0, 0,  # 38 - 3f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 40 - 47
+    0, 0, 0, 0, 0, 0, 0, 0,  # 48 - 4f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 50 - 57
+    0, 0, 0, 0, 0, 0, 0, 0,  # 58 - 5f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 60 - 67
+    0, 0, 0, 0, 0, 0, 0, 0,  # 68 - 6f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 70 - 77
+    0, 0, 0, 4, 0, 5, 2, 0,  # 78 - 7f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 80 - 87
+    1, 1, 1, 1, 1, 1, 1, 1,  # 88 - 8f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 90 - 97
+    1, 1, 1, 1, 1, 1, 1, 1,  # 98 - 9f
+    1, 1, 1, 1, 1, 1, 1, 1,  # a0 - a7
+    1, 1, 1, 1, 1, 1, 1, 1,  # a8 - af
+    1, 1, 1, 1, 1, 1, 1, 1,  # b0 - b7
+    1, 1, 1, 1, 1, 1, 1, 1,  # b8 - bf
+    1, 1, 1, 1, 1, 1, 1, 1,  # c0 - c7
+    1, 1, 1, 1, 1, 1, 1, 1,  # c8 - cf
+    1, 1, 1, 1, 1, 1, 1, 1,  # d0 - d7
+    1, 1, 1, 1, 1, 1, 1, 1,  # d8 - df
+    1, 1, 1, 1, 1, 1, 1, 1,  # e0 - e7
+    1, 1, 1, 1, 1, 1, 1, 1,  # e8 - ef
+    1, 1, 1, 1, 1, 1, 1, 1,  # f0 - f7
+    1, 1, 1, 1, 1, 1, 1, 1,  # f8 - ff
 )
 
 HZ_ST = (
-MachineState.START,MachineState.ERROR,     3,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f
-MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,     4,MachineState.ERROR,# 10-17
-     5,MachineState.ERROR,     6,MachineState.ERROR,     5,     5,     4,MachineState.ERROR,# 18-1f
-     4,MachineState.ERROR,     4,     4,     4,MachineState.ERROR,     4,MachineState.ERROR,# 20-27
-     4,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 28-2f
+MachineState.START, MachineState.ERROR,      3, MachineState.START, MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, # 00-07
+MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 08-0f
+MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.START, MachineState.START,      4, MachineState.ERROR, # 10-17
+     5, MachineState.ERROR,      6, MachineState.ERROR,      5,      5,      4, MachineState.ERROR, # 18-1f
+     4, MachineState.ERROR,      4,      4,      4, MachineState.ERROR,      4, MachineState.ERROR, # 20-27
+     4, MachineState.ITS_ME, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 28-2f
 )
+# fmt: on
 
 HZ_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0)
 
-HZ_SM_MODEL = {'class_table': HZ_CLS,
-               'class_factor': 6,
-               'state_table': HZ_ST,
-               'char_len_table': HZ_CHAR_LEN_TABLE,
-               'name': "HZ-GB-2312",
-               'language': 'Chinese'}
+HZ_SM_MODEL: CodingStateMachineDict = {
+    "class_table": HZ_CLS,
+    "class_factor": 6,
+    "state_table": HZ_ST,
+    "char_len_table": HZ_CHAR_LEN_TABLE,
+    "name": "HZ-GB-2312",
+    "language": "Chinese",
+}
 
+# fmt: off
 ISO2022CN_CLS = (
-2,0,0,0,0,0,0,0,  # 00 - 07
-0,0,0,0,0,0,0,0,  # 08 - 0f
-0,0,0,0,0,0,0,0,  # 10 - 17
-0,0,0,1,0,0,0,0,  # 18 - 1f
-0,0,0,0,0,0,0,0,  # 20 - 27
-0,3,0,0,0,0,0,0,  # 28 - 2f
-0,0,0,0,0,0,0,0,  # 30 - 37
-0,0,0,0,0,0,0,0,  # 38 - 3f
-0,0,0,4,0,0,0,0,  # 40 - 47
-0,0,0,0,0,0,0,0,  # 48 - 4f
-0,0,0,0,0,0,0,0,  # 50 - 57
-0,0,0,0,0,0,0,0,  # 58 - 5f
-0,0,0,0,0,0,0,0,  # 60 - 67
-0,0,0,0,0,0,0,0,  # 68 - 6f
-0,0,0,0,0,0,0,0,  # 70 - 77
-0,0,0,0,0,0,0,0,  # 78 - 7f
-2,2,2,2,2,2,2,2,  # 80 - 87
-2,2,2,2,2,2,2,2,  # 88 - 8f
-2,2,2,2,2,2,2,2,  # 90 - 97
-2,2,2,2,2,2,2,2,  # 98 - 9f
-2,2,2,2,2,2,2,2,  # a0 - a7
-2,2,2,2,2,2,2,2,  # a8 - af
-2,2,2,2,2,2,2,2,  # b0 - b7
-2,2,2,2,2,2,2,2,  # b8 - bf
-2,2,2,2,2,2,2,2,  # c0 - c7
-2,2,2,2,2,2,2,2,  # c8 - cf
-2,2,2,2,2,2,2,2,  # d0 - d7
-2,2,2,2,2,2,2,2,  # d8 - df
-2,2,2,2,2,2,2,2,  # e0 - e7
-2,2,2,2,2,2,2,2,  # e8 - ef
-2,2,2,2,2,2,2,2,  # f0 - f7
-2,2,2,2,2,2,2,2,  # f8 - ff
+    2, 0, 0, 0, 0, 0, 0, 0,  # 00 - 07
+    0, 0, 0, 0, 0, 0, 0, 0,  # 08 - 0f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 10 - 17
+    0, 0, 0, 1, 0, 0, 0, 0,  # 18 - 1f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 20 - 27
+    0, 3, 0, 0, 0, 0, 0, 0,  # 28 - 2f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 30 - 37
+    0, 0, 0, 0, 0, 0, 0, 0,  # 38 - 3f
+    0, 0, 0, 4, 0, 0, 0, 0,  # 40 - 47
+    0, 0, 0, 0, 0, 0, 0, 0,  # 48 - 4f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 50 - 57
+    0, 0, 0, 0, 0, 0, 0, 0,  # 58 - 5f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 60 - 67
+    0, 0, 0, 0, 0, 0, 0, 0,  # 68 - 6f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 70 - 77
+    0, 0, 0, 0, 0, 0, 0, 0,  # 78 - 7f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 80 - 87
+    2, 2, 2, 2, 2, 2, 2, 2,  # 88 - 8f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 90 - 97
+    2, 2, 2, 2, 2, 2, 2, 2,  # 98 - 9f
+    2, 2, 2, 2, 2, 2, 2, 2,  # a0 - a7
+    2, 2, 2, 2, 2, 2, 2, 2,  # a8 - af
+    2, 2, 2, 2, 2, 2, 2, 2,  # b0 - b7
+    2, 2, 2, 2, 2, 2, 2, 2,  # b8 - bf
+    2, 2, 2, 2, 2, 2, 2, 2,  # c0 - c7
+    2, 2, 2, 2, 2, 2, 2, 2,  # c8 - cf
+    2, 2, 2, 2, 2, 2, 2, 2,  # d0 - d7
+    2, 2, 2, 2, 2, 2, 2, 2,  # d8 - df
+    2, 2, 2, 2, 2, 2, 2, 2,  # e0 - e7
+    2, 2, 2, 2, 2, 2, 2, 2,  # e8 - ef
+    2, 2, 2, 2, 2, 2, 2, 2,  # f0 - f7
+    2, 2, 2, 2, 2, 2, 2, 2,  # f8 - ff
 )
 
 ISO2022CN_ST = (
-MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07
-MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f
-MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17
-MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     4,MachineState.ERROR,# 18-1f
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 20-27
-     5,     6,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 28-2f
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 30-37
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,# 38-3f
+    MachineState.START,      3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 00-07
+    MachineState.START, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 08-0f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 10-17
+    MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR,      4, MachineState.ERROR, # 18-1f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 20-27
+        5,      6, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 28-2f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 30-37
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.START, # 38-3f
 )
+# fmt: on
 
 ISO2022CN_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0)
 
-ISO2022CN_SM_MODEL = {'class_table': ISO2022CN_CLS,
-                      'class_factor': 9,
-                      'state_table': ISO2022CN_ST,
-                      'char_len_table': ISO2022CN_CHAR_LEN_TABLE,
-                      'name': "ISO-2022-CN",
-                      'language': 'Chinese'}
+ISO2022CN_SM_MODEL: CodingStateMachineDict = {
+    "class_table": ISO2022CN_CLS,
+    "class_factor": 9,
+    "state_table": ISO2022CN_ST,
+    "char_len_table": ISO2022CN_CHAR_LEN_TABLE,
+    "name": "ISO-2022-CN",
+    "language": "Chinese",
+}
 
+# fmt: off
 ISO2022JP_CLS = (
-2,0,0,0,0,0,0,0,  # 00 - 07
-0,0,0,0,0,0,2,2,  # 08 - 0f
-0,0,0,0,0,0,0,0,  # 10 - 17
-0,0,0,1,0,0,0,0,  # 18 - 1f
-0,0,0,0,7,0,0,0,  # 20 - 27
-3,0,0,0,0,0,0,0,  # 28 - 2f
-0,0,0,0,0,0,0,0,  # 30 - 37
-0,0,0,0,0,0,0,0,  # 38 - 3f
-6,0,4,0,8,0,0,0,  # 40 - 47
-0,9,5,0,0,0,0,0,  # 48 - 4f
-0,0,0,0,0,0,0,0,  # 50 - 57
-0,0,0,0,0,0,0,0,  # 58 - 5f
-0,0,0,0,0,0,0,0,  # 60 - 67
-0,0,0,0,0,0,0,0,  # 68 - 6f
-0,0,0,0,0,0,0,0,  # 70 - 77
-0,0,0,0,0,0,0,0,  # 78 - 7f
-2,2,2,2,2,2,2,2,  # 80 - 87
-2,2,2,2,2,2,2,2,  # 88 - 8f
-2,2,2,2,2,2,2,2,  # 90 - 97
-2,2,2,2,2,2,2,2,  # 98 - 9f
-2,2,2,2,2,2,2,2,  # a0 - a7
-2,2,2,2,2,2,2,2,  # a8 - af
-2,2,2,2,2,2,2,2,  # b0 - b7
-2,2,2,2,2,2,2,2,  # b8 - bf
-2,2,2,2,2,2,2,2,  # c0 - c7
-2,2,2,2,2,2,2,2,  # c8 - cf
-2,2,2,2,2,2,2,2,  # d0 - d7
-2,2,2,2,2,2,2,2,  # d8 - df
-2,2,2,2,2,2,2,2,  # e0 - e7
-2,2,2,2,2,2,2,2,  # e8 - ef
-2,2,2,2,2,2,2,2,  # f0 - f7
-2,2,2,2,2,2,2,2,  # f8 - ff
+    2, 0, 0, 0, 0, 0, 0, 0,  # 00 - 07
+    0, 0, 0, 0, 0, 0, 2, 2,  # 08 - 0f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 10 - 17
+    0, 0, 0, 1, 0, 0, 0, 0,  # 18 - 1f
+    0, 0, 0, 0, 7, 0, 0, 0,  # 20 - 27
+    3, 0, 0, 0, 0, 0, 0, 0,  # 28 - 2f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 30 - 37
+    0, 0, 0, 0, 0, 0, 0, 0,  # 38 - 3f
+    6, 0, 4, 0, 8, 0, 0, 0,  # 40 - 47
+    0, 9, 5, 0, 0, 0, 0, 0,  # 48 - 4f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 50 - 57
+    0, 0, 0, 0, 0, 0, 0, 0,  # 58 - 5f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 60 - 67
+    0, 0, 0, 0, 0, 0, 0, 0,  # 68 - 6f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 70 - 77
+    0, 0, 0, 0, 0, 0, 0, 0,  # 78 - 7f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 80 - 87
+    2, 2, 2, 2, 2, 2, 2, 2,  # 88 - 8f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 90 - 97
+    2, 2, 2, 2, 2, 2, 2, 2,  # 98 - 9f
+    2, 2, 2, 2, 2, 2, 2, 2,  # a0 - a7
+    2, 2, 2, 2, 2, 2, 2, 2,  # a8 - af
+    2, 2, 2, 2, 2, 2, 2, 2,  # b0 - b7
+    2, 2, 2, 2, 2, 2, 2, 2,  # b8 - bf
+    2, 2, 2, 2, 2, 2, 2, 2,  # c0 - c7
+    2, 2, 2, 2, 2, 2, 2, 2,  # c8 - cf
+    2, 2, 2, 2, 2, 2, 2, 2,  # d0 - d7
+    2, 2, 2, 2, 2, 2, 2, 2,  # d8 - df
+    2, 2, 2, 2, 2, 2, 2, 2,  # e0 - e7
+    2, 2, 2, 2, 2, 2, 2, 2,  # e8 - ef
+    2, 2, 2, 2, 2, 2, 2, 2,  # f0 - f7
+    2, 2, 2, 2, 2, 2, 2, 2,  # f8 - ff
 )
 
 ISO2022JP_ST = (
-MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 00-07
-MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 08-0f
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 10-17
-MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,# 18-1f
-MachineState.ERROR,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     4,MachineState.ERROR,MachineState.ERROR,# 20-27
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     6,MachineState.ITS_ME,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,# 28-2f
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,# 30-37
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 38-3f
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,MachineState.START,MachineState.START,# 40-47
+    MachineState.START,      3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 00-07
+    MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 08-0f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 10-17
+    MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, # 18-1f
+    MachineState.ERROR,      5, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR,      4, MachineState.ERROR, MachineState.ERROR, # 20-27
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR,      6, MachineState.ITS_ME, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, # 28-2f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, # 30-37
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 38-3f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ERROR, MachineState.START, MachineState.START, # 40-47
 )
+# fmt: on
 
 ISO2022JP_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0, 0, 0, 0, 0)
 
-ISO2022JP_SM_MODEL = {'class_table': ISO2022JP_CLS,
-                      'class_factor': 10,
-                      'state_table': ISO2022JP_ST,
-                      'char_len_table': ISO2022JP_CHAR_LEN_TABLE,
-                      'name': "ISO-2022-JP",
-                      'language': 'Japanese'}
+ISO2022JP_SM_MODEL: CodingStateMachineDict = {
+    "class_table": ISO2022JP_CLS,
+    "class_factor": 10,
+    "state_table": ISO2022JP_ST,
+    "char_len_table": ISO2022JP_CHAR_LEN_TABLE,
+    "name": "ISO-2022-JP",
+    "language": "Japanese",
+}
 
+# fmt: off
 ISO2022KR_CLS = (
-2,0,0,0,0,0,0,0,  # 00 - 07
-0,0,0,0,0,0,0,0,  # 08 - 0f
-0,0,0,0,0,0,0,0,  # 10 - 17
-0,0,0,1,0,0,0,0,  # 18 - 1f
-0,0,0,0,3,0,0,0,  # 20 - 27
-0,4,0,0,0,0,0,0,  # 28 - 2f
-0,0,0,0,0,0,0,0,  # 30 - 37
-0,0,0,0,0,0,0,0,  # 38 - 3f
-0,0,0,5,0,0,0,0,  # 40 - 47
-0,0,0,0,0,0,0,0,  # 48 - 4f
-0,0,0,0,0,0,0,0,  # 50 - 57
-0,0,0,0,0,0,0,0,  # 58 - 5f
-0,0,0,0,0,0,0,0,  # 60 - 67
-0,0,0,0,0,0,0,0,  # 68 - 6f
-0,0,0,0,0,0,0,0,  # 70 - 77
-0,0,0,0,0,0,0,0,  # 78 - 7f
-2,2,2,2,2,2,2,2,  # 80 - 87
-2,2,2,2,2,2,2,2,  # 88 - 8f
-2,2,2,2,2,2,2,2,  # 90 - 97
-2,2,2,2,2,2,2,2,  # 98 - 9f
-2,2,2,2,2,2,2,2,  # a0 - a7
-2,2,2,2,2,2,2,2,  # a8 - af
-2,2,2,2,2,2,2,2,  # b0 - b7
-2,2,2,2,2,2,2,2,  # b8 - bf
-2,2,2,2,2,2,2,2,  # c0 - c7
-2,2,2,2,2,2,2,2,  # c8 - cf
-2,2,2,2,2,2,2,2,  # d0 - d7
-2,2,2,2,2,2,2,2,  # d8 - df
-2,2,2,2,2,2,2,2,  # e0 - e7
-2,2,2,2,2,2,2,2,  # e8 - ef
-2,2,2,2,2,2,2,2,  # f0 - f7
-2,2,2,2,2,2,2,2,  # f8 - ff
+    2, 0, 0, 0, 0, 0, 0, 0,  # 00 - 07
+    0, 0, 0, 0, 0, 0, 0, 0,  # 08 - 0f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 10 - 17
+    0, 0, 0, 1, 0, 0, 0, 0,  # 18 - 1f
+    0, 0, 0, 0, 3, 0, 0, 0,  # 20 - 27
+    0, 4, 0, 0, 0, 0, 0, 0,  # 28 - 2f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 30 - 37
+    0, 0, 0, 0, 0, 0, 0, 0,  # 38 - 3f
+    0, 0, 0, 5, 0, 0, 0, 0,  # 40 - 47
+    0, 0, 0, 0, 0, 0, 0, 0,  # 48 - 4f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 50 - 57
+    0, 0, 0, 0, 0, 0, 0, 0,  # 58 - 5f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 60 - 67
+    0, 0, 0, 0, 0, 0, 0, 0,  # 68 - 6f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 70 - 77
+    0, 0, 0, 0, 0, 0, 0, 0,  # 78 - 7f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 80 - 87
+    2, 2, 2, 2, 2, 2, 2, 2,  # 88 - 8f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 90 - 97
+    2, 2, 2, 2, 2, 2, 2, 2,  # 98 - 9f
+    2, 2, 2, 2, 2, 2, 2, 2,  # a0 - a7
+    2, 2, 2, 2, 2, 2, 2, 2,  # a8 - af
+    2, 2, 2, 2, 2, 2, 2, 2,  # b0 - b7
+    2, 2, 2, 2, 2, 2, 2, 2,  # b8 - bf
+    2, 2, 2, 2, 2, 2, 2, 2,  # c0 - c7
+    2, 2, 2, 2, 2, 2, 2, 2,  # c8 - cf
+    2, 2, 2, 2, 2, 2, 2, 2,  # d0 - d7
+    2, 2, 2, 2, 2, 2, 2, 2,  # d8 - df
+    2, 2, 2, 2, 2, 2, 2, 2,  # e0 - e7
+    2, 2, 2, 2, 2, 2, 2, 2,  # e8 - ef
+    2, 2, 2, 2, 2, 2, 2, 2,  # f0 - f7
+    2, 2, 2, 2, 2, 2, 2, 2,  # f8 - ff
 )
 
 ISO2022KR_ST = (
-MachineState.START,     3,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,# 00-07
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,# 08-0f
-MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     4,MachineState.ERROR,MachineState.ERROR,# 10-17
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,# 18-1f
-MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.START,MachineState.START,MachineState.START,MachineState.START,# 20-27
+    MachineState.START,      3, MachineState.ERROR, MachineState.START, MachineState.START, MachineState.START, MachineState.ERROR, MachineState.ERROR, # 00-07
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ITS_ME, # 08-0f
+    MachineState.ITS_ME, MachineState.ITS_ME, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR,      4, MachineState.ERROR, MachineState.ERROR, # 10-17
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR,      5, MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, # 18-1f
+    MachineState.ERROR, MachineState.ERROR, MachineState.ERROR, MachineState.ITS_ME, MachineState.START, MachineState.START, MachineState.START, MachineState.START, # 20-27
 )
+# fmt: on
 
 ISO2022KR_CHAR_LEN_TABLE = (0, 0, 0, 0, 0, 0)
 
-ISO2022KR_SM_MODEL = {'class_table': ISO2022KR_CLS,
-                      'class_factor': 6,
-                      'state_table': ISO2022KR_ST,
-                      'char_len_table': ISO2022KR_CHAR_LEN_TABLE,
-                      'name': "ISO-2022-KR",
-                      'language': 'Korean'}
-
-
+ISO2022KR_SM_MODEL: CodingStateMachineDict = {
+    "class_table": ISO2022KR_CLS,
+    "class_factor": 6,
+    "state_table": ISO2022KR_ST,
+    "char_len_table": ISO2022KR_CHAR_LEN_TABLE,
+    "name": "ISO-2022-KR",
+    "language": "Korean",
+}
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py b/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py
index 20ce8f7d..39487f40 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/eucjpprober.py
@@ -25,68 +25,78 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .enums import ProbingState, MachineState
-from .mbcharsetprober import MultiByteCharSetProber
-from .codingstatemachine import CodingStateMachine
+from typing import Union
+
 from .chardistribution import EUCJPDistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .enums import MachineState, ProbingState
 from .jpcntx import EUCJPContextAnalysis
+from .mbcharsetprober import MultiByteCharSetProber
 from .mbcssm import EUCJP_SM_MODEL
 
 
 class EUCJPProber(MultiByteCharSetProber):
-    def __init__(self):
-        super(EUCJPProber, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(EUCJP_SM_MODEL)
         self.distribution_analyzer = EUCJPDistributionAnalysis()
         self.context_analyzer = EUCJPContextAnalysis()
         self.reset()
 
-    def reset(self):
-        super(EUCJPProber, self).reset()
+    def reset(self) -> None:
+        super().reset()
         self.context_analyzer.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "EUC-JP"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Japanese"
 
-    def feed(self, byte_str):
-        for i in range(len(byte_str)):
-            # PY3K: byte_str is a byte array, so byte_str[i] is an int, not a byte
-            coding_state = self.coding_sm.next_state(byte_str[i])
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
+        assert self.coding_sm is not None
+        assert self.distribution_analyzer is not None
+
+        for i, byte in enumerate(byte_str):
+            # PY3K: byte_str is a byte array, so byte is an int, not a byte
+            coding_state = self.coding_sm.next_state(byte)
             if coding_state == MachineState.ERROR:
-                self.logger.debug('%s %s prober hit error at byte %s',
-                                  self.charset_name, self.language, i)
+                self.logger.debug(
+                    "%s %s prober hit error at byte %s",
+                    self.charset_name,
+                    self.language,
+                    i,
+                )
                 self._state = ProbingState.NOT_ME
                 break
-            elif coding_state == MachineState.ITS_ME:
+            if coding_state == MachineState.ITS_ME:
                 self._state = ProbingState.FOUND_IT
                 break
-            elif coding_state == MachineState.START:
+            if coding_state == MachineState.START:
                 char_len = self.coding_sm.get_current_charlen()
                 if i == 0:
-                    self._last_char[1] = byte_str[0]
+                    self._last_char[1] = byte
                     self.context_analyzer.feed(self._last_char, char_len)
                     self.distribution_analyzer.feed(self._last_char, char_len)
                 else:
-                    self.context_analyzer.feed(byte_str[i - 1:i + 1],
-                                                char_len)
-                    self.distribution_analyzer.feed(byte_str[i - 1:i + 1],
-                                                     char_len)
+                    self.context_analyzer.feed(byte_str[i - 1 : i + 1], char_len)
+                    self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len)
 
         self._last_char[0] = byte_str[-1]
 
         if self.state == ProbingState.DETECTING:
-            if (self.context_analyzer.got_enough_data() and
-               (self.get_confidence() > self.SHORTCUT_THRESHOLD)):
+            if self.context_analyzer.got_enough_data() and (
+                self.get_confidence() > self.SHORTCUT_THRESHOLD
+            ):
                 self._state = ProbingState.FOUND_IT
 
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
+        assert self.distribution_analyzer is not None
+
         context_conf = self.context_analyzer.get_confidence()
         distrib_conf = self.distribution_analyzer.get_confidence()
         return max(context_conf, distrib_conf)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py b/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py
index b68078cb..7dc3b103 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/euckrfreq.py
@@ -43,6 +43,7 @@ EUCKR_TYPICAL_DISTRIBUTION_RATIO = 6.0
 EUCKR_TABLE_SIZE = 2352
 
 # Char to FreqOrder table ,
+# fmt: off
 EUCKR_CHAR_TO_FREQ_ORDER = (
   13, 130, 120,1396, 481,1719,1720, 328, 609, 212,1721, 707, 400, 299,1722,  87,
 1397,1723, 104, 536,1117,1203,1724,1267, 685,1268, 508,1725,1726,1727,1728,1398,
@@ -192,4 +193,4 @@ EUCKR_CHAR_TO_FREQ_ORDER = (
 2629,2630,2631, 924, 648, 863, 603,2632,2633, 934,1540, 864, 865,2634, 642,1042,
  670,1190,2635,2636,2637,2638, 168,2639, 652, 873, 542,1054,1541,2640,2641,2642,  # 512, 256
 )
-
+# fmt: on
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py b/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py
index 345a060d..1fc5de04 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/euckrprober.py
@@ -25,23 +25,23 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .mbcharsetprober import MultiByteCharSetProber
-from .codingstatemachine import CodingStateMachine
 from .chardistribution import EUCKRDistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .mbcharsetprober import MultiByteCharSetProber
 from .mbcssm import EUCKR_SM_MODEL
 
 
 class EUCKRProber(MultiByteCharSetProber):
-    def __init__(self):
-        super(EUCKRProber, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(EUCKR_SM_MODEL)
         self.distribution_analyzer = EUCKRDistributionAnalysis()
         self.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "EUC-KR"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Korean"
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py b/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py
index ed7a995a..4900ccc1 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/euctwfreq.py
@@ -43,345 +43,346 @@
 
 EUCTW_TYPICAL_DISTRIBUTION_RATIO = 0.75
 
-# Char to FreqOrder table ,
+# Char to FreqOrder table
 EUCTW_TABLE_SIZE = 5376
 
+# fmt: off
 EUCTW_CHAR_TO_FREQ_ORDER = (
-   1,1800,1506, 255,1431, 198,   9,  82,   6,7310, 177, 202,3615,1256,2808, 110,  # 2742
-3735,  33,3241, 261,  76,  44,2113,  16,2931,2184,1176, 659,3868,  26,3404,2643,  # 2758
-1198,3869,3313,4060, 410,2211, 302, 590, 361,1963,   8, 204,  58,4296,7311,1931,  # 2774
-  63,7312,7313, 317,1614,  75, 222, 159,4061,2412,1480,7314,3500,3068, 224,2809,  # 2790
-3616,   3,  10,3870,1471,  29,2774,1135,2852,1939, 873, 130,3242,1123, 312,7315,  # 2806
-4297,2051, 507, 252, 682,7316, 142,1914, 124, 206,2932,  34,3501,3173,  64, 604,  # 2822
-7317,2494,1976,1977, 155,1990, 645, 641,1606,7318,3405, 337,  72, 406,7319,  80,  # 2838
- 630, 238,3174,1509, 263, 939,1092,2644, 756,1440,1094,3406, 449,  69,2969, 591,  # 2854
- 179,2095, 471, 115,2034,1843,  60,  50,2970, 134, 806,1868, 734,2035,3407, 180,  # 2870
- 995,1607, 156, 537,2893, 688,7320, 319,1305, 779,2144, 514,2374, 298,4298, 359,  # 2886
-2495,  90,2707,1338, 663,  11, 906,1099,2545,  20,2436, 182, 532,1716,7321, 732,  # 2902
-1376,4062,1311,1420,3175,  25,2312,1056, 113, 399, 382,1949, 242,3408,2467, 529,  # 2918
-3243, 475,1447,3617,7322, 117,  21, 656, 810,1297,2295,2329,3502,7323, 126,4063,  # 2934
- 706, 456, 150, 613,4299,  71,1118,2036,4064, 145,3069,  85, 835, 486,2114,1246,  # 2950
-1426, 428, 727,1285,1015, 800, 106, 623, 303,1281,7324,2127,2354, 347,3736, 221,  # 2966
-3503,3110,7325,1955,1153,4065,  83, 296,1199,3070, 192, 624,  93,7326, 822,1897,  # 2982
-2810,3111, 795,2064, 991,1554,1542,1592,  27,  43,2853, 859, 139,1456, 860,4300,  # 2998
- 437, 712,3871, 164,2392,3112, 695, 211,3017,2096, 195,3872,1608,3504,3505,3618,  # 3014
-3873, 234, 811,2971,2097,3874,2229,1441,3506,1615,2375, 668,2076,1638, 305, 228,  # 3030
-1664,4301, 467, 415,7327, 262,2098,1593, 239, 108, 300, 200,1033, 512,1247,2077,  # 3046
-7328,7329,2173,3176,3619,2673, 593, 845,1062,3244,  88,1723,2037,3875,1950, 212,  # 3062
- 266, 152, 149, 468,1898,4066,4302,  77, 187,7330,3018,  37,   5,2972,7331,3876,  # 3078
-7332,7333,  39,2517,4303,2894,3177,2078,  55, 148,  74,4304, 545, 483,1474,1029,  # 3094
-1665, 217,1869,1531,3113,1104,2645,4067,  24, 172,3507, 900,3877,3508,3509,4305,  # 3110
-  32,1408,2811,1312, 329, 487,2355,2247,2708, 784,2674,   4,3019,3314,1427,1788,  # 3126
- 188, 109, 499,7334,3620,1717,1789, 888,1217,3020,4306,7335,3510,7336,3315,1520,  # 3142
-3621,3878, 196,1034, 775,7337,7338, 929,1815, 249, 439,  38,7339,1063,7340, 794,  # 3158
-3879,1435,2296,  46, 178,3245,2065,7341,2376,7342, 214,1709,4307, 804,  35, 707,  # 3174
- 324,3622,1601,2546, 140, 459,4068,7343,7344,1365, 839, 272, 978,2257,2572,3409,  # 3190
-2128,1363,3623,1423, 697, 100,3071,  48,  70,1231, 495,3114,2193,7345,1294,7346,  # 3206
-2079, 462, 586,1042,3246, 853, 256, 988, 185,2377,3410,1698, 434,1084,7347,3411,  # 3222
- 314,2615,2775,4308,2330,2331, 569,2280, 637,1816,2518, 757,1162,1878,1616,3412,  # 3238
- 287,1577,2115, 768,4309,1671,2854,3511,2519,1321,3737, 909,2413,7348,4069, 933,  # 3254
-3738,7349,2052,2356,1222,4310, 765,2414,1322, 786,4311,7350,1919,1462,1677,2895,  # 3270
-1699,7351,4312,1424,2437,3115,3624,2590,3316,1774,1940,3413,3880,4070, 309,1369,  # 3286
-1130,2812, 364,2230,1653,1299,3881,3512,3882,3883,2646, 525,1085,3021, 902,2000,  # 3302
-1475, 964,4313, 421,1844,1415,1057,2281, 940,1364,3116, 376,4314,4315,1381,   7,  # 3318
-2520, 983,2378, 336,1710,2675,1845, 321,3414, 559,1131,3022,2742,1808,1132,1313,  # 3334
- 265,1481,1857,7352, 352,1203,2813,3247, 167,1089, 420,2814, 776, 792,1724,3513,  # 3350
-4071,2438,3248,7353,4072,7354, 446, 229, 333,2743, 901,3739,1200,1557,4316,2647,  # 3366
-1920, 395,2744,2676,3740,4073,1835, 125, 916,3178,2616,4317,7355,7356,3741,7357,  # 3382
-7358,7359,4318,3117,3625,1133,2547,1757,3415,1510,2313,1409,3514,7360,2145, 438,  # 3398
-2591,2896,2379,3317,1068, 958,3023, 461, 311,2855,2677,4074,1915,3179,4075,1978,  # 3414
- 383, 750,2745,2617,4076, 274, 539, 385,1278,1442,7361,1154,1964, 384, 561, 210,  # 3430
-  98,1295,2548,3515,7362,1711,2415,1482,3416,3884,2897,1257, 129,7363,3742, 642,  # 3446
- 523,2776,2777,2648,7364, 141,2231,1333,  68, 176, 441, 876, 907,4077, 603,2592,  # 3462
- 710, 171,3417, 404, 549,  18,3118,2393,1410,3626,1666,7365,3516,4319,2898,4320,  # 3478
-7366,2973, 368,7367, 146, 366,  99, 871,3627,1543, 748, 807,1586,1185,  22,2258,  # 3494
- 379,3743,3180,7368,3181, 505,1941,2618,1991,1382,2314,7369, 380,2357, 218, 702,  # 3510
-1817,1248,3418,3024,3517,3318,3249,7370,2974,3628, 930,3250,3744,7371,  59,7372,  # 3526
- 585, 601,4078, 497,3419,1112,1314,4321,1801,7373,1223,1472,2174,7374, 749,1836,  # 3542
- 690,1899,3745,1772,3885,1476, 429,1043,1790,2232,2116, 917,4079, 447,1086,1629,  # 3558
-7375, 556,7376,7377,2020,1654, 844,1090, 105, 550, 966,1758,2815,1008,1782, 686,  # 3574
-1095,7378,2282, 793,1602,7379,3518,2593,4322,4080,2933,2297,4323,3746, 980,2496,  # 3590
- 544, 353, 527,4324, 908,2678,2899,7380, 381,2619,1942,1348,7381,1341,1252, 560,  # 3606
-3072,7382,3420,2856,7383,2053, 973, 886,2080, 143,4325,7384,7385, 157,3886, 496,  # 3622
-4081,  57, 840, 540,2038,4326,4327,3421,2117,1445, 970,2259,1748,1965,2081,4082,  # 3638
-3119,1234,1775,3251,2816,3629, 773,1206,2129,1066,2039,1326,3887,1738,1725,4083,  # 3654
- 279,3120,  51,1544,2594, 423,1578,2130,2066, 173,4328,1879,7386,7387,1583, 264,  # 3670
- 610,3630,4329,2439, 280, 154,7388,7389,7390,1739, 338,1282,3073, 693,2857,1411,  # 3686
-1074,3747,2440,7391,4330,7392,7393,1240, 952,2394,7394,2900,1538,2679, 685,1483,  # 3702
-4084,2468,1436, 953,4085,2054,4331, 671,2395,  79,4086,2441,3252, 608, 567,2680,  # 3718
-3422,4087,4088,1691, 393,1261,1791,2396,7395,4332,7396,7397,7398,7399,1383,1672,  # 3734
-3748,3182,1464, 522,1119, 661,1150, 216, 675,4333,3888,1432,3519, 609,4334,2681,  # 3750
-2397,7400,7401,7402,4089,3025,   0,7403,2469, 315, 231,2442, 301,3319,4335,2380,  # 3766
-7404, 233,4090,3631,1818,4336,4337,7405,  96,1776,1315,2082,7406, 257,7407,1809,  # 3782
-3632,2709,1139,1819,4091,2021,1124,2163,2778,1777,2649,7408,3074, 363,1655,3183,  # 3798
-7409,2975,7410,7411,7412,3889,1567,3890, 718, 103,3184, 849,1443, 341,3320,2934,  # 3814
-1484,7413,1712, 127,  67, 339,4092,2398, 679,1412, 821,7414,7415, 834, 738, 351,  # 3830
-2976,2146, 846, 235,1497,1880, 418,1992,3749,2710, 186,1100,2147,2746,3520,1545,  # 3846
-1355,2935,2858,1377, 583,3891,4093,2573,2977,7416,1298,3633,1078,2549,3634,2358,  # 3862
-  78,3750,3751, 267,1289,2099,2001,1594,4094, 348, 369,1274,2194,2175,1837,4338,  # 3878
-1820,2817,3635,2747,2283,2002,4339,2936,2748, 144,3321, 882,4340,3892,2749,3423,  # 3894
-4341,2901,7417,4095,1726, 320,7418,3893,3026, 788,2978,7419,2818,1773,1327,2859,  # 3910
-3894,2819,7420,1306,4342,2003,1700,3752,3521,2359,2650, 787,2022, 506, 824,3636,  # 3926
- 534, 323,4343,1044,3322,2023,1900, 946,3424,7421,1778,1500,1678,7422,1881,4344,  # 3942
- 165, 243,4345,3637,2521, 123, 683,4096, 764,4346,  36,3895,1792, 589,2902, 816,  # 3958
- 626,1667,3027,2233,1639,1555,1622,3753,3896,7423,3897,2860,1370,1228,1932, 891,  # 3974
-2083,2903, 304,4097,7424, 292,2979,2711,3522, 691,2100,4098,1115,4347, 118, 662,  # 3990
-7425, 611,1156, 854,2381,1316,2861,   2, 386, 515,2904,7426,7427,3253, 868,2234,  # 4006
-1486, 855,2651, 785,2212,3028,7428,1040,3185,3523,7429,3121, 448,7430,1525,7431,  # 4022
-2164,4348,7432,3754,7433,4099,2820,3524,3122, 503, 818,3898,3123,1568, 814, 676,  # 4038
-1444, 306,1749,7434,3755,1416,1030, 197,1428, 805,2821,1501,4349,7435,7436,7437,  # 4054
-1993,7438,4350,7439,7440,2195,  13,2779,3638,2980,3124,1229,1916,7441,3756,2131,  # 4070
-7442,4100,4351,2399,3525,7443,2213,1511,1727,1120,7444,7445, 646,3757,2443, 307,  # 4086
-7446,7447,1595,3186,7448,7449,7450,3639,1113,1356,3899,1465,2522,2523,7451, 519,  # 4102
-7452, 128,2132,  92,2284,1979,7453,3900,1512, 342,3125,2196,7454,2780,2214,1980,  # 4118
-3323,7455, 290,1656,1317, 789, 827,2360,7456,3758,4352, 562, 581,3901,7457, 401,  # 4134
-4353,2248,  94,4354,1399,2781,7458,1463,2024,4355,3187,1943,7459, 828,1105,4101,  # 4150
-1262,1394,7460,4102, 605,4356,7461,1783,2862,7462,2822, 819,2101, 578,2197,2937,  # 4166
-7463,1502, 436,3254,4103,3255,2823,3902,2905,3425,3426,7464,2712,2315,7465,7466,  # 4182
-2332,2067,  23,4357, 193, 826,3759,2102, 699,1630,4104,3075, 390,1793,1064,3526,  # 4198
-7467,1579,3076,3077,1400,7468,4105,1838,1640,2863,7469,4358,4359, 137,4106, 598,  # 4214
-3078,1966, 780, 104, 974,2938,7470, 278, 899, 253, 402, 572, 504, 493,1339,7471,  # 4230
-3903,1275,4360,2574,2550,7472,3640,3029,3079,2249, 565,1334,2713, 863,  41,7473,  # 4246
-7474,4361,7475,1657,2333,  19, 463,2750,4107, 606,7476,2981,3256,1087,2084,1323,  # 4262
-2652,2982,7477,1631,1623,1750,4108,2682,7478,2864, 791,2714,2653,2334, 232,2416,  # 4278
-7479,2983,1498,7480,2654,2620, 755,1366,3641,3257,3126,2025,1609, 119,1917,3427,  # 4294
- 862,1026,4109,7481,3904,3760,4362,3905,4363,2260,1951,2470,7482,1125, 817,4110,  # 4310
-4111,3906,1513,1766,2040,1487,4112,3030,3258,2824,3761,3127,7483,7484,1507,7485,  # 4326
-2683, 733,  40,1632,1106,2865, 345,4113, 841,2524, 230,4364,2984,1846,3259,3428,  # 4342
-7486,1263, 986,3429,7487, 735, 879, 254,1137, 857, 622,1300,1180,1388,1562,3907,  # 4358
-3908,2939, 967,2751,2655,1349, 592,2133,1692,3324,2985,1994,4114,1679,3909,1901,  # 4374
-2185,7488, 739,3642,2715,1296,1290,7489,4115,2198,2199,1921,1563,2595,2551,1870,  # 4390
-2752,2986,7490, 435,7491, 343,1108, 596,  17,1751,4365,2235,3430,3643,7492,4366,  # 4406
- 294,3527,2940,1693, 477, 979, 281,2041,3528, 643,2042,3644,2621,2782,2261,1031,  # 4422
-2335,2134,2298,3529,4367, 367,1249,2552,7493,3530,7494,4368,1283,3325,2004, 240,  # 4438
-1762,3326,4369,4370, 836,1069,3128, 474,7495,2148,2525, 268,3531,7496,3188,1521,  # 4454
-1284,7497,1658,1546,4116,7498,3532,3533,7499,4117,3327,2684,1685,4118, 961,1673,  # 4470
-2622, 190,2005,2200,3762,4371,4372,7500, 570,2497,3645,1490,7501,4373,2623,3260,  # 4486
-1956,4374, 584,1514, 396,1045,1944,7502,4375,1967,2444,7503,7504,4376,3910, 619,  # 4502
-7505,3129,3261, 215,2006,2783,2553,3189,4377,3190,4378, 763,4119,3763,4379,7506,  # 4518
-7507,1957,1767,2941,3328,3646,1174, 452,1477,4380,3329,3130,7508,2825,1253,2382,  # 4534
-2186,1091,2285,4120, 492,7509, 638,1169,1824,2135,1752,3911, 648, 926,1021,1324,  # 4550
-4381, 520,4382, 997, 847,1007, 892,4383,3764,2262,1871,3647,7510,2400,1784,4384,  # 4566
-1952,2942,3080,3191,1728,4121,2043,3648,4385,2007,1701,3131,1551,  30,2263,4122,  # 4582
-7511,2026,4386,3534,7512, 501,7513,4123, 594,3431,2165,1821,3535,3432,3536,3192,  # 4598
- 829,2826,4124,7514,1680,3132,1225,4125,7515,3262,4387,4126,3133,2336,7516,4388,  # 4614
-4127,7517,3912,3913,7518,1847,2383,2596,3330,7519,4389, 374,3914, 652,4128,4129,  # 4630
- 375,1140, 798,7520,7521,7522,2361,4390,2264, 546,1659, 138,3031,2445,4391,7523,  # 4646
-2250, 612,1848, 910, 796,3765,1740,1371, 825,3766,3767,7524,2906,2554,7525, 692,  # 4662
- 444,3032,2624, 801,4392,4130,7526,1491, 244,1053,3033,4131,4132, 340,7527,3915,  # 4678
-1041,2987, 293,1168,  87,1357,7528,1539, 959,7529,2236, 721, 694,4133,3768, 219,  # 4694
-1478, 644,1417,3331,2656,1413,1401,1335,1389,3916,7530,7531,2988,2362,3134,1825,  # 4710
- 730,1515, 184,2827,  66,4393,7532,1660,2943, 246,3332, 378,1457, 226,3433, 975,  # 4726
-3917,2944,1264,3537, 674, 696,7533, 163,7534,1141,2417,2166, 713,3538,3333,4394,  # 4742
-3918,7535,7536,1186,  15,7537,1079,1070,7538,1522,3193,3539, 276,1050,2716, 758,  # 4758
-1126, 653,2945,3263,7539,2337, 889,3540,3919,3081,2989, 903,1250,4395,3920,3434,  # 4774
-3541,1342,1681,1718, 766,3264, 286,  89,2946,3649,7540,1713,7541,2597,3334,2990,  # 4790
-7542,2947,2215,3194,2866,7543,4396,2498,2526, 181, 387,1075,3921, 731,2187,3335,  # 4806
-7544,3265, 310, 313,3435,2299, 770,4134,  54,3034, 189,4397,3082,3769,3922,7545,  # 4822
-1230,1617,1849, 355,3542,4135,4398,3336, 111,4136,3650,1350,3135,3436,3035,4137,  # 4838
-2149,3266,3543,7546,2784,3923,3924,2991, 722,2008,7547,1071, 247,1207,2338,2471,  # 4854
-1378,4399,2009, 864,1437,1214,4400, 373,3770,1142,2216, 667,4401, 442,2753,2555,  # 4870
-3771,3925,1968,4138,3267,1839, 837, 170,1107, 934,1336,1882,7548,7549,2118,4139,  # 4886
-2828, 743,1569,7550,4402,4140, 582,2384,1418,3437,7551,1802,7552, 357,1395,1729,  # 4902
-3651,3268,2418,1564,2237,7553,3083,3772,1633,4403,1114,2085,4141,1532,7554, 482,  # 4918
-2446,4404,7555,7556,1492, 833,1466,7557,2717,3544,1641,2829,7558,1526,1272,3652,  # 4934
-4142,1686,1794, 416,2556,1902,1953,1803,7559,3773,2785,3774,1159,2316,7560,2867,  # 4950
-4405,1610,1584,3036,2419,2754, 443,3269,1163,3136,7561,7562,3926,7563,4143,2499,  # 4966
-3037,4406,3927,3137,2103,1647,3545,2010,1872,4144,7564,4145, 431,3438,7565, 250,  # 4982
-  97,  81,4146,7566,1648,1850,1558, 160, 848,7567, 866, 740,1694,7568,2201,2830,  # 4998
-3195,4147,4407,3653,1687, 950,2472, 426, 469,3196,3654,3655,3928,7569,7570,1188,  # 5014
- 424,1995, 861,3546,4148,3775,2202,2685, 168,1235,3547,4149,7571,2086,1674,4408,  # 5030
-3337,3270, 220,2557,1009,7572,3776, 670,2992, 332,1208, 717,7573,7574,3548,2447,  # 5046
-3929,3338,7575, 513,7576,1209,2868,3339,3138,4409,1080,7577,7578,7579,7580,2527,  # 5062
-3656,3549, 815,1587,3930,3931,7581,3550,3439,3777,1254,4410,1328,3038,1390,3932,  # 5078
-1741,3933,3778,3934,7582, 236,3779,2448,3271,7583,7584,3657,3780,1273,3781,4411,  # 5094
-7585, 308,7586,4412, 245,4413,1851,2473,1307,2575, 430, 715,2136,2449,7587, 270,  # 5110
- 199,2869,3935,7588,3551,2718,1753, 761,1754, 725,1661,1840,4414,3440,3658,7589,  # 5126
-7590, 587,  14,3272, 227,2598, 326, 480,2265, 943,2755,3552, 291, 650,1883,7591,  # 5142
-1702,1226, 102,1547,  62,3441, 904,4415,3442,1164,4150,7592,7593,1224,1548,2756,  # 5158
- 391, 498,1493,7594,1386,1419,7595,2055,1177,4416, 813, 880,1081,2363, 566,1145,  # 5174
-4417,2286,1001,1035,2558,2599,2238, 394,1286,7596,7597,2068,7598,  86,1494,1730,  # 5190
-3936, 491,1588, 745, 897,2948, 843,3340,3937,2757,2870,3273,1768, 998,2217,2069,  # 5206
- 397,1826,1195,1969,3659,2993,3341, 284,7599,3782,2500,2137,2119,1903,7600,3938,  # 5222
-2150,3939,4151,1036,3443,1904, 114,2559,4152, 209,1527,7601,7602,2949,2831,2625,  # 5238
-2385,2719,3139, 812,2560,7603,3274,7604,1559, 737,1884,3660,1210, 885,  28,2686,  # 5254
-3553,3783,7605,4153,1004,1779,4418,7606, 346,1981,2218,2687,4419,3784,1742, 797,  # 5270
-1642,3940,1933,1072,1384,2151, 896,3941,3275,3661,3197,2871,3554,7607,2561,1958,  # 5286
-4420,2450,1785,7608,7609,7610,3942,4154,1005,1308,3662,4155,2720,4421,4422,1528,  # 5302
-2600, 161,1178,4156,1982, 987,4423,1101,4157, 631,3943,1157,3198,2420,1343,1241,  # 5318
-1016,2239,2562, 372, 877,2339,2501,1160, 555,1934, 911,3944,7611, 466,1170, 169,  # 5334
-1051,2907,2688,3663,2474,2994,1182,2011,2563,1251,2626,7612, 992,2340,3444,1540,  # 5350
-2721,1201,2070,2401,1996,2475,7613,4424, 528,1922,2188,1503,1873,1570,2364,3342,  # 5366
-3276,7614, 557,1073,7615,1827,3445,2087,2266,3140,3039,3084, 767,3085,2786,4425,  # 5382
-1006,4158,4426,2341,1267,2176,3664,3199, 778,3945,3200,2722,1597,2657,7616,4427,  # 5398
-7617,3446,7618,7619,7620,3277,2689,1433,3278, 131,  95,1504,3946, 723,4159,3141,  # 5414
-1841,3555,2758,2189,3947,2027,2104,3665,7621,2995,3948,1218,7622,3343,3201,3949,  # 5430
-4160,2576, 248,1634,3785, 912,7623,2832,3666,3040,3786, 654,  53,7624,2996,7625,  # 5446
-1688,4428, 777,3447,1032,3950,1425,7626, 191, 820,2120,2833, 971,4429, 931,3202,  # 5462
- 135, 664, 783,3787,1997, 772,2908,1935,3951,3788,4430,2909,3203, 282,2723, 640,  # 5478
-1372,3448,1127, 922, 325,3344,7627,7628, 711,2044,7629,7630,3952,2219,2787,1936,  # 5494
-3953,3345,2220,2251,3789,2300,7631,4431,3790,1258,3279,3954,3204,2138,2950,3955,  # 5510
-3956,7632,2221, 258,3205,4432, 101,1227,7633,3280,1755,7634,1391,3281,7635,2910,  # 5526
-2056, 893,7636,7637,7638,1402,4161,2342,7639,7640,3206,3556,7641,7642, 878,1325,  # 5542
-1780,2788,4433, 259,1385,2577, 744,1183,2267,4434,7643,3957,2502,7644, 684,1024,  # 5558
-4162,7645, 472,3557,3449,1165,3282,3958,3959, 322,2152, 881, 455,1695,1152,1340,  # 5574
- 660, 554,2153,4435,1058,4436,4163, 830,1065,3346,3960,4437,1923,7646,1703,1918,  # 5590
-7647, 932,2268, 122,7648,4438, 947, 677,7649,3791,2627, 297,1905,1924,2269,4439,  # 5606
-2317,3283,7650,7651,4164,7652,4165,  84,4166, 112, 989,7653, 547,1059,3961, 701,  # 5622
-3558,1019,7654,4167,7655,3450, 942, 639, 457,2301,2451, 993,2951, 407, 851, 494,  # 5638
-4440,3347, 927,7656,1237,7657,2421,3348, 573,4168, 680, 921,2911,1279,1874, 285,  # 5654
- 790,1448,1983, 719,2167,7658,7659,4441,3962,3963,1649,7660,1541, 563,7661,1077,  # 5670
-7662,3349,3041,3451, 511,2997,3964,3965,3667,3966,1268,2564,3350,3207,4442,4443,  # 5686
-7663, 535,1048,1276,1189,2912,2028,3142,1438,1373,2834,2952,1134,2012,7664,4169,  # 5702
-1238,2578,3086,1259,7665, 700,7666,2953,3143,3668,4170,7667,4171,1146,1875,1906,  # 5718
-4444,2601,3967, 781,2422, 132,1589, 203, 147, 273,2789,2402, 898,1786,2154,3968,  # 5734
-3969,7668,3792,2790,7669,7670,4445,4446,7671,3208,7672,1635,3793, 965,7673,1804,  # 5750
-2690,1516,3559,1121,1082,1329,3284,3970,1449,3794,  65,1128,2835,2913,2759,1590,  # 5766
-3795,7674,7675,  12,2658,  45, 976,2579,3144,4447, 517,2528,1013,1037,3209,7676,  # 5782
-3796,2836,7677,3797,7678,3452,7679,2602, 614,1998,2318,3798,3087,2724,2628,7680,  # 5798
-2580,4172, 599,1269,7681,1810,3669,7682,2691,3088, 759,1060, 489,1805,3351,3285,  # 5814
-1358,7683,7684,2386,1387,1215,2629,2252, 490,7685,7686,4173,1759,2387,2343,7687,  # 5830
-4448,3799,1907,3971,2630,1806,3210,4449,3453,3286,2760,2344, 874,7688,7689,3454,  # 5846
-3670,1858,  91,2914,3671,3042,3800,4450,7690,3145,3972,2659,7691,3455,1202,1403,  # 5862
-3801,2954,2529,1517,2503,4451,3456,2504,7692,4452,7693,2692,1885,1495,1731,3973,  # 5878
-2365,4453,7694,2029,7695,7696,3974,2693,1216, 237,2581,4174,2319,3975,3802,4454,  # 5894
-4455,2694,3560,3457, 445,4456,7697,7698,7699,7700,2761,  61,3976,3672,1822,3977,  # 5910
-7701, 687,2045, 935, 925, 405,2660, 703,1096,1859,2725,4457,3978,1876,1367,2695,  # 5926
-3352, 918,2105,1781,2476, 334,3287,1611,1093,4458, 564,3146,3458,3673,3353, 945,  # 5942
-2631,2057,4459,7702,1925, 872,4175,7703,3459,2696,3089, 349,4176,3674,3979,4460,  # 5958
-3803,4177,3675,2155,3980,4461,4462,4178,4463,2403,2046, 782,3981, 400, 251,4179,  # 5974
-1624,7704,7705, 277,3676, 299,1265, 476,1191,3804,2121,4180,4181,1109, 205,7706,  # 5990
-2582,1000,2156,3561,1860,7707,7708,7709,4464,7710,4465,2565, 107,2477,2157,3982,  # 6006
-3460,3147,7711,1533, 541,1301, 158, 753,4182,2872,3562,7712,1696, 370,1088,4183,  # 6022
-4466,3563, 579, 327, 440, 162,2240, 269,1937,1374,3461, 968,3043,  56,1396,3090,  # 6038
-2106,3288,3354,7713,1926,2158,4467,2998,7714,3564,7715,7716,3677,4468,2478,7717,  # 6054
-2791,7718,1650,4469,7719,2603,7720,7721,3983,2661,3355,1149,3356,3984,3805,3985,  # 6070
-7722,1076,  49,7723, 951,3211,3289,3290, 450,2837, 920,7724,1811,2792,2366,4184,  # 6086
-1908,1138,2367,3806,3462,7725,3212,4470,1909,1147,1518,2423,4471,3807,7726,4472,  # 6102
-2388,2604, 260,1795,3213,7727,7728,3808,3291, 708,7729,3565,1704,7730,3566,1351,  # 6118
-1618,3357,2999,1886, 944,4185,3358,4186,3044,3359,4187,7731,3678, 422, 413,1714,  # 6134
-3292, 500,2058,2345,4188,2479,7732,1344,1910, 954,7733,1668,7734,7735,3986,2404,  # 6150
-4189,3567,3809,4190,7736,2302,1318,2505,3091, 133,3092,2873,4473, 629,  31,2838,  # 6166
-2697,3810,4474, 850, 949,4475,3987,2955,1732,2088,4191,1496,1852,7737,3988, 620,  # 6182
-3214, 981,1242,3679,3360,1619,3680,1643,3293,2139,2452,1970,1719,3463,2168,7738,  # 6198
-3215,7739,7740,3361,1828,7741,1277,4476,1565,2047,7742,1636,3568,3093,7743, 869,  # 6214
-2839, 655,3811,3812,3094,3989,3000,3813,1310,3569,4477,7744,7745,7746,1733, 558,  # 6230
-4478,3681, 335,1549,3045,1756,4192,3682,1945,3464,1829,1291,1192, 470,2726,2107,  # 6246
-2793, 913,1054,3990,7747,1027,7748,3046,3991,4479, 982,2662,3362,3148,3465,3216,  # 6262
-3217,1946,2794,7749, 571,4480,7750,1830,7751,3570,2583,1523,2424,7752,2089, 984,  # 6278
-4481,3683,1959,7753,3684, 852, 923,2795,3466,3685, 969,1519, 999,2048,2320,1705,  # 6294
-7754,3095, 615,1662, 151, 597,3992,2405,2321,1049, 275,4482,3686,4193, 568,3687,  # 6310
-3571,2480,4194,3688,7755,2425,2270, 409,3218,7756,1566,2874,3467,1002, 769,2840,  # 6326
- 194,2090,3149,3689,2222,3294,4195, 628,1505,7757,7758,1763,2177,3001,3993, 521,  # 6342
-1161,2584,1787,2203,2406,4483,3994,1625,4196,4197, 412,  42,3096, 464,7759,2632,  # 6358
-4484,3363,1760,1571,2875,3468,2530,1219,2204,3814,2633,2140,2368,4485,4486,3295,  # 6374
-1651,3364,3572,7760,7761,3573,2481,3469,7762,3690,7763,7764,2271,2091, 460,7765,  # 6390
-4487,7766,3002, 962, 588,3574, 289,3219,2634,1116,  52,7767,3047,1796,7768,7769,  # 6406
-7770,1467,7771,1598,1143,3691,4198,1984,1734,1067,4488,1280,3365, 465,4489,1572,  # 6422
- 510,7772,1927,2241,1812,1644,3575,7773,4490,3692,7774,7775,2663,1573,1534,7776,  # 6438
-7777,4199, 536,1807,1761,3470,3815,3150,2635,7778,7779,7780,4491,3471,2915,1911,  # 6454
-2796,7781,3296,1122, 377,3220,7782, 360,7783,7784,4200,1529, 551,7785,2059,3693,  # 6470
-1769,2426,7786,2916,4201,3297,3097,2322,2108,2030,4492,1404, 136,1468,1479, 672,  # 6486
-1171,3221,2303, 271,3151,7787,2762,7788,2049, 678,2727, 865,1947,4493,7789,2013,  # 6502
-3995,2956,7790,2728,2223,1397,3048,3694,4494,4495,1735,2917,3366,3576,7791,3816,  # 6518
- 509,2841,2453,2876,3817,7792,7793,3152,3153,4496,4202,2531,4497,2304,1166,1010,  # 6534
- 552, 681,1887,7794,7795,2957,2958,3996,1287,1596,1861,3154, 358, 453, 736, 175,  # 6550
- 478,1117, 905,1167,1097,7796,1853,1530,7797,1706,7798,2178,3472,2287,3695,3473,  # 6566
-3577,4203,2092,4204,7799,3367,1193,2482,4205,1458,2190,2205,1862,1888,1421,3298,  # 6582
-2918,3049,2179,3474, 595,2122,7800,3997,7801,7802,4206,1707,2636, 223,3696,1359,  # 6598
- 751,3098, 183,3475,7803,2797,3003, 419,2369, 633, 704,3818,2389, 241,7804,7805,  # 6614
-7806, 838,3004,3697,2272,2763,2454,3819,1938,2050,3998,1309,3099,2242,1181,7807,  # 6630
-1136,2206,3820,2370,1446,4207,2305,4498,7808,7809,4208,1055,2605, 484,3698,7810,  # 6646
-3999, 625,4209,2273,3368,1499,4210,4000,7811,4001,4211,3222,2274,2275,3476,7812,  # 6662
-7813,2764, 808,2606,3699,3369,4002,4212,3100,2532, 526,3370,3821,4213, 955,7814,  # 6678
-1620,4214,2637,2427,7815,1429,3700,1669,1831, 994, 928,7816,3578,1260,7817,7818,  # 6694
-7819,1948,2288, 741,2919,1626,4215,2729,2455, 867,1184, 362,3371,1392,7820,7821,  # 6710
-4003,4216,1770,1736,3223,2920,4499,4500,1928,2698,1459,1158,7822,3050,3372,2877,  # 6726
-1292,1929,2506,2842,3701,1985,1187,2071,2014,2607,4217,7823,2566,2507,2169,3702,  # 6742
-2483,3299,7824,3703,4501,7825,7826, 666,1003,3005,1022,3579,4218,7827,4502,1813,  # 6758
-2253, 574,3822,1603, 295,1535, 705,3823,4219, 283, 858, 417,7828,7829,3224,4503,  # 6774
-4504,3051,1220,1889,1046,2276,2456,4004,1393,1599, 689,2567, 388,4220,7830,2484,  # 6790
- 802,7831,2798,3824,2060,1405,2254,7832,4505,3825,2109,1052,1345,3225,1585,7833,  # 6806
- 809,7834,7835,7836, 575,2730,3477, 956,1552,1469,1144,2323,7837,2324,1560,2457,  # 6822
-3580,3226,4005, 616,2207,3155,2180,2289,7838,1832,7839,3478,4506,7840,1319,3704,  # 6838
-3705,1211,3581,1023,3227,1293,2799,7841,7842,7843,3826, 607,2306,3827, 762,2878,  # 6854
-1439,4221,1360,7844,1485,3052,7845,4507,1038,4222,1450,2061,2638,4223,1379,4508,  # 6870
-2585,7846,7847,4224,1352,1414,2325,2921,1172,7848,7849,3828,3829,7850,1797,1451,  # 6886
-7851,7852,7853,7854,2922,4006,4007,2485,2346, 411,4008,4009,3582,3300,3101,4509,  # 6902
-1561,2664,1452,4010,1375,7855,7856,  47,2959, 316,7857,1406,1591,2923,3156,7858,  # 6918
-1025,2141,3102,3157, 354,2731, 884,2224,4225,2407, 508,3706, 726,3583, 996,2428,  # 6934
-3584, 729,7859, 392,2191,1453,4011,4510,3707,7860,7861,2458,3585,2608,1675,2800,  # 6950
- 919,2347,2960,2348,1270,4511,4012,  73,7862,7863, 647,7864,3228,2843,2255,1550,  # 6966
-1346,3006,7865,1332, 883,3479,7866,7867,7868,7869,3301,2765,7870,1212, 831,1347,  # 6982
-4226,4512,2326,3830,1863,3053, 720,3831,4513,4514,3832,7871,4227,7872,7873,4515,  # 6998
-7874,7875,1798,4516,3708,2609,4517,3586,1645,2371,7876,7877,2924, 669,2208,2665,  # 7014
-2429,7878,2879,7879,7880,1028,3229,7881,4228,2408,7882,2256,1353,7883,7884,4518,  # 7030
-3158, 518,7885,4013,7886,4229,1960,7887,2142,4230,7888,7889,3007,2349,2350,3833,  # 7046
- 516,1833,1454,4014,2699,4231,4519,2225,2610,1971,1129,3587,7890,2766,7891,2961,  # 7062
-1422, 577,1470,3008,1524,3373,7892,7893, 432,4232,3054,3480,7894,2586,1455,2508,  # 7078
-2226,1972,1175,7895,1020,2732,4015,3481,4520,7896,2733,7897,1743,1361,3055,3482,  # 7094
-2639,4016,4233,4521,2290, 895, 924,4234,2170, 331,2243,3056, 166,1627,3057,1098,  # 7110
-7898,1232,2880,2227,3374,4522, 657, 403,1196,2372, 542,3709,3375,1600,4235,3483,  # 7126
-7899,4523,2767,3230, 576, 530,1362,7900,4524,2533,2666,3710,4017,7901, 842,3834,  # 7142
-7902,2801,2031,1014,4018, 213,2700,3376, 665, 621,4236,7903,3711,2925,2430,7904,  # 7158
-2431,3302,3588,3377,7905,4237,2534,4238,4525,3589,1682,4239,3484,1380,7906, 724,  # 7174
-2277, 600,1670,7907,1337,1233,4526,3103,2244,7908,1621,4527,7909, 651,4240,7910,  # 7190
-1612,4241,2611,7911,2844,7912,2734,2307,3058,7913, 716,2459,3059, 174,1255,2701,  # 7206
-4019,3590, 548,1320,1398, 728,4020,1574,7914,1890,1197,3060,4021,7915,3061,3062,  # 7222
-3712,3591,3713, 747,7916, 635,4242,4528,7917,7918,7919,4243,7920,7921,4529,7922,  # 7238
-3378,4530,2432, 451,7923,3714,2535,2072,4244,2735,4245,4022,7924,1764,4531,7925,  # 7254
-4246, 350,7926,2278,2390,2486,7927,4247,4023,2245,1434,4024, 488,4532, 458,4248,  # 7270
-4025,3715, 771,1330,2391,3835,2568,3159,2159,2409,1553,2667,3160,4249,7928,2487,  # 7286
-2881,2612,1720,2702,4250,3379,4533,7929,2536,4251,7930,3231,4252,2768,7931,2015,  # 7302
-2736,7932,1155,1017,3716,3836,7933,3303,2308, 201,1864,4253,1430,7934,4026,7935,  # 7318
-7936,7937,7938,7939,4254,1604,7940, 414,1865, 371,2587,4534,4535,3485,2016,3104,  # 7334
-4536,1708, 960,4255, 887, 389,2171,1536,1663,1721,7941,2228,4027,2351,2926,1580,  # 7350
-7942,7943,7944,1744,7945,2537,4537,4538,7946,4539,7947,2073,7948,7949,3592,3380,  # 7366
-2882,4256,7950,4257,2640,3381,2802, 673,2703,2460, 709,3486,4028,3593,4258,7951,  # 7382
-1148, 502, 634,7952,7953,1204,4540,3594,1575,4541,2613,3717,7954,3718,3105, 948,  # 7398
-3232, 121,1745,3837,1110,7955,4259,3063,2509,3009,4029,3719,1151,1771,3838,1488,  # 7414
-4030,1986,7956,2433,3487,7957,7958,2093,7959,4260,3839,1213,1407,2803, 531,2737,  # 7430
-2538,3233,1011,1537,7960,2769,4261,3106,1061,7961,3720,3721,1866,2883,7962,2017,  # 7446
- 120,4262,4263,2062,3595,3234,2309,3840,2668,3382,1954,4542,7963,7964,3488,1047,  # 7462
-2704,1266,7965,1368,4543,2845, 649,3383,3841,2539,2738,1102,2846,2669,7966,7967,  # 7478
-1999,7968,1111,3596,2962,7969,2488,3842,3597,2804,1854,3384,3722,7970,7971,3385,  # 7494
-2410,2884,3304,3235,3598,7972,2569,7973,3599,2805,4031,1460, 856,7974,3600,7975,  # 7510
-2885,2963,7976,2886,3843,7977,4264, 632,2510, 875,3844,1697,3845,2291,7978,7979,  # 7526
-4544,3010,1239, 580,4545,4265,7980, 914, 936,2074,1190,4032,1039,2123,7981,7982,  # 7542
-7983,3386,1473,7984,1354,4266,3846,7985,2172,3064,4033, 915,3305,4267,4268,3306,  # 7558
-1605,1834,7986,2739, 398,3601,4269,3847,4034, 328,1912,2847,4035,3848,1331,4270,  # 7574
-3011, 937,4271,7987,3602,4036,4037,3387,2160,4546,3388, 524, 742, 538,3065,1012,  # 7590
-7988,7989,3849,2461,7990, 658,1103, 225,3850,7991,7992,4547,7993,4548,7994,3236,  # 7606
-1243,7995,4038, 963,2246,4549,7996,2705,3603,3161,7997,7998,2588,2327,7999,4550,  # 7622
-8000,8001,8002,3489,3307, 957,3389,2540,2032,1930,2927,2462, 870,2018,3604,1746,  # 7638
-2770,2771,2434,2463,8003,3851,8004,3723,3107,3724,3490,3390,3725,8005,1179,3066,  # 7654
-8006,3162,2373,4272,3726,2541,3163,3108,2740,4039,8007,3391,1556,2542,2292, 977,  # 7670
-2887,2033,4040,1205,3392,8008,1765,3393,3164,2124,1271,1689, 714,4551,3491,8009,  # 7686
-2328,3852, 533,4273,3605,2181, 617,8010,2464,3308,3492,2310,8011,8012,3165,8013,  # 7702
-8014,3853,1987, 618, 427,2641,3493,3394,8015,8016,1244,1690,8017,2806,4274,4552,  # 7718
-8018,3494,8019,8020,2279,1576, 473,3606,4275,3395, 972,8021,3607,8022,3067,8023,  # 7734
-8024,4553,4554,8025,3727,4041,4042,8026, 153,4555, 356,8027,1891,2888,4276,2143,  # 7750
- 408, 803,2352,8028,3854,8029,4277,1646,2570,2511,4556,4557,3855,8030,3856,4278,  # 7766
-8031,2411,3396, 752,8032,8033,1961,2964,8034, 746,3012,2465,8035,4279,3728, 698,  # 7782
-4558,1892,4280,3608,2543,4559,3609,3857,8036,3166,3397,8037,1823,1302,4043,2706,  # 7798
-3858,1973,4281,8038,4282,3167, 823,1303,1288,1236,2848,3495,4044,3398, 774,3859,  # 7814
-8039,1581,4560,1304,2849,3860,4561,8040,2435,2161,1083,3237,4283,4045,4284, 344,  # 7830
-1173, 288,2311, 454,1683,8041,8042,1461,4562,4046,2589,8043,8044,4563, 985, 894,  # 7846
-8045,3399,3168,8046,1913,2928,3729,1988,8047,2110,1974,8048,4047,8049,2571,1194,  # 7862
- 425,8050,4564,3169,1245,3730,4285,8051,8052,2850,8053, 636,4565,1855,3861, 760,  # 7878
-1799,8054,4286,2209,1508,4566,4048,1893,1684,2293,8055,8056,8057,4287,4288,2210,  # 7894
- 479,8058,8059, 832,8060,4049,2489,8061,2965,2490,3731, 990,3109, 627,1814,2642,  # 7910
-4289,1582,4290,2125,2111,3496,4567,8062, 799,4291,3170,8063,4568,2112,1737,3013,  # 7926
-1018, 543, 754,4292,3309,1676,4569,4570,4050,8064,1489,8065,3497,8066,2614,2889,  # 7942
-4051,8067,8068,2966,8069,8070,8071,8072,3171,4571,4572,2182,1722,8073,3238,3239,  # 7958
-1842,3610,1715, 481, 365,1975,1856,8074,8075,1962,2491,4573,8076,2126,3611,3240,  # 7974
- 433,1894,2063,2075,8077, 602,2741,8078,8079,8080,8081,8082,3014,1628,3400,8083,  # 7990
-3172,4574,4052,2890,4575,2512,8084,2544,2772,8085,8086,8087,3310,4576,2891,8088,  # 8006
-4577,8089,2851,4578,4579,1221,2967,4053,2513,8090,8091,8092,1867,1989,8093,8094,  # 8022
-8095,1895,8096,8097,4580,1896,4054, 318,8098,2094,4055,4293,8099,8100, 485,8101,  # 8038
- 938,3862, 553,2670, 116,8102,3863,3612,8103,3498,2671,2773,3401,3311,2807,8104,  # 8054
-3613,2929,4056,1747,2930,2968,8105,8106, 207,8107,8108,2672,4581,2514,8109,3015,  # 8070
- 890,3614,3864,8110,1877,3732,3402,8111,2183,2353,3403,1652,8112,8113,8114, 941,  # 8086
-2294, 208,3499,4057,2019, 330,4294,3865,2892,2492,3733,4295,8115,8116,8117,8118,  # 8102
+    1, 1800, 1506, 255, 1431, 198, 9, 82, 6, 7310, 177, 202, 3615, 1256, 2808, 110,  # 2742
+    3735, 33, 3241, 261, 76, 44, 2113, 16, 2931, 2184, 1176, 659, 3868, 26, 3404, 2643,  # 2758
+    1198, 3869, 3313, 4060, 410, 2211, 302, 590, 361, 1963, 8, 204, 58, 4296, 7311, 1931,  # 2774
+    63, 7312, 7313, 317, 1614, 75, 222, 159, 4061, 2412, 1480, 7314, 3500, 3068, 224, 2809,  # 2790
+    3616, 3, 10, 3870, 1471, 29, 2774, 1135, 2852, 1939, 873, 130, 3242, 1123, 312, 7315,  # 2806
+    4297, 2051, 507, 252, 682, 7316, 142, 1914, 124, 206, 2932, 34, 3501, 3173, 64, 604,  # 2822
+    7317, 2494, 1976, 1977, 155, 1990, 645, 641, 1606, 7318, 3405, 337, 72, 406, 7319, 80,  # 2838
+    630, 238, 3174, 1509, 263, 939, 1092, 2644, 756, 1440, 1094, 3406, 449, 69, 2969, 591,  # 2854
+    179, 2095, 471, 115, 2034, 1843, 60, 50, 2970, 134, 806, 1868, 734, 2035, 3407, 180,  # 2870
+    995, 1607, 156, 537, 2893, 688, 7320, 319, 1305, 779, 2144, 514, 2374, 298, 4298, 359,  # 2886
+    2495, 90, 2707, 1338, 663, 11, 906, 1099, 2545, 20, 2436, 182, 532, 1716, 7321, 732,  # 2902
+    1376, 4062, 1311, 1420, 3175, 25, 2312, 1056, 113, 399, 382, 1949, 242, 3408, 2467, 529,  # 2918
+    3243, 475, 1447, 3617, 7322, 117, 21, 656, 810, 1297, 2295, 2329, 3502, 7323, 126, 4063,  # 2934
+    706, 456, 150, 613, 4299, 71, 1118, 2036, 4064, 145, 3069, 85, 835, 486, 2114, 1246,  # 2950
+    1426, 428, 727, 1285, 1015, 800, 106, 623, 303, 1281, 7324, 2127, 2354, 347, 3736, 221,  # 2966
+    3503, 3110, 7325, 1955, 1153, 4065, 83, 296, 1199, 3070, 192, 624, 93, 7326, 822, 1897,  # 2982
+    2810, 3111, 795, 2064, 991, 1554, 1542, 1592, 27, 43, 2853, 859, 139, 1456, 860, 4300,  # 2998
+    437, 712, 3871, 164, 2392, 3112, 695, 211, 3017, 2096, 195, 3872, 1608, 3504, 3505, 3618,  # 3014
+    3873, 234, 811, 2971, 2097, 3874, 2229, 1441, 3506, 1615, 2375, 668, 2076, 1638, 305, 228,  # 3030
+    1664, 4301, 467, 415, 7327, 262, 2098, 1593, 239, 108, 300, 200, 1033, 512, 1247, 2077,  # 3046
+    7328, 7329, 2173, 3176, 3619, 2673, 593, 845, 1062, 3244, 88, 1723, 2037, 3875, 1950, 212,  # 3062
+    266, 152, 149, 468, 1898, 4066, 4302, 77, 187, 7330, 3018, 37, 5, 2972, 7331, 3876,  # 3078
+    7332, 7333, 39, 2517, 4303, 2894, 3177, 2078, 55, 148, 74, 4304, 545, 483, 1474, 1029,  # 3094
+    1665, 217, 1869, 1531, 3113, 1104, 2645, 4067, 24, 172, 3507, 900, 3877, 3508, 3509, 4305,  # 3110
+    32, 1408, 2811, 1312, 329, 487, 2355, 2247, 2708, 784, 2674, 4, 3019, 3314, 1427, 1788,  # 3126
+    188, 109, 499, 7334, 3620, 1717, 1789, 888, 1217, 3020, 4306, 7335, 3510, 7336, 3315, 1520,  # 3142
+    3621, 3878, 196, 1034, 775, 7337, 7338, 929, 1815, 249, 439, 38, 7339, 1063, 7340, 794,  # 3158
+    3879, 1435, 2296, 46, 178, 3245, 2065, 7341, 2376, 7342, 214, 1709, 4307, 804, 35, 707,  # 3174
+    324, 3622, 1601, 2546, 140, 459, 4068, 7343, 7344, 1365, 839, 272, 978, 2257, 2572, 3409,  # 3190
+    2128, 1363, 3623, 1423, 697, 100, 3071, 48, 70, 1231, 495, 3114, 2193, 7345, 1294, 7346,  # 3206
+    2079, 462, 586, 1042, 3246, 853, 256, 988, 185, 2377, 3410, 1698, 434, 1084, 7347, 3411,  # 3222
+    314, 2615, 2775, 4308, 2330, 2331, 569, 2280, 637, 1816, 2518, 757, 1162, 1878, 1616, 3412,  # 3238
+    287, 1577, 2115, 768, 4309, 1671, 2854, 3511, 2519, 1321, 3737, 909, 2413, 7348, 4069, 933,  # 3254
+    3738, 7349, 2052, 2356, 1222, 4310, 765, 2414, 1322, 786, 4311, 7350, 1919, 1462, 1677, 2895,  # 3270
+    1699, 7351, 4312, 1424, 2437, 3115, 3624, 2590, 3316, 1774, 1940, 3413, 3880, 4070, 309, 1369,  # 3286
+    1130, 2812, 364, 2230, 1653, 1299, 3881, 3512, 3882, 3883, 2646, 525, 1085, 3021, 902, 2000,  # 3302
+    1475, 964, 4313, 421, 1844, 1415, 1057, 2281, 940, 1364, 3116, 376, 4314, 4315, 1381, 7,  # 3318
+    2520, 983, 2378, 336, 1710, 2675, 1845, 321, 3414, 559, 1131, 3022, 2742, 1808, 1132, 1313,  # 3334
+    265, 1481, 1857, 7352, 352, 1203, 2813, 3247, 167, 1089, 420, 2814, 776, 792, 1724, 3513,  # 3350
+    4071, 2438, 3248, 7353, 4072, 7354, 446, 229, 333, 2743, 901, 3739, 1200, 1557, 4316, 2647,  # 3366
+    1920, 395, 2744, 2676, 3740, 4073, 1835, 125, 916, 3178, 2616, 4317, 7355, 7356, 3741, 7357,  # 3382
+    7358, 7359, 4318, 3117, 3625, 1133, 2547, 1757, 3415, 1510, 2313, 1409, 3514, 7360, 2145, 438,  # 3398
+    2591, 2896, 2379, 3317, 1068, 958, 3023, 461, 311, 2855, 2677, 4074, 1915, 3179, 4075, 1978,  # 3414
+    383, 750, 2745, 2617, 4076, 274, 539, 385, 1278, 1442, 7361, 1154, 1964, 384, 561, 210,  # 3430
+    98, 1295, 2548, 3515, 7362, 1711, 2415, 1482, 3416, 3884, 2897, 1257, 129, 7363, 3742, 642,  # 3446
+    523, 2776, 2777, 2648, 7364, 141, 2231, 1333, 68, 176, 441, 876, 907, 4077, 603, 2592,  # 3462
+    710, 171, 3417, 404, 549, 18, 3118, 2393, 1410, 3626, 1666, 7365, 3516, 4319, 2898, 4320,  # 3478
+    7366, 2973, 368, 7367, 146, 366, 99, 871, 3627, 1543, 748, 807, 1586, 1185, 22, 2258,  # 3494
+    379, 3743, 3180, 7368, 3181, 505, 1941, 2618, 1991, 1382, 2314, 7369, 380, 2357, 218, 702,  # 3510
+    1817, 1248, 3418, 3024, 3517, 3318, 3249, 7370, 2974, 3628, 930, 3250, 3744, 7371, 59, 7372,  # 3526
+    585, 601, 4078, 497, 3419, 1112, 1314, 4321, 1801, 7373, 1223, 1472, 2174, 7374, 749, 1836,  # 3542
+    690, 1899, 3745, 1772, 3885, 1476, 429, 1043, 1790, 2232, 2116, 917, 4079, 447, 1086, 1629,  # 3558
+    7375, 556, 7376, 7377, 2020, 1654, 844, 1090, 105, 550, 966, 1758, 2815, 1008, 1782, 686,  # 3574
+    1095, 7378, 2282, 793, 1602, 7379, 3518, 2593, 4322, 4080, 2933, 2297, 4323, 3746, 980, 2496,  # 3590
+    544, 353, 527, 4324, 908, 2678, 2899, 7380, 381, 2619, 1942, 1348, 7381, 1341, 1252, 560,  # 3606
+    3072, 7382, 3420, 2856, 7383, 2053, 973, 886, 2080, 143, 4325, 7384, 7385, 157, 3886, 496,  # 3622
+    4081, 57, 840, 540, 2038, 4326, 4327, 3421, 2117, 1445, 970, 2259, 1748, 1965, 2081, 4082,  # 3638
+    3119, 1234, 1775, 3251, 2816, 3629, 773, 1206, 2129, 1066, 2039, 1326, 3887, 1738, 1725, 4083,  # 3654
+    279, 3120, 51, 1544, 2594, 423, 1578, 2130, 2066, 173, 4328, 1879, 7386, 7387, 1583, 264,  # 3670
+    610, 3630, 4329, 2439, 280, 154, 7388, 7389, 7390, 1739, 338, 1282, 3073, 693, 2857, 1411,  # 3686
+    1074, 3747, 2440, 7391, 4330, 7392, 7393, 1240, 952, 2394, 7394, 2900, 1538, 2679, 685, 1483,  # 3702
+    4084, 2468, 1436, 953, 4085, 2054, 4331, 671, 2395, 79, 4086, 2441, 3252, 608, 567, 2680,  # 3718
+    3422, 4087, 4088, 1691, 393, 1261, 1791, 2396, 7395, 4332, 7396, 7397, 7398, 7399, 1383, 1672,  # 3734
+    3748, 3182, 1464, 522, 1119, 661, 1150, 216, 675, 4333, 3888, 1432, 3519, 609, 4334, 2681,  # 3750
+    2397, 7400, 7401, 7402, 4089, 3025, 0, 7403, 2469, 315, 231, 2442, 301, 3319, 4335, 2380,  # 3766
+    7404, 233, 4090, 3631, 1818, 4336, 4337, 7405, 96, 1776, 1315, 2082, 7406, 257, 7407, 1809,  # 3782
+    3632, 2709, 1139, 1819, 4091, 2021, 1124, 2163, 2778, 1777, 2649, 7408, 3074, 363, 1655, 3183,  # 3798
+    7409, 2975, 7410, 7411, 7412, 3889, 1567, 3890, 718, 103, 3184, 849, 1443, 341, 3320, 2934,  # 3814
+    1484, 7413, 1712, 127, 67, 339, 4092, 2398, 679, 1412, 821, 7414, 7415, 834, 738, 351,  # 3830
+    2976, 2146, 846, 235, 1497, 1880, 418, 1992, 3749, 2710, 186, 1100, 2147, 2746, 3520, 1545,  # 3846
+    1355, 2935, 2858, 1377, 583, 3891, 4093, 2573, 2977, 7416, 1298, 3633, 1078, 2549, 3634, 2358,  # 3862
+    78, 3750, 3751, 267, 1289, 2099, 2001, 1594, 4094, 348, 369, 1274, 2194, 2175, 1837, 4338,  # 3878
+    1820, 2817, 3635, 2747, 2283, 2002, 4339, 2936, 2748, 144, 3321, 882, 4340, 3892, 2749, 3423,  # 3894
+    4341, 2901, 7417, 4095, 1726, 320, 7418, 3893, 3026, 788, 2978, 7419, 2818, 1773, 1327, 2859,  # 3910
+    3894, 2819, 7420, 1306, 4342, 2003, 1700, 3752, 3521, 2359, 2650, 787, 2022, 506, 824, 3636,  # 3926
+    534, 323, 4343, 1044, 3322, 2023, 1900, 946, 3424, 7421, 1778, 1500, 1678, 7422, 1881, 4344,  # 3942
+    165, 243, 4345, 3637, 2521, 123, 683, 4096, 764, 4346, 36, 3895, 1792, 589, 2902, 816,  # 3958
+    626, 1667, 3027, 2233, 1639, 1555, 1622, 3753, 3896, 7423, 3897, 2860, 1370, 1228, 1932, 891,  # 3974
+    2083, 2903, 304, 4097, 7424, 292, 2979, 2711, 3522, 691, 2100, 4098, 1115, 4347, 118, 662,  # 3990
+    7425, 611, 1156, 854, 2381, 1316, 2861, 2, 386, 515, 2904, 7426, 7427, 3253, 868, 2234,  # 4006
+    1486, 855, 2651, 785, 2212, 3028, 7428, 1040, 3185, 3523, 7429, 3121, 448, 7430, 1525, 7431,  # 4022
+    2164, 4348, 7432, 3754, 7433, 4099, 2820, 3524, 3122, 503, 818, 3898, 3123, 1568, 814, 676,  # 4038
+    1444, 306, 1749, 7434, 3755, 1416, 1030, 197, 1428, 805, 2821, 1501, 4349, 7435, 7436, 7437,  # 4054
+    1993, 7438, 4350, 7439, 7440, 2195, 13, 2779, 3638, 2980, 3124, 1229, 1916, 7441, 3756, 2131,  # 4070
+    7442, 4100, 4351, 2399, 3525, 7443, 2213, 1511, 1727, 1120, 7444, 7445, 646, 3757, 2443, 307,  # 4086
+    7446, 7447, 1595, 3186, 7448, 7449, 7450, 3639, 1113, 1356, 3899, 1465, 2522, 2523, 7451, 519,  # 4102
+    7452, 128, 2132, 92, 2284, 1979, 7453, 3900, 1512, 342, 3125, 2196, 7454, 2780, 2214, 1980,  # 4118
+    3323, 7455, 290, 1656, 1317, 789, 827, 2360, 7456, 3758, 4352, 562, 581, 3901, 7457, 401,  # 4134
+    4353, 2248, 94, 4354, 1399, 2781, 7458, 1463, 2024, 4355, 3187, 1943, 7459, 828, 1105, 4101,  # 4150
+    1262, 1394, 7460, 4102, 605, 4356, 7461, 1783, 2862, 7462, 2822, 819, 2101, 578, 2197, 2937,  # 4166
+    7463, 1502, 436, 3254, 4103, 3255, 2823, 3902, 2905, 3425, 3426, 7464, 2712, 2315, 7465, 7466,  # 4182
+    2332, 2067, 23, 4357, 193, 826, 3759, 2102, 699, 1630, 4104, 3075, 390, 1793, 1064, 3526,  # 4198
+    7467, 1579, 3076, 3077, 1400, 7468, 4105, 1838, 1640, 2863, 7469, 4358, 4359, 137, 4106, 598,  # 4214
+    3078, 1966, 780, 104, 974, 2938, 7470, 278, 899, 253, 402, 572, 504, 493, 1339, 7471,  # 4230
+    3903, 1275, 4360, 2574, 2550, 7472, 3640, 3029, 3079, 2249, 565, 1334, 2713, 863, 41, 7473,  # 4246
+    7474, 4361, 7475, 1657, 2333, 19, 463, 2750, 4107, 606, 7476, 2981, 3256, 1087, 2084, 1323,  # 4262
+    2652, 2982, 7477, 1631, 1623, 1750, 4108, 2682, 7478, 2864, 791, 2714, 2653, 2334, 232, 2416,  # 4278
+    7479, 2983, 1498, 7480, 2654, 2620, 755, 1366, 3641, 3257, 3126, 2025, 1609, 119, 1917, 3427,  # 4294
+    862, 1026, 4109, 7481, 3904, 3760, 4362, 3905, 4363, 2260, 1951, 2470, 7482, 1125, 817, 4110,  # 4310
+    4111, 3906, 1513, 1766, 2040, 1487, 4112, 3030, 3258, 2824, 3761, 3127, 7483, 7484, 1507, 7485,  # 4326
+    2683, 733, 40, 1632, 1106, 2865, 345, 4113, 841, 2524, 230, 4364, 2984, 1846, 3259, 3428,  # 4342
+    7486, 1263, 986, 3429, 7487, 735, 879, 254, 1137, 857, 622, 1300, 1180, 1388, 1562, 3907,  # 4358
+    3908, 2939, 967, 2751, 2655, 1349, 592, 2133, 1692, 3324, 2985, 1994, 4114, 1679, 3909, 1901,  # 4374
+    2185, 7488, 739, 3642, 2715, 1296, 1290, 7489, 4115, 2198, 2199, 1921, 1563, 2595, 2551, 1870,  # 4390
+    2752, 2986, 7490, 435, 7491, 343, 1108, 596, 17, 1751, 4365, 2235, 3430, 3643, 7492, 4366,  # 4406
+    294, 3527, 2940, 1693, 477, 979, 281, 2041, 3528, 643, 2042, 3644, 2621, 2782, 2261, 1031,  # 4422
+    2335, 2134, 2298, 3529, 4367, 367, 1249, 2552, 7493, 3530, 7494, 4368, 1283, 3325, 2004, 240,  # 4438
+    1762, 3326, 4369, 4370, 836, 1069, 3128, 474, 7495, 2148, 2525, 268, 3531, 7496, 3188, 1521,  # 4454
+    1284, 7497, 1658, 1546, 4116, 7498, 3532, 3533, 7499, 4117, 3327, 2684, 1685, 4118, 961, 1673,  # 4470
+    2622, 190, 2005, 2200, 3762, 4371, 4372, 7500, 570, 2497, 3645, 1490, 7501, 4373, 2623, 3260,  # 4486
+    1956, 4374, 584, 1514, 396, 1045, 1944, 7502, 4375, 1967, 2444, 7503, 7504, 4376, 3910, 619,  # 4502
+    7505, 3129, 3261, 215, 2006, 2783, 2553, 3189, 4377, 3190, 4378, 763, 4119, 3763, 4379, 7506,  # 4518
+    7507, 1957, 1767, 2941, 3328, 3646, 1174, 452, 1477, 4380, 3329, 3130, 7508, 2825, 1253, 2382,  # 4534
+    2186, 1091, 2285, 4120, 492, 7509, 638, 1169, 1824, 2135, 1752, 3911, 648, 926, 1021, 1324,  # 4550
+    4381, 520, 4382, 997, 847, 1007, 892, 4383, 3764, 2262, 1871, 3647, 7510, 2400, 1784, 4384,  # 4566
+    1952, 2942, 3080, 3191, 1728, 4121, 2043, 3648, 4385, 2007, 1701, 3131, 1551, 30, 2263, 4122,  # 4582
+    7511, 2026, 4386, 3534, 7512, 501, 7513, 4123, 594, 3431, 2165, 1821, 3535, 3432, 3536, 3192,  # 4598
+    829, 2826, 4124, 7514, 1680, 3132, 1225, 4125, 7515, 3262, 4387, 4126, 3133, 2336, 7516, 4388,  # 4614
+    4127, 7517, 3912, 3913, 7518, 1847, 2383, 2596, 3330, 7519, 4389, 374, 3914, 652, 4128, 4129,  # 4630
+    375, 1140, 798, 7520, 7521, 7522, 2361, 4390, 2264, 546, 1659, 138, 3031, 2445, 4391, 7523,  # 4646
+    2250, 612, 1848, 910, 796, 3765, 1740, 1371, 825, 3766, 3767, 7524, 2906, 2554, 7525, 692,  # 4662
+    444, 3032, 2624, 801, 4392, 4130, 7526, 1491, 244, 1053, 3033, 4131, 4132, 340, 7527, 3915,  # 4678
+    1041, 2987, 293, 1168, 87, 1357, 7528, 1539, 959, 7529, 2236, 721, 694, 4133, 3768, 219,  # 4694
+    1478, 644, 1417, 3331, 2656, 1413, 1401, 1335, 1389, 3916, 7530, 7531, 2988, 2362, 3134, 1825,  # 4710
+    730, 1515, 184, 2827, 66, 4393, 7532, 1660, 2943, 246, 3332, 378, 1457, 226, 3433, 975,  # 4726
+    3917, 2944, 1264, 3537, 674, 696, 7533, 163, 7534, 1141, 2417, 2166, 713, 3538, 3333, 4394,  # 4742
+    3918, 7535, 7536, 1186, 15, 7537, 1079, 1070, 7538, 1522, 3193, 3539, 276, 1050, 2716, 758,  # 4758
+    1126, 653, 2945, 3263, 7539, 2337, 889, 3540, 3919, 3081, 2989, 903, 1250, 4395, 3920, 3434,  # 4774
+    3541, 1342, 1681, 1718, 766, 3264, 286, 89, 2946, 3649, 7540, 1713, 7541, 2597, 3334, 2990,  # 4790
+    7542, 2947, 2215, 3194, 2866, 7543, 4396, 2498, 2526, 181, 387, 1075, 3921, 731, 2187, 3335,  # 4806
+    7544, 3265, 310, 313, 3435, 2299, 770, 4134, 54, 3034, 189, 4397, 3082, 3769, 3922, 7545,  # 4822
+    1230, 1617, 1849, 355, 3542, 4135, 4398, 3336, 111, 4136, 3650, 1350, 3135, 3436, 3035, 4137,  # 4838
+    2149, 3266, 3543, 7546, 2784, 3923, 3924, 2991, 722, 2008, 7547, 1071, 247, 1207, 2338, 2471,  # 4854
+    1378, 4399, 2009, 864, 1437, 1214, 4400, 373, 3770, 1142, 2216, 667, 4401, 442, 2753, 2555,  # 4870
+    3771, 3925, 1968, 4138, 3267, 1839, 837, 170, 1107, 934, 1336, 1882, 7548, 7549, 2118, 4139,  # 4886
+    2828, 743, 1569, 7550, 4402, 4140, 582, 2384, 1418, 3437, 7551, 1802, 7552, 357, 1395, 1729,  # 4902
+    3651, 3268, 2418, 1564, 2237, 7553, 3083, 3772, 1633, 4403, 1114, 2085, 4141, 1532, 7554, 482,  # 4918
+    2446, 4404, 7555, 7556, 1492, 833, 1466, 7557, 2717, 3544, 1641, 2829, 7558, 1526, 1272, 3652,  # 4934
+    4142, 1686, 1794, 416, 2556, 1902, 1953, 1803, 7559, 3773, 2785, 3774, 1159, 2316, 7560, 2867,  # 4950
+    4405, 1610, 1584, 3036, 2419, 2754, 443, 3269, 1163, 3136, 7561, 7562, 3926, 7563, 4143, 2499,  # 4966
+    3037, 4406, 3927, 3137, 2103, 1647, 3545, 2010, 1872, 4144, 7564, 4145, 431, 3438, 7565, 250,  # 4982
+    97, 81, 4146, 7566, 1648, 1850, 1558, 160, 848, 7567, 866, 740, 1694, 7568, 2201, 2830,  # 4998
+    3195, 4147, 4407, 3653, 1687, 950, 2472, 426, 469, 3196, 3654, 3655, 3928, 7569, 7570, 1188,  # 5014
+    424, 1995, 861, 3546, 4148, 3775, 2202, 2685, 168, 1235, 3547, 4149, 7571, 2086, 1674, 4408,  # 5030
+    3337, 3270, 220, 2557, 1009, 7572, 3776, 670, 2992, 332, 1208, 717, 7573, 7574, 3548, 2447,  # 5046
+    3929, 3338, 7575, 513, 7576, 1209, 2868, 3339, 3138, 4409, 1080, 7577, 7578, 7579, 7580, 2527,  # 5062
+    3656, 3549, 815, 1587, 3930, 3931, 7581, 3550, 3439, 3777, 1254, 4410, 1328, 3038, 1390, 3932,  # 5078
+    1741, 3933, 3778, 3934, 7582, 236, 3779, 2448, 3271, 7583, 7584, 3657, 3780, 1273, 3781, 4411,  # 5094
+    7585, 308, 7586, 4412, 245, 4413, 1851, 2473, 1307, 2575, 430, 715, 2136, 2449, 7587, 270,  # 5110
+    199, 2869, 3935, 7588, 3551, 2718, 1753, 761, 1754, 725, 1661, 1840, 4414, 3440, 3658, 7589,  # 5126
+    7590, 587, 14, 3272, 227, 2598, 326, 480, 2265, 943, 2755, 3552, 291, 650, 1883, 7591,  # 5142
+    1702, 1226, 102, 1547, 62, 3441, 904, 4415, 3442, 1164, 4150, 7592, 7593, 1224, 1548, 2756,  # 5158
+    391, 498, 1493, 7594, 1386, 1419, 7595, 2055, 1177, 4416, 813, 880, 1081, 2363, 566, 1145,  # 5174
+    4417, 2286, 1001, 1035, 2558, 2599, 2238, 394, 1286, 7596, 7597, 2068, 7598, 86, 1494, 1730,  # 5190
+    3936, 491, 1588, 745, 897, 2948, 843, 3340, 3937, 2757, 2870, 3273, 1768, 998, 2217, 2069,  # 5206
+    397, 1826, 1195, 1969, 3659, 2993, 3341, 284, 7599, 3782, 2500, 2137, 2119, 1903, 7600, 3938,  # 5222
+    2150, 3939, 4151, 1036, 3443, 1904, 114, 2559, 4152, 209, 1527, 7601, 7602, 2949, 2831, 2625,  # 5238
+    2385, 2719, 3139, 812, 2560, 7603, 3274, 7604, 1559, 737, 1884, 3660, 1210, 885, 28, 2686,  # 5254
+    3553, 3783, 7605, 4153, 1004, 1779, 4418, 7606, 346, 1981, 2218, 2687, 4419, 3784, 1742, 797,  # 5270
+    1642, 3940, 1933, 1072, 1384, 2151, 896, 3941, 3275, 3661, 3197, 2871, 3554, 7607, 2561, 1958,  # 5286
+    4420, 2450, 1785, 7608, 7609, 7610, 3942, 4154, 1005, 1308, 3662, 4155, 2720, 4421, 4422, 1528,  # 5302
+    2600, 161, 1178, 4156, 1982, 987, 4423, 1101, 4157, 631, 3943, 1157, 3198, 2420, 1343, 1241,  # 5318
+    1016, 2239, 2562, 372, 877, 2339, 2501, 1160, 555, 1934, 911, 3944, 7611, 466, 1170, 169,  # 5334
+    1051, 2907, 2688, 3663, 2474, 2994, 1182, 2011, 2563, 1251, 2626, 7612, 992, 2340, 3444, 1540,  # 5350
+    2721, 1201, 2070, 2401, 1996, 2475, 7613, 4424, 528, 1922, 2188, 1503, 1873, 1570, 2364, 3342,  # 5366
+    3276, 7614, 557, 1073, 7615, 1827, 3445, 2087, 2266, 3140, 3039, 3084, 767, 3085, 2786, 4425,  # 5382
+    1006, 4158, 4426, 2341, 1267, 2176, 3664, 3199, 778, 3945, 3200, 2722, 1597, 2657, 7616, 4427,  # 5398
+    7617, 3446, 7618, 7619, 7620, 3277, 2689, 1433, 3278, 131, 95, 1504, 3946, 723, 4159, 3141,  # 5414
+    1841, 3555, 2758, 2189, 3947, 2027, 2104, 3665, 7621, 2995, 3948, 1218, 7622, 3343, 3201, 3949,  # 5430
+    4160, 2576, 248, 1634, 3785, 912, 7623, 2832, 3666, 3040, 3786, 654, 53, 7624, 2996, 7625,  # 5446
+    1688, 4428, 777, 3447, 1032, 3950, 1425, 7626, 191, 820, 2120, 2833, 971, 4429, 931, 3202,  # 5462
+    135, 664, 783, 3787, 1997, 772, 2908, 1935, 3951, 3788, 4430, 2909, 3203, 282, 2723, 640,  # 5478
+    1372, 3448, 1127, 922, 325, 3344, 7627, 7628, 711, 2044, 7629, 7630, 3952, 2219, 2787, 1936,  # 5494
+    3953, 3345, 2220, 2251, 3789, 2300, 7631, 4431, 3790, 1258, 3279, 3954, 3204, 2138, 2950, 3955,  # 5510
+    3956, 7632, 2221, 258, 3205, 4432, 101, 1227, 7633, 3280, 1755, 7634, 1391, 3281, 7635, 2910,  # 5526
+    2056, 893, 7636, 7637, 7638, 1402, 4161, 2342, 7639, 7640, 3206, 3556, 7641, 7642, 878, 1325,  # 5542
+    1780, 2788, 4433, 259, 1385, 2577, 744, 1183, 2267, 4434, 7643, 3957, 2502, 7644, 684, 1024,  # 5558
+    4162, 7645, 472, 3557, 3449, 1165, 3282, 3958, 3959, 322, 2152, 881, 455, 1695, 1152, 1340,  # 5574
+    660, 554, 2153, 4435, 1058, 4436, 4163, 830, 1065, 3346, 3960, 4437, 1923, 7646, 1703, 1918,  # 5590
+    7647, 932, 2268, 122, 7648, 4438, 947, 677, 7649, 3791, 2627, 297, 1905, 1924, 2269, 4439,  # 5606
+    2317, 3283, 7650, 7651, 4164, 7652, 4165, 84, 4166, 112, 989, 7653, 547, 1059, 3961, 701,  # 5622
+    3558, 1019, 7654, 4167, 7655, 3450, 942, 639, 457, 2301, 2451, 993, 2951, 407, 851, 494,  # 5638
+    4440, 3347, 927, 7656, 1237, 7657, 2421, 3348, 573, 4168, 680, 921, 2911, 1279, 1874, 285,  # 5654
+    790, 1448, 1983, 719, 2167, 7658, 7659, 4441, 3962, 3963, 1649, 7660, 1541, 563, 7661, 1077,  # 5670
+    7662, 3349, 3041, 3451, 511, 2997, 3964, 3965, 3667, 3966, 1268, 2564, 3350, 3207, 4442, 4443,  # 5686
+    7663, 535, 1048, 1276, 1189, 2912, 2028, 3142, 1438, 1373, 2834, 2952, 1134, 2012, 7664, 4169,  # 5702
+    1238, 2578, 3086, 1259, 7665, 700, 7666, 2953, 3143, 3668, 4170, 7667, 4171, 1146, 1875, 1906,  # 5718
+    4444, 2601, 3967, 781, 2422, 132, 1589, 203, 147, 273, 2789, 2402, 898, 1786, 2154, 3968,  # 5734
+    3969, 7668, 3792, 2790, 7669, 7670, 4445, 4446, 7671, 3208, 7672, 1635, 3793, 965, 7673, 1804,  # 5750
+    2690, 1516, 3559, 1121, 1082, 1329, 3284, 3970, 1449, 3794, 65, 1128, 2835, 2913, 2759, 1590,  # 5766
+    3795, 7674, 7675, 12, 2658, 45, 976, 2579, 3144, 4447, 517, 2528, 1013, 1037, 3209, 7676,  # 5782
+    3796, 2836, 7677, 3797, 7678, 3452, 7679, 2602, 614, 1998, 2318, 3798, 3087, 2724, 2628, 7680,  # 5798
+    2580, 4172, 599, 1269, 7681, 1810, 3669, 7682, 2691, 3088, 759, 1060, 489, 1805, 3351, 3285,  # 5814
+    1358, 7683, 7684, 2386, 1387, 1215, 2629, 2252, 490, 7685, 7686, 4173, 1759, 2387, 2343, 7687,  # 5830
+    4448, 3799, 1907, 3971, 2630, 1806, 3210, 4449, 3453, 3286, 2760, 2344, 874, 7688, 7689, 3454,  # 5846
+    3670, 1858, 91, 2914, 3671, 3042, 3800, 4450, 7690, 3145, 3972, 2659, 7691, 3455, 1202, 1403,  # 5862
+    3801, 2954, 2529, 1517, 2503, 4451, 3456, 2504, 7692, 4452, 7693, 2692, 1885, 1495, 1731, 3973,  # 5878
+    2365, 4453, 7694, 2029, 7695, 7696, 3974, 2693, 1216, 237, 2581, 4174, 2319, 3975, 3802, 4454,  # 5894
+    4455, 2694, 3560, 3457, 445, 4456, 7697, 7698, 7699, 7700, 2761, 61, 3976, 3672, 1822, 3977,  # 5910
+    7701, 687, 2045, 935, 925, 405, 2660, 703, 1096, 1859, 2725, 4457, 3978, 1876, 1367, 2695,  # 5926
+    3352, 918, 2105, 1781, 2476, 334, 3287, 1611, 1093, 4458, 564, 3146, 3458, 3673, 3353, 945,  # 5942
+    2631, 2057, 4459, 7702, 1925, 872, 4175, 7703, 3459, 2696, 3089, 349, 4176, 3674, 3979, 4460,  # 5958
+    3803, 4177, 3675, 2155, 3980, 4461, 4462, 4178, 4463, 2403, 2046, 782, 3981, 400, 251, 4179,  # 5974
+    1624, 7704, 7705, 277, 3676, 299, 1265, 476, 1191, 3804, 2121, 4180, 4181, 1109, 205, 7706,  # 5990
+    2582, 1000, 2156, 3561, 1860, 7707, 7708, 7709, 4464, 7710, 4465, 2565, 107, 2477, 2157, 3982,  # 6006
+    3460, 3147, 7711, 1533, 541, 1301, 158, 753, 4182, 2872, 3562, 7712, 1696, 370, 1088, 4183,  # 6022
+    4466, 3563, 579, 327, 440, 162, 2240, 269, 1937, 1374, 3461, 968, 3043, 56, 1396, 3090,  # 6038
+    2106, 3288, 3354, 7713, 1926, 2158, 4467, 2998, 7714, 3564, 7715, 7716, 3677, 4468, 2478, 7717,  # 6054
+    2791, 7718, 1650, 4469, 7719, 2603, 7720, 7721, 3983, 2661, 3355, 1149, 3356, 3984, 3805, 3985,  # 6070
+    7722, 1076, 49, 7723, 951, 3211, 3289, 3290, 450, 2837, 920, 7724, 1811, 2792, 2366, 4184,  # 6086
+    1908, 1138, 2367, 3806, 3462, 7725, 3212, 4470, 1909, 1147, 1518, 2423, 4471, 3807, 7726, 4472,  # 6102
+    2388, 2604, 260, 1795, 3213, 7727, 7728, 3808, 3291, 708, 7729, 3565, 1704, 7730, 3566, 1351,  # 6118
+    1618, 3357, 2999, 1886, 944, 4185, 3358, 4186, 3044, 3359, 4187, 7731, 3678, 422, 413, 1714,  # 6134
+    3292, 500, 2058, 2345, 4188, 2479, 7732, 1344, 1910, 954, 7733, 1668, 7734, 7735, 3986, 2404,  # 6150
+    4189, 3567, 3809, 4190, 7736, 2302, 1318, 2505, 3091, 133, 3092, 2873, 4473, 629, 31, 2838,  # 6166
+    2697, 3810, 4474, 850, 949, 4475, 3987, 2955, 1732, 2088, 4191, 1496, 1852, 7737, 3988, 620,  # 6182
+    3214, 981, 1242, 3679, 3360, 1619, 3680, 1643, 3293, 2139, 2452, 1970, 1719, 3463, 2168, 7738,  # 6198
+    3215, 7739, 7740, 3361, 1828, 7741, 1277, 4476, 1565, 2047, 7742, 1636, 3568, 3093, 7743, 869,  # 6214
+    2839, 655, 3811, 3812, 3094, 3989, 3000, 3813, 1310, 3569, 4477, 7744, 7745, 7746, 1733, 558,  # 6230
+    4478, 3681, 335, 1549, 3045, 1756, 4192, 3682, 1945, 3464, 1829, 1291, 1192, 470, 2726, 2107,  # 6246
+    2793, 913, 1054, 3990, 7747, 1027, 7748, 3046, 3991, 4479, 982, 2662, 3362, 3148, 3465, 3216,  # 6262
+    3217, 1946, 2794, 7749, 571, 4480, 7750, 1830, 7751, 3570, 2583, 1523, 2424, 7752, 2089, 984,  # 6278
+    4481, 3683, 1959, 7753, 3684, 852, 923, 2795, 3466, 3685, 969, 1519, 999, 2048, 2320, 1705,  # 6294
+    7754, 3095, 615, 1662, 151, 597, 3992, 2405, 2321, 1049, 275, 4482, 3686, 4193, 568, 3687,  # 6310
+    3571, 2480, 4194, 3688, 7755, 2425, 2270, 409, 3218, 7756, 1566, 2874, 3467, 1002, 769, 2840,  # 6326
+    194, 2090, 3149, 3689, 2222, 3294, 4195, 628, 1505, 7757, 7758, 1763, 2177, 3001, 3993, 521,  # 6342
+    1161, 2584, 1787, 2203, 2406, 4483, 3994, 1625, 4196, 4197, 412, 42, 3096, 464, 7759, 2632,  # 6358
+    4484, 3363, 1760, 1571, 2875, 3468, 2530, 1219, 2204, 3814, 2633, 2140, 2368, 4485, 4486, 3295,  # 6374
+    1651, 3364, 3572, 7760, 7761, 3573, 2481, 3469, 7762, 3690, 7763, 7764, 2271, 2091, 460, 7765,  # 6390
+    4487, 7766, 3002, 962, 588, 3574, 289, 3219, 2634, 1116, 52, 7767, 3047, 1796, 7768, 7769,  # 6406
+    7770, 1467, 7771, 1598, 1143, 3691, 4198, 1984, 1734, 1067, 4488, 1280, 3365, 465, 4489, 1572,  # 6422
+    510, 7772, 1927, 2241, 1812, 1644, 3575, 7773, 4490, 3692, 7774, 7775, 2663, 1573, 1534, 7776,  # 6438
+    7777, 4199, 536, 1807, 1761, 3470, 3815, 3150, 2635, 7778, 7779, 7780, 4491, 3471, 2915, 1911,  # 6454
+    2796, 7781, 3296, 1122, 377, 3220, 7782, 360, 7783, 7784, 4200, 1529, 551, 7785, 2059, 3693,  # 6470
+    1769, 2426, 7786, 2916, 4201, 3297, 3097, 2322, 2108, 2030, 4492, 1404, 136, 1468, 1479, 672,  # 6486
+    1171, 3221, 2303, 271, 3151, 7787, 2762, 7788, 2049, 678, 2727, 865, 1947, 4493, 7789, 2013,  # 6502
+    3995, 2956, 7790, 2728, 2223, 1397, 3048, 3694, 4494, 4495, 1735, 2917, 3366, 3576, 7791, 3816,  # 6518
+    509, 2841, 2453, 2876, 3817, 7792, 7793, 3152, 3153, 4496, 4202, 2531, 4497, 2304, 1166, 1010,  # 6534
+    552, 681, 1887, 7794, 7795, 2957, 2958, 3996, 1287, 1596, 1861, 3154, 358, 453, 736, 175,  # 6550
+    478, 1117, 905, 1167, 1097, 7796, 1853, 1530, 7797, 1706, 7798, 2178, 3472, 2287, 3695, 3473,  # 6566
+    3577, 4203, 2092, 4204, 7799, 3367, 1193, 2482, 4205, 1458, 2190, 2205, 1862, 1888, 1421, 3298,  # 6582
+    2918, 3049, 2179, 3474, 595, 2122, 7800, 3997, 7801, 7802, 4206, 1707, 2636, 223, 3696, 1359,  # 6598
+    751, 3098, 183, 3475, 7803, 2797, 3003, 419, 2369, 633, 704, 3818, 2389, 241, 7804, 7805,  # 6614
+    7806, 838, 3004, 3697, 2272, 2763, 2454, 3819, 1938, 2050, 3998, 1309, 3099, 2242, 1181, 7807,  # 6630
+    1136, 2206, 3820, 2370, 1446, 4207, 2305, 4498, 7808, 7809, 4208, 1055, 2605, 484, 3698, 7810,  # 6646
+    3999, 625, 4209, 2273, 3368, 1499, 4210, 4000, 7811, 4001, 4211, 3222, 2274, 2275, 3476, 7812,  # 6662
+    7813, 2764, 808, 2606, 3699, 3369, 4002, 4212, 3100, 2532, 526, 3370, 3821, 4213, 955, 7814,  # 6678
+    1620, 4214, 2637, 2427, 7815, 1429, 3700, 1669, 1831, 994, 928, 7816, 3578, 1260, 7817, 7818,  # 6694
+    7819, 1948, 2288, 741, 2919, 1626, 4215, 2729, 2455, 867, 1184, 362, 3371, 1392, 7820, 7821,  # 6710
+    4003, 4216, 1770, 1736, 3223, 2920, 4499, 4500, 1928, 2698, 1459, 1158, 7822, 3050, 3372, 2877,  # 6726
+    1292, 1929, 2506, 2842, 3701, 1985, 1187, 2071, 2014, 2607, 4217, 7823, 2566, 2507, 2169, 3702,  # 6742
+    2483, 3299, 7824, 3703, 4501, 7825, 7826, 666, 1003, 3005, 1022, 3579, 4218, 7827, 4502, 1813,  # 6758
+    2253, 574, 3822, 1603, 295, 1535, 705, 3823, 4219, 283, 858, 417, 7828, 7829, 3224, 4503,  # 6774
+    4504, 3051, 1220, 1889, 1046, 2276, 2456, 4004, 1393, 1599, 689, 2567, 388, 4220, 7830, 2484,  # 6790
+    802, 7831, 2798, 3824, 2060, 1405, 2254, 7832, 4505, 3825, 2109, 1052, 1345, 3225, 1585, 7833,  # 6806
+    809, 7834, 7835, 7836, 575, 2730, 3477, 956, 1552, 1469, 1144, 2323, 7837, 2324, 1560, 2457,  # 6822
+    3580, 3226, 4005, 616, 2207, 3155, 2180, 2289, 7838, 1832, 7839, 3478, 4506, 7840, 1319, 3704,  # 6838
+    3705, 1211, 3581, 1023, 3227, 1293, 2799, 7841, 7842, 7843, 3826, 607, 2306, 3827, 762, 2878,  # 6854
+    1439, 4221, 1360, 7844, 1485, 3052, 7845, 4507, 1038, 4222, 1450, 2061, 2638, 4223, 1379, 4508,  # 6870
+    2585, 7846, 7847, 4224, 1352, 1414, 2325, 2921, 1172, 7848, 7849, 3828, 3829, 7850, 1797, 1451,  # 6886
+    7851, 7852, 7853, 7854, 2922, 4006, 4007, 2485, 2346, 411, 4008, 4009, 3582, 3300, 3101, 4509,  # 6902
+    1561, 2664, 1452, 4010, 1375, 7855, 7856, 47, 2959, 316, 7857, 1406, 1591, 2923, 3156, 7858,  # 6918
+    1025, 2141, 3102, 3157, 354, 2731, 884, 2224, 4225, 2407, 508, 3706, 726, 3583, 996, 2428,  # 6934
+    3584, 729, 7859, 392, 2191, 1453, 4011, 4510, 3707, 7860, 7861, 2458, 3585, 2608, 1675, 2800,  # 6950
+    919, 2347, 2960, 2348, 1270, 4511, 4012, 73, 7862, 7863, 647, 7864, 3228, 2843, 2255, 1550,  # 6966
+    1346, 3006, 7865, 1332, 883, 3479, 7866, 7867, 7868, 7869, 3301, 2765, 7870, 1212, 831, 1347,  # 6982
+    4226, 4512, 2326, 3830, 1863, 3053, 720, 3831, 4513, 4514, 3832, 7871, 4227, 7872, 7873, 4515,  # 6998
+    7874, 7875, 1798, 4516, 3708, 2609, 4517, 3586, 1645, 2371, 7876, 7877, 2924, 669, 2208, 2665,  # 7014
+    2429, 7878, 2879, 7879, 7880, 1028, 3229, 7881, 4228, 2408, 7882, 2256, 1353, 7883, 7884, 4518,  # 7030
+    3158, 518, 7885, 4013, 7886, 4229, 1960, 7887, 2142, 4230, 7888, 7889, 3007, 2349, 2350, 3833,  # 7046
+    516, 1833, 1454, 4014, 2699, 4231, 4519, 2225, 2610, 1971, 1129, 3587, 7890, 2766, 7891, 2961,  # 7062
+    1422, 577, 1470, 3008, 1524, 3373, 7892, 7893, 432, 4232, 3054, 3480, 7894, 2586, 1455, 2508,  # 7078
+    2226, 1972, 1175, 7895, 1020, 2732, 4015, 3481, 4520, 7896, 2733, 7897, 1743, 1361, 3055, 3482,  # 7094
+    2639, 4016, 4233, 4521, 2290, 895, 924, 4234, 2170, 331, 2243, 3056, 166, 1627, 3057, 1098,  # 7110
+    7898, 1232, 2880, 2227, 3374, 4522, 657, 403, 1196, 2372, 542, 3709, 3375, 1600, 4235, 3483,  # 7126
+    7899, 4523, 2767, 3230, 576, 530, 1362, 7900, 4524, 2533, 2666, 3710, 4017, 7901, 842, 3834,  # 7142
+    7902, 2801, 2031, 1014, 4018, 213, 2700, 3376, 665, 621, 4236, 7903, 3711, 2925, 2430, 7904,  # 7158
+    2431, 3302, 3588, 3377, 7905, 4237, 2534, 4238, 4525, 3589, 1682, 4239, 3484, 1380, 7906, 724,  # 7174
+    2277, 600, 1670, 7907, 1337, 1233, 4526, 3103, 2244, 7908, 1621, 4527, 7909, 651, 4240, 7910,  # 7190
+    1612, 4241, 2611, 7911, 2844, 7912, 2734, 2307, 3058, 7913, 716, 2459, 3059, 174, 1255, 2701,  # 7206
+    4019, 3590, 548, 1320, 1398, 728, 4020, 1574, 7914, 1890, 1197, 3060, 4021, 7915, 3061, 3062,  # 7222
+    3712, 3591, 3713, 747, 7916, 635, 4242, 4528, 7917, 7918, 7919, 4243, 7920, 7921, 4529, 7922,  # 7238
+    3378, 4530, 2432, 451, 7923, 3714, 2535, 2072, 4244, 2735, 4245, 4022, 7924, 1764, 4531, 7925,  # 7254
+    4246, 350, 7926, 2278, 2390, 2486, 7927, 4247, 4023, 2245, 1434, 4024, 488, 4532, 458, 4248,  # 7270
+    4025, 3715, 771, 1330, 2391, 3835, 2568, 3159, 2159, 2409, 1553, 2667, 3160, 4249, 7928, 2487,  # 7286
+    2881, 2612, 1720, 2702, 4250, 3379, 4533, 7929, 2536, 4251, 7930, 3231, 4252, 2768, 7931, 2015,  # 7302
+    2736, 7932, 1155, 1017, 3716, 3836, 7933, 3303, 2308, 201, 1864, 4253, 1430, 7934, 4026, 7935,  # 7318
+    7936, 7937, 7938, 7939, 4254, 1604, 7940, 414, 1865, 371, 2587, 4534, 4535, 3485, 2016, 3104,  # 7334
+    4536, 1708, 960, 4255, 887, 389, 2171, 1536, 1663, 1721, 7941, 2228, 4027, 2351, 2926, 1580,  # 7350
+    7942, 7943, 7944, 1744, 7945, 2537, 4537, 4538, 7946, 4539, 7947, 2073, 7948, 7949, 3592, 3380,  # 7366
+    2882, 4256, 7950, 4257, 2640, 3381, 2802, 673, 2703, 2460, 709, 3486, 4028, 3593, 4258, 7951,  # 7382
+    1148, 502, 634, 7952, 7953, 1204, 4540, 3594, 1575, 4541, 2613, 3717, 7954, 3718, 3105, 948,  # 7398
+    3232, 121, 1745, 3837, 1110, 7955, 4259, 3063, 2509, 3009, 4029, 3719, 1151, 1771, 3838, 1488,  # 7414
+    4030, 1986, 7956, 2433, 3487, 7957, 7958, 2093, 7959, 4260, 3839, 1213, 1407, 2803, 531, 2737,  # 7430
+    2538, 3233, 1011, 1537, 7960, 2769, 4261, 3106, 1061, 7961, 3720, 3721, 1866, 2883, 7962, 2017,  # 7446
+    120, 4262, 4263, 2062, 3595, 3234, 2309, 3840, 2668, 3382, 1954, 4542, 7963, 7964, 3488, 1047,  # 7462
+    2704, 1266, 7965, 1368, 4543, 2845, 649, 3383, 3841, 2539, 2738, 1102, 2846, 2669, 7966, 7967,  # 7478
+    1999, 7968, 1111, 3596, 2962, 7969, 2488, 3842, 3597, 2804, 1854, 3384, 3722, 7970, 7971, 3385,  # 7494
+    2410, 2884, 3304, 3235, 3598, 7972, 2569, 7973, 3599, 2805, 4031, 1460, 856, 7974, 3600, 7975,  # 7510
+    2885, 2963, 7976, 2886, 3843, 7977, 4264, 632, 2510, 875, 3844, 1697, 3845, 2291, 7978, 7979,  # 7526
+    4544, 3010, 1239, 580, 4545, 4265, 7980, 914, 936, 2074, 1190, 4032, 1039, 2123, 7981, 7982,  # 7542
+    7983, 3386, 1473, 7984, 1354, 4266, 3846, 7985, 2172, 3064, 4033, 915, 3305, 4267, 4268, 3306,  # 7558
+    1605, 1834, 7986, 2739, 398, 3601, 4269, 3847, 4034, 328, 1912, 2847, 4035, 3848, 1331, 4270,  # 7574
+    3011, 937, 4271, 7987, 3602, 4036, 4037, 3387, 2160, 4546, 3388, 524, 742, 538, 3065, 1012,  # 7590
+    7988, 7989, 3849, 2461, 7990, 658, 1103, 225, 3850, 7991, 7992, 4547, 7993, 4548, 7994, 3236,  # 7606
+    1243, 7995, 4038, 963, 2246, 4549, 7996, 2705, 3603, 3161, 7997, 7998, 2588, 2327, 7999, 4550,  # 7622
+    8000, 8001, 8002, 3489, 3307, 957, 3389, 2540, 2032, 1930, 2927, 2462, 870, 2018, 3604, 1746,  # 7638
+    2770, 2771, 2434, 2463, 8003, 3851, 8004, 3723, 3107, 3724, 3490, 3390, 3725, 8005, 1179, 3066,  # 7654
+    8006, 3162, 2373, 4272, 3726, 2541, 3163, 3108, 2740, 4039, 8007, 3391, 1556, 2542, 2292, 977,  # 7670
+    2887, 2033, 4040, 1205, 3392, 8008, 1765, 3393, 3164, 2124, 1271, 1689, 714, 4551, 3491, 8009,  # 7686
+    2328, 3852, 533, 4273, 3605, 2181, 617, 8010, 2464, 3308, 3492, 2310, 8011, 8012, 3165, 8013,  # 7702
+    8014, 3853, 1987, 618, 427, 2641, 3493, 3394, 8015, 8016, 1244, 1690, 8017, 2806, 4274, 4552,  # 7718
+    8018, 3494, 8019, 8020, 2279, 1576, 473, 3606, 4275, 3395, 972, 8021, 3607, 8022, 3067, 8023,  # 7734
+    8024, 4553, 4554, 8025, 3727, 4041, 4042, 8026, 153, 4555, 356, 8027, 1891, 2888, 4276, 2143,  # 7750
+    408, 803, 2352, 8028, 3854, 8029, 4277, 1646, 2570, 2511, 4556, 4557, 3855, 8030, 3856, 4278,  # 7766
+    8031, 2411, 3396, 752, 8032, 8033, 1961, 2964, 8034, 746, 3012, 2465, 8035, 4279, 3728, 698,  # 7782
+    4558, 1892, 4280, 3608, 2543, 4559, 3609, 3857, 8036, 3166, 3397, 8037, 1823, 1302, 4043, 2706,  # 7798
+    3858, 1973, 4281, 8038, 4282, 3167, 823, 1303, 1288, 1236, 2848, 3495, 4044, 3398, 774, 3859,  # 7814
+    8039, 1581, 4560, 1304, 2849, 3860, 4561, 8040, 2435, 2161, 1083, 3237, 4283, 4045, 4284, 344,  # 7830
+    1173, 288, 2311, 454, 1683, 8041, 8042, 1461, 4562, 4046, 2589, 8043, 8044, 4563, 985, 894,  # 7846
+    8045, 3399, 3168, 8046, 1913, 2928, 3729, 1988, 8047, 2110, 1974, 8048, 4047, 8049, 2571, 1194,  # 7862
+    425, 8050, 4564, 3169, 1245, 3730, 4285, 8051, 8052, 2850, 8053, 636, 4565, 1855, 3861, 760,  # 7878
+    1799, 8054, 4286, 2209, 1508, 4566, 4048, 1893, 1684, 2293, 8055, 8056, 8057, 4287, 4288, 2210,  # 7894
+    479, 8058, 8059, 832, 8060, 4049, 2489, 8061, 2965, 2490, 3731, 990, 3109, 627, 1814, 2642,  # 7910
+    4289, 1582, 4290, 2125, 2111, 3496, 4567, 8062, 799, 4291, 3170, 8063, 4568, 2112, 1737, 3013,  # 7926
+    1018, 543, 754, 4292, 3309, 1676, 4569, 4570, 4050, 8064, 1489, 8065, 3497, 8066, 2614, 2889,  # 7942
+    4051, 8067, 8068, 2966, 8069, 8070, 8071, 8072, 3171, 4571, 4572, 2182, 1722, 8073, 3238, 3239,  # 7958
+    1842, 3610, 1715, 481, 365, 1975, 1856, 8074, 8075, 1962, 2491, 4573, 8076, 2126, 3611, 3240,  # 7974
+    433, 1894, 2063, 2075, 8077, 602, 2741, 8078, 8079, 8080, 8081, 8082, 3014, 1628, 3400, 8083,  # 7990
+    3172, 4574, 4052, 2890, 4575, 2512, 8084, 2544, 2772, 8085, 8086, 8087, 3310, 4576, 2891, 8088,  # 8006
+    4577, 8089, 2851, 4578, 4579, 1221, 2967, 4053, 2513, 8090, 8091, 8092, 1867, 1989, 8093, 8094,  # 8022
+    8095, 1895, 8096, 8097, 4580, 1896, 4054, 318, 8098, 2094, 4055, 4293, 8099, 8100, 485, 8101,  # 8038
+    938, 3862, 553, 2670, 116, 8102, 3863, 3612, 8103, 3498, 2671, 2773, 3401, 3311, 2807, 8104,  # 8054
+    3613, 2929, 4056, 1747, 2930, 2968, 8105, 8106, 207, 8107, 8108, 2672, 4581, 2514, 8109, 3015,  # 8070
+    890, 3614, 3864, 8110, 1877, 3732, 3402, 8111, 2183, 2353, 3403, 1652, 8112, 8113, 8114, 941,  # 8086
+    2294, 208, 3499, 4057, 2019, 330, 4294, 3865, 2892, 2492, 3733, 4295, 8115, 8116, 8117, 8118,  # 8102
 )
-
+# fmt: on
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py b/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py
index 35669cc4..a37ab189 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/euctwprober.py
@@ -25,22 +25,23 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .mbcharsetprober import MultiByteCharSetProber
-from .codingstatemachine import CodingStateMachine
 from .chardistribution import EUCTWDistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .mbcharsetprober import MultiByteCharSetProber
 from .mbcssm import EUCTW_SM_MODEL
 
+
 class EUCTWProber(MultiByteCharSetProber):
-    def __init__(self):
-        super(EUCTWProber, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(EUCTW_SM_MODEL)
         self.distribution_analyzer = EUCTWDistributionAnalysis()
         self.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "EUC-TW"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Taiwan"
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py b/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py
index 697837bd..b32bfc74 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/gb2312freq.py
@@ -43,6 +43,7 @@ GB2312_TYPICAL_DISTRIBUTION_RATIO = 0.9
 
 GB2312_TABLE_SIZE = 3760
 
+# fmt: off
 GB2312_CHAR_TO_FREQ_ORDER = (
 1671, 749,1443,2364,3924,3807,2330,3921,1704,3463,2691,1511,1515, 572,3191,2205,
 2361, 224,2558, 479,1711, 963,3162, 440,4060,1905,2966,2947,3580,2647,3961,3842,
@@ -280,4 +281,4 @@ GB2312_CHAR_TO_FREQ_ORDER = (
  381,1638,4592,1020, 516,3214, 458, 947,4575,1432, 211,1514,2926,1865,2142, 189,
  852,1221,1400,1486, 882,2299,4036, 351,  28,1122, 700,6479,6480,6481,6482,6483,  #last 512
 )
-
+# fmt: on
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py b/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py
index 8446d2dd..d423e731 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/gb2312prober.py
@@ -25,22 +25,23 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .mbcharsetprober import MultiByteCharSetProber
-from .codingstatemachine import CodingStateMachine
 from .chardistribution import GB2312DistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .mbcharsetprober import MultiByteCharSetProber
 from .mbcssm import GB2312_SM_MODEL
 
+
 class GB2312Prober(MultiByteCharSetProber):
-    def __init__(self):
-        super(GB2312Prober, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(GB2312_SM_MODEL)
         self.distribution_analyzer = GB2312DistributionAnalysis()
         self.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "GB2312"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Chinese"
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py b/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py
index b0e1bf49..785d0057 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/hebrewprober.py
@@ -25,8 +25,11 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import Optional, Union
+
 from .charsetprober import CharSetProber
 from .enums import ProbingState
+from .sbcharsetprober import SingleByteCharSetProber
 
 # This prober doesn't actually recognize a language or a charset.
 # It is a helper prober for the use of the Hebrew model probers
@@ -125,18 +128,20 @@ from .enums import ProbingState
 # model probers scores. The answer is returned in the form of the name of the
 # charset identified, either "windows-1255" or "ISO-8859-8".
 
+
 class HebrewProber(CharSetProber):
+    SPACE = 0x20
     # windows-1255 / ISO-8859-8 code points of interest
-    FINAL_KAF = 0xea
-    NORMAL_KAF = 0xeb
-    FINAL_MEM = 0xed
-    NORMAL_MEM = 0xee
-    FINAL_NUN = 0xef
-    NORMAL_NUN = 0xf0
-    FINAL_PE = 0xf3
-    NORMAL_PE = 0xf4
-    FINAL_TSADI = 0xf5
-    NORMAL_TSADI = 0xf6
+    FINAL_KAF = 0xEA
+    NORMAL_KAF = 0xEB
+    FINAL_MEM = 0xED
+    NORMAL_MEM = 0xEE
+    FINAL_NUN = 0xEF
+    NORMAL_NUN = 0xF0
+    FINAL_PE = 0xF3
+    NORMAL_PE = 0xF4
+    FINAL_TSADI = 0xF5
+    NORMAL_TSADI = 0xF6
 
     # Minimum Visual vs Logical final letter score difference.
     # If the difference is below this, don't rely solely on the final letter score
@@ -151,35 +156,44 @@ class HebrewProber(CharSetProber):
     VISUAL_HEBREW_NAME = "ISO-8859-8"
     LOGICAL_HEBREW_NAME = "windows-1255"
 
-    def __init__(self):
-        super(HebrewProber, self).__init__()
-        self._final_char_logical_score = None
-        self._final_char_visual_score = None
-        self._prev = None
-        self._before_prev = None
-        self._logical_prober = None
-        self._visual_prober = None
+    def __init__(self) -> None:
+        super().__init__()
+        self._final_char_logical_score = 0
+        self._final_char_visual_score = 0
+        self._prev = self.SPACE
+        self._before_prev = self.SPACE
+        self._logical_prober: Optional[SingleByteCharSetProber] = None
+        self._visual_prober: Optional[SingleByteCharSetProber] = None
         self.reset()
 
-    def reset(self):
+    def reset(self) -> None:
         self._final_char_logical_score = 0
         self._final_char_visual_score = 0
         # The two last characters seen in the previous buffer,
         # mPrev and mBeforePrev are initialized to space in order to simulate
         # a word delimiter at the beginning of the data
-        self._prev = ' '
-        self._before_prev = ' '
+        self._prev = self.SPACE
+        self._before_prev = self.SPACE
         # These probers are owned by the group prober.
 
-    def set_model_probers(self, logicalProber, visualProber):
-        self._logical_prober = logicalProber
-        self._visual_prober = visualProber
+    def set_model_probers(
+        self,
+        logical_prober: SingleByteCharSetProber,
+        visual_prober: SingleByteCharSetProber,
+    ) -> None:
+        self._logical_prober = logical_prober
+        self._visual_prober = visual_prober
 
-    def is_final(self, c):
-        return c in [self.FINAL_KAF, self.FINAL_MEM, self.FINAL_NUN,
-                     self.FINAL_PE, self.FINAL_TSADI]
+    def is_final(self, c: int) -> bool:
+        return c in [
+            self.FINAL_KAF,
+            self.FINAL_MEM,
+            self.FINAL_NUN,
+            self.FINAL_PE,
+            self.FINAL_TSADI,
+        ]
 
-    def is_non_final(self, c):
+    def is_non_final(self, c: int) -> bool:
         # The normal Tsadi is not a good Non-Final letter due to words like
         # 'lechotet' (to chat) containing an apostrophe after the tsadi. This
         # apostrophe is converted to a space in FilterWithoutEnglishLetters
@@ -190,10 +204,9 @@ class HebrewProber(CharSetProber):
         # for example legally end with a Non-Final Pe or Kaf. However, the
         # benefit of these letters as Non-Final letters outweighs the damage
         # since these words are quite rare.
-        return c in [self.NORMAL_KAF, self.NORMAL_MEM,
-                     self.NORMAL_NUN, self.NORMAL_PE]
+        return c in [self.NORMAL_KAF, self.NORMAL_MEM, self.NORMAL_NUN, self.NORMAL_PE]
 
-    def feed(self, byte_str):
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
         # Final letter analysis for logical-visual decision.
         # Look for evidence that the received buffer is either logical Hebrew
         # or visual Hebrew.
@@ -227,9 +240,9 @@ class HebrewProber(CharSetProber):
         byte_str = self.filter_high_byte_only(byte_str)
 
         for cur in byte_str:
-            if cur == ' ':
+            if cur == self.SPACE:
                 # We stand on a space - a word just ended
-                if self._before_prev != ' ':
+                if self._before_prev != self.SPACE:
                     # next-to-last char was not a space so self._prev is not a
                     # 1 letter word
                     if self.is_final(self._prev):
@@ -241,8 +254,11 @@ class HebrewProber(CharSetProber):
                         self._final_char_visual_score += 1
             else:
                 # Not standing on a space
-                if ((self._before_prev == ' ') and
-                        (self.is_final(self._prev)) and (cur != ' ')):
+                if (
+                    (self._before_prev == self.SPACE)
+                    and (self.is_final(self._prev))
+                    and (cur != self.SPACE)
+                ):
                     # case (3) [-2:space][-1:final letter][cur:not space]
                     self._final_char_visual_score += 1
             self._before_prev = self._prev
@@ -253,7 +269,10 @@ class HebrewProber(CharSetProber):
         return ProbingState.DETECTING
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
+        assert self._logical_prober is not None
+        assert self._visual_prober is not None
+
         # Make the decision: is it Logical or Visual?
         # If the final letter score distance is dominant enough, rely on it.
         finalsub = self._final_char_logical_score - self._final_char_visual_score
@@ -263,8 +282,9 @@ class HebrewProber(CharSetProber):
             return self.VISUAL_HEBREW_NAME
 
         # It's not dominant enough, try to rely on the model scores instead.
-        modelsub = (self._logical_prober.get_confidence()
-                    - self._visual_prober.get_confidence())
+        modelsub = (
+            self._logical_prober.get_confidence() - self._visual_prober.get_confidence()
+        )
         if modelsub > self.MIN_MODEL_DISTANCE:
             return self.LOGICAL_HEBREW_NAME
         if modelsub < -self.MIN_MODEL_DISTANCE:
@@ -280,13 +300,17 @@ class HebrewProber(CharSetProber):
         return self.LOGICAL_HEBREW_NAME
 
     @property
-    def language(self):
-        return 'Hebrew'
+    def language(self) -> str:
+        return "Hebrew"
 
     @property
-    def state(self):
+    def state(self) -> ProbingState:
+        assert self._logical_prober is not None
+        assert self._visual_prober is not None
+
         # Remain active as long as any of the model probers are active.
-        if (self._logical_prober.state == ProbingState.NOT_ME) and \
-           (self._visual_prober.state == ProbingState.NOT_ME):
+        if (self._logical_prober.state == ProbingState.NOT_ME) and (
+            self._visual_prober.state == ProbingState.NOT_ME
+        ):
             return ProbingState.NOT_ME
         return ProbingState.DETECTING
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py b/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py
index 83fc082b..3293576e 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/jisfreq.py
@@ -46,6 +46,7 @@ JIS_TYPICAL_DISTRIBUTION_RATIO = 3.0
 # Char to FreqOrder table ,
 JIS_TABLE_SIZE = 4368
 
+# fmt: off
 JIS_CHAR_TO_FREQ_ORDER = (
   40,   1,   6, 182, 152, 180, 295,2127, 285, 381,3295,4304,3068,4606,3165,3510, #   16
 3511,1822,2785,4607,1193,2226,5070,4608, 171,2996,1247,  18, 179,5071, 856,1661, #   32
@@ -321,5 +322,4 @@ JIS_CHAR_TO_FREQ_ORDER = (
 1444,1698,2385,2251,3729,1365,2281,2235,1717,6188, 864,3841,2515, 444, 527,2767, # 4352
 2922,3625, 544, 461,6189, 566, 209,2437,3398,2098,1065,2068,3331,3626,3257,2137, # 4368  #last 512
 )
-
-
+# fmt: on
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py b/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py
index 20044e4b..2f53bdda 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/jpcntx.py
@@ -25,110 +25,114 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import List, Tuple, Union
 
 # This is hiragana 2-char sequence table, the number in each cell represents its frequency category
-jp2CharContext = (
-(0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,0,0,0,1),
-(2,4,0,4,0,3,0,4,0,3,4,4,4,2,4,3,3,4,3,2,3,3,4,2,3,3,3,2,4,1,4,3,3,1,5,4,3,4,3,4,3,5,3,0,3,5,4,2,0,3,1,0,3,3,0,3,3,0,1,1,0,4,3,0,3,3,0,4,0,2,0,3,5,5,5,5,4,0,4,1,0,3,4),
-(0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2),
-(0,4,0,5,0,5,0,4,0,4,5,4,4,3,5,3,5,1,5,3,4,3,4,4,3,4,3,3,4,3,5,4,4,3,5,5,3,5,5,5,3,5,5,3,4,5,5,3,1,3,2,0,3,4,0,4,2,0,4,2,1,5,3,2,3,5,0,4,0,2,0,5,4,4,5,4,5,0,4,0,0,4,4),
-(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0),
-(0,3,0,4,0,3,0,3,0,4,5,4,3,3,3,3,4,3,5,4,4,3,5,4,4,3,4,3,4,4,4,4,5,3,4,4,3,4,5,5,4,5,5,1,4,5,4,3,0,3,3,1,3,3,0,4,4,0,3,3,1,5,3,3,3,5,0,4,0,3,0,4,4,3,4,3,3,0,4,1,1,3,4),
-(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0),
-(0,4,0,3,0,3,0,4,0,3,4,4,3,2,2,1,2,1,3,1,3,3,3,3,3,4,3,1,3,3,5,3,3,0,4,3,0,5,4,3,3,5,4,4,3,4,4,5,0,1,2,0,1,2,0,2,2,0,1,0,0,5,2,2,1,4,0,3,0,1,0,4,4,3,5,4,3,0,2,1,0,4,3),
-(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0),
-(0,3,0,5,0,4,0,2,1,4,4,2,4,1,4,2,4,2,4,3,3,3,4,3,3,3,3,1,4,2,3,3,3,1,4,4,1,1,1,4,3,3,2,0,2,4,3,2,0,3,3,0,3,1,1,0,0,0,3,3,0,4,2,2,3,4,0,4,0,3,0,4,4,5,3,4,4,0,3,0,0,1,4),
-(1,4,0,4,0,4,0,4,0,3,5,4,4,3,4,3,5,4,3,3,4,3,5,4,4,4,4,3,4,2,4,3,3,1,5,4,3,2,4,5,4,5,5,4,4,5,4,4,0,3,2,2,3,3,0,4,3,1,3,2,1,4,3,3,4,5,0,3,0,2,0,4,5,5,4,5,4,0,4,0,0,5,4),
-(0,5,0,5,0,4,0,3,0,4,4,3,4,3,3,3,4,0,4,4,4,3,4,3,4,3,3,1,4,2,4,3,4,0,5,4,1,4,5,4,4,5,3,2,4,3,4,3,2,4,1,3,3,3,2,3,2,0,4,3,3,4,3,3,3,4,0,4,0,3,0,4,5,4,4,4,3,0,4,1,0,1,3),
-(0,3,1,4,0,3,0,2,0,3,4,4,3,1,4,2,3,3,4,3,4,3,4,3,4,4,3,2,3,1,5,4,4,1,4,4,3,5,4,4,3,5,5,4,3,4,4,3,1,2,3,1,2,2,0,3,2,0,3,1,0,5,3,3,3,4,3,3,3,3,4,4,4,4,5,4,2,0,3,3,2,4,3),
-(0,2,0,3,0,1,0,1,0,0,3,2,0,0,2,0,1,0,2,1,3,3,3,1,2,3,1,0,1,0,4,2,1,1,3,3,0,4,3,3,1,4,3,3,0,3,3,2,0,0,0,0,1,0,0,2,0,0,0,0,0,4,1,0,2,3,2,2,2,1,3,3,3,4,4,3,2,0,3,1,0,3,3),
-(0,4,0,4,0,3,0,3,0,4,4,4,3,3,3,3,3,3,4,3,4,2,4,3,4,3,3,2,4,3,4,5,4,1,4,5,3,5,4,5,3,5,4,0,3,5,5,3,1,3,3,2,2,3,0,3,4,1,3,3,2,4,3,3,3,4,0,4,0,3,0,4,5,4,4,5,3,0,4,1,0,3,4),
-(0,2,0,3,0,3,0,0,0,2,2,2,1,0,1,0,0,0,3,0,3,0,3,0,1,3,1,0,3,1,3,3,3,1,3,3,3,0,1,3,1,3,4,0,0,3,1,1,0,3,2,0,0,0,0,1,3,0,1,0,0,3,3,2,0,3,0,0,0,0,0,3,4,3,4,3,3,0,3,0,0,2,3),
-(2,3,0,3,0,2,0,1,0,3,3,4,3,1,3,1,1,1,3,1,4,3,4,3,3,3,0,0,3,1,5,4,3,1,4,3,2,5,5,4,4,4,4,3,3,4,4,4,0,2,1,1,3,2,0,1,2,0,0,1,0,4,1,3,3,3,0,3,0,1,0,4,4,4,5,5,3,0,2,0,0,4,4),
-(0,2,0,1,0,3,1,3,0,2,3,3,3,0,3,1,0,0,3,0,3,2,3,1,3,2,1,1,0,0,4,2,1,0,2,3,1,4,3,2,0,4,4,3,1,3,1,3,0,1,0,0,1,0,0,0,1,0,0,0,0,4,1,1,1,2,0,3,0,0,0,3,4,2,4,3,2,0,1,0,0,3,3),
-(0,1,0,4,0,5,0,4,0,2,4,4,2,3,3,2,3,3,5,3,3,3,4,3,4,2,3,0,4,3,3,3,4,1,4,3,2,1,5,5,3,4,5,1,3,5,4,2,0,3,3,0,1,3,0,4,2,0,1,3,1,4,3,3,3,3,0,3,0,1,0,3,4,4,4,5,5,0,3,0,1,4,5),
-(0,2,0,3,0,3,0,0,0,2,3,1,3,0,4,0,1,1,3,0,3,4,3,2,3,1,0,3,3,2,3,1,3,0,2,3,0,2,1,4,1,2,2,0,0,3,3,0,0,2,0,0,0,1,0,0,0,0,2,2,0,3,2,1,3,3,0,2,0,2,0,0,3,3,1,2,4,0,3,0,2,2,3),
-(2,4,0,5,0,4,0,4,0,2,4,4,4,3,4,3,3,3,1,2,4,3,4,3,4,4,5,0,3,3,3,3,2,0,4,3,1,4,3,4,1,4,4,3,3,4,4,3,1,2,3,0,4,2,0,4,1,0,3,3,0,4,3,3,3,4,0,4,0,2,0,3,5,3,4,5,2,0,3,0,0,4,5),
-(0,3,0,4,0,1,0,1,0,1,3,2,2,1,3,0,3,0,2,0,2,0,3,0,2,0,0,0,1,0,1,1,0,0,3,1,0,0,0,4,0,3,1,0,2,1,3,0,0,0,0,0,0,3,0,0,0,0,0,0,0,4,2,2,3,1,0,3,0,0,0,1,4,4,4,3,0,0,4,0,0,1,4),
-(1,4,1,5,0,3,0,3,0,4,5,4,4,3,5,3,3,4,4,3,4,1,3,3,3,3,2,1,4,1,5,4,3,1,4,4,3,5,4,4,3,5,4,3,3,4,4,4,0,3,3,1,2,3,0,3,1,0,3,3,0,5,4,4,4,4,4,4,3,3,5,4,4,3,3,5,4,0,3,2,0,4,4),
-(0,2,0,3,0,1,0,0,0,1,3,3,3,2,4,1,3,0,3,1,3,0,2,2,1,1,0,0,2,0,4,3,1,0,4,3,0,4,4,4,1,4,3,1,1,3,3,1,0,2,0,0,1,3,0,0,0,0,2,0,0,4,3,2,4,3,5,4,3,3,3,4,3,3,4,3,3,0,2,1,0,3,3),
-(0,2,0,4,0,3,0,2,0,2,5,5,3,4,4,4,4,1,4,3,3,0,4,3,4,3,1,3,3,2,4,3,0,3,4,3,0,3,4,4,2,4,4,0,4,5,3,3,2,2,1,1,1,2,0,1,5,0,3,3,2,4,3,3,3,4,0,3,0,2,0,4,4,3,5,5,0,0,3,0,2,3,3),
-(0,3,0,4,0,3,0,1,0,3,4,3,3,1,3,3,3,0,3,1,3,0,4,3,3,1,1,0,3,0,3,3,0,0,4,4,0,1,5,4,3,3,5,0,3,3,4,3,0,2,0,1,1,1,0,1,3,0,1,2,1,3,3,2,3,3,0,3,0,1,0,1,3,3,4,4,1,0,1,2,2,1,3),
-(0,1,0,4,0,4,0,3,0,1,3,3,3,2,3,1,1,0,3,0,3,3,4,3,2,4,2,0,1,0,4,3,2,0,4,3,0,5,3,3,2,4,4,4,3,3,3,4,0,1,3,0,0,1,0,0,1,0,0,0,0,4,2,3,3,3,0,3,0,0,0,4,4,4,5,3,2,0,3,3,0,3,5),
-(0,2,0,3,0,0,0,3,0,1,3,0,2,0,0,0,1,0,3,1,1,3,3,0,0,3,0,0,3,0,2,3,1,0,3,1,0,3,3,2,0,4,2,2,0,2,0,0,0,4,0,0,0,0,0,0,0,0,0,0,0,2,1,2,0,1,0,1,0,0,0,1,3,1,2,0,0,0,1,0,0,1,4),
-(0,3,0,3,0,5,0,1,0,2,4,3,1,3,3,2,1,1,5,2,1,0,5,1,2,0,0,0,3,3,2,2,3,2,4,3,0,0,3,3,1,3,3,0,2,5,3,4,0,3,3,0,1,2,0,2,2,0,3,2,0,2,2,3,3,3,0,2,0,1,0,3,4,4,2,5,4,0,3,0,0,3,5),
-(0,3,0,3,0,3,0,1,0,3,3,3,3,0,3,0,2,0,2,1,1,0,2,0,1,0,0,0,2,1,0,0,1,0,3,2,0,0,3,3,1,2,3,1,0,3,3,0,0,1,0,0,0,0,0,2,0,0,0,0,0,2,3,1,2,3,0,3,0,1,0,3,2,1,0,4,3,0,1,1,0,3,3),
-(0,4,0,5,0,3,0,3,0,4,5,5,4,3,5,3,4,3,5,3,3,2,5,3,4,4,4,3,4,3,4,5,5,3,4,4,3,4,4,5,4,4,4,3,4,5,5,4,2,3,4,2,3,4,0,3,3,1,4,3,2,4,3,3,5,5,0,3,0,3,0,5,5,5,5,4,4,0,4,0,1,4,4),
-(0,4,0,4,0,3,0,3,0,3,5,4,4,2,3,2,5,1,3,2,5,1,4,2,3,2,3,3,4,3,3,3,3,2,5,4,1,3,3,5,3,4,4,0,4,4,3,1,1,3,1,0,2,3,0,2,3,0,3,0,0,4,3,1,3,4,0,3,0,2,0,4,4,4,3,4,5,0,4,0,0,3,4),
-(0,3,0,3,0,3,1,2,0,3,4,4,3,3,3,0,2,2,4,3,3,1,3,3,3,1,1,0,3,1,4,3,2,3,4,4,2,4,4,4,3,4,4,3,2,4,4,3,1,3,3,1,3,3,0,4,1,0,2,2,1,4,3,2,3,3,5,4,3,3,5,4,4,3,3,0,4,0,3,2,2,4,4),
-(0,2,0,1,0,0,0,0,0,1,2,1,3,0,0,0,0,0,2,0,1,2,1,0,0,1,0,0,0,0,3,0,0,1,0,1,1,3,1,0,0,0,1,1,0,1,1,0,0,0,0,0,2,0,0,0,0,0,0,0,0,1,1,2,2,0,3,4,0,0,0,1,1,0,0,1,0,0,0,0,0,1,1),
-(0,1,0,0,0,1,0,0,0,0,4,0,4,1,4,0,3,0,4,0,3,0,4,0,3,0,3,0,4,1,5,1,4,0,0,3,0,5,0,5,2,0,1,0,0,0,2,1,4,0,1,3,0,0,3,0,0,3,1,1,4,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0),
-(1,4,0,5,0,3,0,2,0,3,5,4,4,3,4,3,5,3,4,3,3,0,4,3,3,3,3,3,3,2,4,4,3,1,3,4,4,5,4,4,3,4,4,1,3,5,4,3,3,3,1,2,2,3,3,1,3,1,3,3,3,5,3,3,4,5,0,3,0,3,0,3,4,3,4,4,3,0,3,0,2,4,3),
-(0,1,0,4,0,0,0,0,0,1,4,0,4,1,4,2,4,0,3,0,1,0,1,0,0,0,0,0,2,0,3,1,1,1,0,3,0,0,0,1,2,1,0,0,1,1,1,1,0,1,0,0,0,1,0,0,3,0,0,0,0,3,2,0,2,2,0,1,0,0,0,2,3,2,3,3,0,0,0,0,2,1,0),
-(0,5,1,5,0,3,0,3,0,5,4,4,5,1,5,3,3,0,4,3,4,3,5,3,4,3,3,2,4,3,4,3,3,0,3,3,1,4,4,3,4,4,4,3,4,5,5,3,2,3,1,1,3,3,1,3,1,1,3,3,2,4,5,3,3,5,0,4,0,3,0,4,4,3,5,3,3,0,3,4,0,4,3),
-(0,5,0,5,0,3,0,2,0,4,4,3,5,2,4,3,3,3,4,4,4,3,5,3,5,3,3,1,4,0,4,3,3,0,3,3,0,4,4,4,4,5,4,3,3,5,5,3,2,3,1,2,3,2,0,1,0,0,3,2,2,4,4,3,1,5,0,4,0,3,0,4,3,1,3,2,1,0,3,3,0,3,3),
-(0,4,0,5,0,5,0,4,0,4,5,5,5,3,4,3,3,2,5,4,4,3,5,3,5,3,4,0,4,3,4,4,3,2,4,4,3,4,5,4,4,5,5,0,3,5,5,4,1,3,3,2,3,3,1,3,1,0,4,3,1,4,4,3,4,5,0,4,0,2,0,4,3,4,4,3,3,0,4,0,0,5,5),
-(0,4,0,4,0,5,0,1,1,3,3,4,4,3,4,1,3,0,5,1,3,0,3,1,3,1,1,0,3,0,3,3,4,0,4,3,0,4,4,4,3,4,4,0,3,5,4,1,0,3,0,0,2,3,0,3,1,0,3,1,0,3,2,1,3,5,0,3,0,1,0,3,2,3,3,4,4,0,2,2,0,4,4),
-(2,4,0,5,0,4,0,3,0,4,5,5,4,3,5,3,5,3,5,3,5,2,5,3,4,3,3,4,3,4,5,3,2,1,5,4,3,2,3,4,5,3,4,1,2,5,4,3,0,3,3,0,3,2,0,2,3,0,4,1,0,3,4,3,3,5,0,3,0,1,0,4,5,5,5,4,3,0,4,2,0,3,5),
-(0,5,0,4,0,4,0,2,0,5,4,3,4,3,4,3,3,3,4,3,4,2,5,3,5,3,4,1,4,3,4,4,4,0,3,5,0,4,4,4,4,5,3,1,3,4,5,3,3,3,3,3,3,3,0,2,2,0,3,3,2,4,3,3,3,5,3,4,1,3,3,5,3,2,0,0,0,0,4,3,1,3,3),
-(0,1,0,3,0,3,0,1,0,1,3,3,3,2,3,3,3,0,3,0,0,0,3,1,3,0,0,0,2,2,2,3,0,0,3,2,0,1,2,4,1,3,3,0,0,3,3,3,0,1,0,0,2,1,0,0,3,0,3,1,0,3,0,0,1,3,0,2,0,1,0,3,3,1,3,3,0,0,1,1,0,3,3),
-(0,2,0,3,0,2,1,4,0,2,2,3,1,1,3,1,1,0,2,0,3,1,2,3,1,3,0,0,1,0,4,3,2,3,3,3,1,4,2,3,3,3,3,1,0,3,1,4,0,1,1,0,1,2,0,1,1,0,1,1,0,3,1,3,2,2,0,1,0,0,0,2,3,3,3,1,0,0,0,0,0,2,3),
-(0,5,0,4,0,5,0,2,0,4,5,5,3,3,4,3,3,1,5,4,4,2,4,4,4,3,4,2,4,3,5,5,4,3,3,4,3,3,5,5,4,5,5,1,3,4,5,3,1,4,3,1,3,3,0,3,3,1,4,3,1,4,5,3,3,5,0,4,0,3,0,5,3,3,1,4,3,0,4,0,1,5,3),
-(0,5,0,5,0,4,0,2,0,4,4,3,4,3,3,3,3,3,5,4,4,4,4,4,4,5,3,3,5,2,4,4,4,3,4,4,3,3,4,4,5,5,3,3,4,3,4,3,3,4,3,3,3,3,1,2,2,1,4,3,3,5,4,4,3,4,0,4,0,3,0,4,4,4,4,4,1,0,4,2,0,2,4),
-(0,4,0,4,0,3,0,1,0,3,5,2,3,0,3,0,2,1,4,2,3,3,4,1,4,3,3,2,4,1,3,3,3,0,3,3,0,0,3,3,3,5,3,3,3,3,3,2,0,2,0,0,2,0,0,2,0,0,1,0,0,3,1,2,2,3,0,3,0,2,0,4,4,3,3,4,1,0,3,0,0,2,4),
-(0,0,0,4,0,0,0,0,0,0,1,0,1,0,2,0,0,0,0,0,1,0,2,0,1,0,0,0,0,0,3,1,3,0,3,2,0,0,0,1,0,3,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,4,0,2,0,0,0,0,0,0,2),
-(0,2,1,3,0,2,0,2,0,3,3,3,3,1,3,1,3,3,3,3,3,3,4,2,2,1,2,1,4,0,4,3,1,3,3,3,2,4,3,5,4,3,3,3,3,3,3,3,0,1,3,0,2,0,0,1,0,0,1,0,0,4,2,0,2,3,0,3,3,0,3,3,4,2,3,1,4,0,1,2,0,2,3),
-(0,3,0,3,0,1,0,3,0,2,3,3,3,0,3,1,2,0,3,3,2,3,3,2,3,2,3,1,3,0,4,3,2,0,3,3,1,4,3,3,2,3,4,3,1,3,3,1,1,0,1,1,0,1,0,1,0,1,0,0,0,4,1,1,0,3,0,3,1,0,2,3,3,3,3,3,1,0,0,2,0,3,3),
-(0,0,0,0,0,0,0,0,0,0,3,0,2,0,3,0,0,0,0,0,0,0,3,0,0,0,0,0,0,0,3,0,3,0,3,1,0,1,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,2,0,2,3,0,0,0,0,0,0,0,0,3),
-(0,2,0,3,1,3,0,3,0,2,3,3,3,1,3,1,3,1,3,1,3,3,3,1,3,0,2,3,1,1,4,3,3,2,3,3,1,2,2,4,1,3,3,0,1,4,2,3,0,1,3,0,3,0,0,1,3,0,2,0,0,3,3,2,1,3,0,3,0,2,0,3,4,4,4,3,1,0,3,0,0,3,3),
-(0,2,0,1,0,2,0,0,0,1,3,2,2,1,3,0,1,1,3,0,3,2,3,1,2,0,2,0,1,1,3,3,3,0,3,3,1,1,2,3,2,3,3,1,2,3,2,0,0,1,0,0,0,0,0,0,3,0,1,0,0,2,1,2,1,3,0,3,0,0,0,3,4,4,4,3,2,0,2,0,0,2,4),
-(0,0,0,1,0,1,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,2,2,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,1,3,1,0,0,0,0,0,0,0,3),
-(0,3,0,3,0,2,0,3,0,3,3,3,2,3,2,2,2,0,3,1,3,3,3,2,3,3,0,0,3,0,3,2,2,0,2,3,1,4,3,4,3,3,2,3,1,5,4,4,0,3,1,2,1,3,0,3,1,1,2,0,2,3,1,3,1,3,0,3,0,1,0,3,3,4,4,2,1,0,2,1,0,2,4),
-(0,1,0,3,0,1,0,2,0,1,4,2,5,1,4,0,2,0,2,1,3,1,4,0,2,1,0,0,2,1,4,1,1,0,3,3,0,5,1,3,2,3,3,1,0,3,2,3,0,1,0,0,0,0,0,0,1,0,0,0,0,4,0,1,0,3,0,2,0,1,0,3,3,3,4,3,3,0,0,0,0,2,3),
-(0,0,0,1,0,0,0,0,0,0,2,0,1,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,1,0,0,1,0,0,0,0,0,3),
-(0,1,0,3,0,4,0,3,0,2,4,3,1,0,3,2,2,1,3,1,2,2,3,1,1,1,2,1,3,0,1,2,0,1,3,2,1,3,0,5,5,1,0,0,1,3,2,1,0,3,0,0,1,0,0,0,0,0,3,4,0,1,1,1,3,2,0,2,0,1,0,2,3,3,1,2,3,0,1,0,1,0,4),
-(0,0,0,1,0,3,0,3,0,2,2,1,0,0,4,0,3,0,3,1,3,0,3,0,3,0,1,0,3,0,3,1,3,0,3,3,0,0,1,2,1,1,1,0,1,2,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,2,2,1,2,0,0,2,0,0,0,0,2,3,3,3,3,0,0,0,0,1,4),
-(0,0,0,3,0,3,0,0,0,0,3,1,1,0,3,0,1,0,2,0,1,0,0,0,0,0,0,0,1,0,3,0,2,0,2,3,0,0,2,2,3,1,2,0,0,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,2,0,0,0,0,2,3),
-(2,4,0,5,0,5,0,4,0,3,4,3,3,3,4,3,3,3,4,3,4,4,5,4,5,5,5,2,3,0,5,5,4,1,5,4,3,1,5,4,3,4,4,3,3,4,3,3,0,3,2,0,2,3,0,3,0,0,3,3,0,5,3,2,3,3,0,3,0,3,0,3,4,5,4,5,3,0,4,3,0,3,4),
-(0,3,0,3,0,3,0,3,0,3,3,4,3,2,3,2,3,0,4,3,3,3,3,3,3,3,3,0,3,2,4,3,3,1,3,4,3,4,4,4,3,4,4,3,2,4,4,1,0,2,0,0,1,1,0,2,0,0,3,1,0,5,3,2,1,3,0,3,0,1,2,4,3,2,4,3,3,0,3,2,0,4,4),
-(0,3,0,3,0,1,0,0,0,1,4,3,3,2,3,1,3,1,4,2,3,2,4,2,3,4,3,0,2,2,3,3,3,0,3,3,3,0,3,4,1,3,3,0,3,4,3,3,0,1,1,0,1,0,0,0,4,0,3,0,0,3,1,2,1,3,0,4,0,1,0,4,3,3,4,3,3,0,2,0,0,3,3),
-(0,3,0,4,0,1,0,3,0,3,4,3,3,0,3,3,3,1,3,1,3,3,4,3,3,3,0,0,3,1,5,3,3,1,3,3,2,5,4,3,3,4,5,3,2,5,3,4,0,1,0,0,0,0,0,2,0,0,1,1,0,4,2,2,1,3,0,3,0,2,0,4,4,3,5,3,2,0,1,1,0,3,4),
-(0,5,0,4,0,5,0,2,0,4,4,3,3,2,3,3,3,1,4,3,4,1,5,3,4,3,4,0,4,2,4,3,4,1,5,4,0,4,4,4,4,5,4,1,3,5,4,2,1,4,1,1,3,2,0,3,1,0,3,2,1,4,3,3,3,4,0,4,0,3,0,4,4,4,3,3,3,0,4,2,0,3,4),
-(1,4,0,4,0,3,0,1,0,3,3,3,1,1,3,3,2,2,3,3,1,0,3,2,2,1,2,0,3,1,2,1,2,0,3,2,0,2,2,3,3,4,3,0,3,3,1,2,0,1,1,3,1,2,0,0,3,0,1,1,0,3,2,2,3,3,0,3,0,0,0,2,3,3,4,3,3,0,1,0,0,1,4),
-(0,4,0,4,0,4,0,0,0,3,4,4,3,1,4,2,3,2,3,3,3,1,4,3,4,0,3,0,4,2,3,3,2,2,5,4,2,1,3,4,3,4,3,1,3,3,4,2,0,2,1,0,3,3,0,0,2,0,3,1,0,4,4,3,4,3,0,4,0,1,0,2,4,4,4,4,4,0,3,2,0,3,3),
-(0,0,0,1,0,4,0,0,0,0,0,0,1,1,1,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,1,0,3,2,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,2),
-(0,2,0,3,0,4,0,4,0,1,3,3,3,0,4,0,2,1,2,1,1,1,2,0,3,1,1,0,1,0,3,1,0,0,3,3,2,0,1,1,0,0,0,0,0,1,0,2,0,2,2,0,3,1,0,0,1,0,1,1,0,1,2,0,3,0,0,0,0,1,0,0,3,3,4,3,1,0,1,0,3,0,2),
-(0,0,0,3,0,5,0,0,0,0,1,0,2,0,3,1,0,1,3,0,0,0,2,0,0,0,1,0,0,0,1,1,0,0,4,0,0,0,2,3,0,1,4,1,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,0,0,1,0,0,0,0,0,0,0,2,0,0,3,0,0,0,0,0,3),
-(0,2,0,5,0,5,0,1,0,2,4,3,3,2,5,1,3,2,3,3,3,0,4,1,2,0,3,0,4,0,2,2,1,1,5,3,0,0,1,4,2,3,2,0,3,3,3,2,0,2,4,1,1,2,0,1,1,0,3,1,0,1,3,1,2,3,0,2,0,0,0,1,3,5,4,4,4,0,3,0,0,1,3),
-(0,4,0,5,0,4,0,4,0,4,5,4,3,3,4,3,3,3,4,3,4,4,5,3,4,5,4,2,4,2,3,4,3,1,4,4,1,3,5,4,4,5,5,4,4,5,5,5,2,3,3,1,4,3,1,3,3,0,3,3,1,4,3,4,4,4,0,3,0,4,0,3,3,4,4,5,0,0,4,3,0,4,5),
-(0,4,0,4,0,3,0,3,0,3,4,4,4,3,3,2,4,3,4,3,4,3,5,3,4,3,2,1,4,2,4,4,3,1,3,4,2,4,5,5,3,4,5,4,1,5,4,3,0,3,2,2,3,2,1,3,1,0,3,3,3,5,3,3,3,5,4,4,2,3,3,4,3,3,3,2,1,0,3,2,1,4,3),
-(0,4,0,5,0,4,0,3,0,3,5,5,3,2,4,3,4,0,5,4,4,1,4,4,4,3,3,3,4,3,5,5,2,3,3,4,1,2,5,5,3,5,5,2,3,5,5,4,0,3,2,0,3,3,1,1,5,1,4,1,0,4,3,2,3,5,0,4,0,3,0,5,4,3,4,3,0,0,4,1,0,4,4),
-(1,3,0,4,0,2,0,2,0,2,5,5,3,3,3,3,3,0,4,2,3,4,4,4,3,4,0,0,3,4,5,4,3,3,3,3,2,5,5,4,5,5,5,4,3,5,5,5,1,3,1,0,1,0,0,3,2,0,4,2,0,5,2,3,2,4,1,3,0,3,0,4,5,4,5,4,3,0,4,2,0,5,4),
-(0,3,0,4,0,5,0,3,0,3,4,4,3,2,3,2,3,3,3,3,3,2,4,3,3,2,2,0,3,3,3,3,3,1,3,3,3,0,4,4,3,4,4,1,1,4,4,2,0,3,1,0,1,1,0,4,1,0,2,3,1,3,3,1,3,4,0,3,0,1,0,3,1,3,0,0,1,0,2,0,0,4,4),
-(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0),
-(0,3,0,3,0,2,0,3,0,1,5,4,3,3,3,1,4,2,1,2,3,4,4,2,4,4,5,0,3,1,4,3,4,0,4,3,3,3,2,3,2,5,3,4,3,2,2,3,0,0,3,0,2,1,0,1,2,0,0,0,0,2,1,1,3,1,0,2,0,4,0,3,4,4,4,5,2,0,2,0,0,1,3),
-(0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,1,1,1,0,0,1,1,0,0,0,4,2,1,1,0,1,0,3,2,0,0,3,1,1,1,2,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,1,0,0,0,2,0,0,0,1,4,0,4,2,1,0,0,0,0,0,1),
-(0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,1,0,0,0,0,0,0,1,0,1,0,0,0,0,3,1,0,0,0,2,0,2,1,0,0,1,2,1,0,1,1,0,0,3,0,0,0,0,0,0,0,0,0,0,0,1,3,1,0,0,0,0,0,1,0,0,2,1,0,0,0,0,0,0,0,0,2),
-(0,4,0,4,0,4,0,3,0,4,4,3,4,2,4,3,2,0,4,4,4,3,5,3,5,3,3,2,4,2,4,3,4,3,1,4,0,2,3,4,4,4,3,3,3,4,4,4,3,4,1,3,4,3,2,1,2,1,3,3,3,4,4,3,3,5,0,4,0,3,0,4,3,3,3,2,1,0,3,0,0,3,3),
-(0,4,0,3,0,3,0,3,0,3,5,5,3,3,3,3,4,3,4,3,3,3,4,4,4,3,3,3,3,4,3,5,3,3,1,3,2,4,5,5,5,5,4,3,4,5,5,3,2,2,3,3,3,3,2,3,3,1,2,3,2,4,3,3,3,4,0,4,0,2,0,4,3,2,2,1,2,0,3,0,0,4,1),
+# fmt: off
+jp2_char_context = (
+    (0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1),
+    (2, 4, 0, 4, 0, 3, 0, 4, 0, 3, 4, 4, 4, 2, 4, 3, 3, 4, 3, 2, 3, 3, 4, 2, 3, 3, 3, 2, 4, 1, 4, 3, 3, 1, 5, 4, 3, 4, 3, 4, 3, 5, 3, 0, 3, 5, 4, 2, 0, 3, 1, 0, 3, 3, 0, 3, 3, 0, 1, 1, 0, 4, 3, 0, 3, 3, 0, 4, 0, 2, 0, 3, 5, 5, 5, 5, 4, 0, 4, 1, 0, 3, 4),
+    (0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2),
+    (0, 4, 0, 5, 0, 5, 0, 4, 0, 4, 5, 4, 4, 3, 5, 3, 5, 1, 5, 3, 4, 3, 4, 4, 3, 4, 3, 3, 4, 3, 5, 4, 4, 3, 5, 5, 3, 5, 5, 5, 3, 5, 5, 3, 4, 5, 5, 3, 1, 3, 2, 0, 3, 4, 0, 4, 2, 0, 4, 2, 1, 5, 3, 2, 3, 5, 0, 4, 0, 2, 0, 5, 4, 4, 5, 4, 5, 0, 4, 0, 0, 4, 4),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0),
+    (0, 3, 0, 4, 0, 3, 0, 3, 0, 4, 5, 4, 3, 3, 3, 3, 4, 3, 5, 4, 4, 3, 5, 4, 4, 3, 4, 3, 4, 4, 4, 4, 5, 3, 4, 4, 3, 4, 5, 5, 4, 5, 5, 1, 4, 5, 4, 3, 0, 3, 3, 1, 3, 3, 0, 4, 4, 0, 3, 3, 1, 5, 3, 3, 3, 5, 0, 4, 0, 3, 0, 4, 4, 3, 4, 3, 3, 0, 4, 1, 1, 3, 4),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0),
+    (0, 4, 0, 3, 0, 3, 0, 4, 0, 3, 4, 4, 3, 2, 2, 1, 2, 1, 3, 1, 3, 3, 3, 3, 3, 4, 3, 1, 3, 3, 5, 3, 3, 0, 4, 3, 0, 5, 4, 3, 3, 5, 4, 4, 3, 4, 4, 5, 0, 1, 2, 0, 1, 2, 0, 2, 2, 0, 1, 0, 0, 5, 2, 2, 1, 4, 0, 3, 0, 1, 0, 4, 4, 3, 5, 4, 3, 0, 2, 1, 0, 4, 3),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0),
+    (0, 3, 0, 5, 0, 4, 0, 2, 1, 4, 4, 2, 4, 1, 4, 2, 4, 2, 4, 3, 3, 3, 4, 3, 3, 3, 3, 1, 4, 2, 3, 3, 3, 1, 4, 4, 1, 1, 1, 4, 3, 3, 2, 0, 2, 4, 3, 2, 0, 3, 3, 0, 3, 1, 1, 0, 0, 0, 3, 3, 0, 4, 2, 2, 3, 4, 0, 4, 0, 3, 0, 4, 4, 5, 3, 4, 4, 0, 3, 0, 0, 1, 4),
+    (1, 4, 0, 4, 0, 4, 0, 4, 0, 3, 5, 4, 4, 3, 4, 3, 5, 4, 3, 3, 4, 3, 5, 4, 4, 4, 4, 3, 4, 2, 4, 3, 3, 1, 5, 4, 3, 2, 4, 5, 4, 5, 5, 4, 4, 5, 4, 4, 0, 3, 2, 2, 3, 3, 0, 4, 3, 1, 3, 2, 1, 4, 3, 3, 4, 5, 0, 3, 0, 2, 0, 4, 5, 5, 4, 5, 4, 0, 4, 0, 0, 5, 4),
+    (0, 5, 0, 5, 0, 4, 0, 3, 0, 4, 4, 3, 4, 3, 3, 3, 4, 0, 4, 4, 4, 3, 4, 3, 4, 3, 3, 1, 4, 2, 4, 3, 4, 0, 5, 4, 1, 4, 5, 4, 4, 5, 3, 2, 4, 3, 4, 3, 2, 4, 1, 3, 3, 3, 2, 3, 2, 0, 4, 3, 3, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 5, 4, 4, 4, 3, 0, 4, 1, 0, 1, 3),
+    (0, 3, 1, 4, 0, 3, 0, 2, 0, 3, 4, 4, 3, 1, 4, 2, 3, 3, 4, 3, 4, 3, 4, 3, 4, 4, 3, 2, 3, 1, 5, 4, 4, 1, 4, 4, 3, 5, 4, 4, 3, 5, 5, 4, 3, 4, 4, 3, 1, 2, 3, 1, 2, 2, 0, 3, 2, 0, 3, 1, 0, 5, 3, 3, 3, 4, 3, 3, 3, 3, 4, 4, 4, 4, 5, 4, 2, 0, 3, 3, 2, 4, 3),
+    (0, 2, 0, 3, 0, 1, 0, 1, 0, 0, 3, 2, 0, 0, 2, 0, 1, 0, 2, 1, 3, 3, 3, 1, 2, 3, 1, 0, 1, 0, 4, 2, 1, 1, 3, 3, 0, 4, 3, 3, 1, 4, 3, 3, 0, 3, 3, 2, 0, 0, 0, 0, 1, 0, 0, 2, 0, 0, 0, 0, 0, 4, 1, 0, 2, 3, 2, 2, 2, 1, 3, 3, 3, 4, 4, 3, 2, 0, 3, 1, 0, 3, 3),
+    (0, 4, 0, 4, 0, 3, 0, 3, 0, 4, 4, 4, 3, 3, 3, 3, 3, 3, 4, 3, 4, 2, 4, 3, 4, 3, 3, 2, 4, 3, 4, 5, 4, 1, 4, 5, 3, 5, 4, 5, 3, 5, 4, 0, 3, 5, 5, 3, 1, 3, 3, 2, 2, 3, 0, 3, 4, 1, 3, 3, 2, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 5, 4, 4, 5, 3, 0, 4, 1, 0, 3, 4),
+    (0, 2, 0, 3, 0, 3, 0, 0, 0, 2, 2, 2, 1, 0, 1, 0, 0, 0, 3, 0, 3, 0, 3, 0, 1, 3, 1, 0, 3, 1, 3, 3, 3, 1, 3, 3, 3, 0, 1, 3, 1, 3, 4, 0, 0, 3, 1, 1, 0, 3, 2, 0, 0, 0, 0, 1, 3, 0, 1, 0, 0, 3, 3, 2, 0, 3, 0, 0, 0, 0, 0, 3, 4, 3, 4, 3, 3, 0, 3, 0, 0, 2, 3),
+    (2, 3, 0, 3, 0, 2, 0, 1, 0, 3, 3, 4, 3, 1, 3, 1, 1, 1, 3, 1, 4, 3, 4, 3, 3, 3, 0, 0, 3, 1, 5, 4, 3, 1, 4, 3, 2, 5, 5, 4, 4, 4, 4, 3, 3, 4, 4, 4, 0, 2, 1, 1, 3, 2, 0, 1, 2, 0, 0, 1, 0, 4, 1, 3, 3, 3, 0, 3, 0, 1, 0, 4, 4, 4, 5, 5, 3, 0, 2, 0, 0, 4, 4),
+    (0, 2, 0, 1, 0, 3, 1, 3, 0, 2, 3, 3, 3, 0, 3, 1, 0, 0, 3, 0, 3, 2, 3, 1, 3, 2, 1, 1, 0, 0, 4, 2, 1, 0, 2, 3, 1, 4, 3, 2, 0, 4, 4, 3, 1, 3, 1, 3, 0, 1, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 4, 1, 1, 1, 2, 0, 3, 0, 0, 0, 3, 4, 2, 4, 3, 2, 0, 1, 0, 0, 3, 3),
+    (0, 1, 0, 4, 0, 5, 0, 4, 0, 2, 4, 4, 2, 3, 3, 2, 3, 3, 5, 3, 3, 3, 4, 3, 4, 2, 3, 0, 4, 3, 3, 3, 4, 1, 4, 3, 2, 1, 5, 5, 3, 4, 5, 1, 3, 5, 4, 2, 0, 3, 3, 0, 1, 3, 0, 4, 2, 0, 1, 3, 1, 4, 3, 3, 3, 3, 0, 3, 0, 1, 0, 3, 4, 4, 4, 5, 5, 0, 3, 0, 1, 4, 5),
+    (0, 2, 0, 3, 0, 3, 0, 0, 0, 2, 3, 1, 3, 0, 4, 0, 1, 1, 3, 0, 3, 4, 3, 2, 3, 1, 0, 3, 3, 2, 3, 1, 3, 0, 2, 3, 0, 2, 1, 4, 1, 2, 2, 0, 0, 3, 3, 0, 0, 2, 0, 0, 0, 1, 0, 0, 0, 0, 2, 2, 0, 3, 2, 1, 3, 3, 0, 2, 0, 2, 0, 0, 3, 3, 1, 2, 4, 0, 3, 0, 2, 2, 3),
+    (2, 4, 0, 5, 0, 4, 0, 4, 0, 2, 4, 4, 4, 3, 4, 3, 3, 3, 1, 2, 4, 3, 4, 3, 4, 4, 5, 0, 3, 3, 3, 3, 2, 0, 4, 3, 1, 4, 3, 4, 1, 4, 4, 3, 3, 4, 4, 3, 1, 2, 3, 0, 4, 2, 0, 4, 1, 0, 3, 3, 0, 4, 3, 3, 3, 4, 0, 4, 0, 2, 0, 3, 5, 3, 4, 5, 2, 0, 3, 0, 0, 4, 5),
+    (0, 3, 0, 4, 0, 1, 0, 1, 0, 1, 3, 2, 2, 1, 3, 0, 3, 0, 2, 0, 2, 0, 3, 0, 2, 0, 0, 0, 1, 0, 1, 1, 0, 0, 3, 1, 0, 0, 0, 4, 0, 3, 1, 0, 2, 1, 3, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 4, 2, 2, 3, 1, 0, 3, 0, 0, 0, 1, 4, 4, 4, 3, 0, 0, 4, 0, 0, 1, 4),
+    (1, 4, 1, 5, 0, 3, 0, 3, 0, 4, 5, 4, 4, 3, 5, 3, 3, 4, 4, 3, 4, 1, 3, 3, 3, 3, 2, 1, 4, 1, 5, 4, 3, 1, 4, 4, 3, 5, 4, 4, 3, 5, 4, 3, 3, 4, 4, 4, 0, 3, 3, 1, 2, 3, 0, 3, 1, 0, 3, 3, 0, 5, 4, 4, 4, 4, 4, 4, 3, 3, 5, 4, 4, 3, 3, 5, 4, 0, 3, 2, 0, 4, 4),
+    (0, 2, 0, 3, 0, 1, 0, 0, 0, 1, 3, 3, 3, 2, 4, 1, 3, 0, 3, 1, 3, 0, 2, 2, 1, 1, 0, 0, 2, 0, 4, 3, 1, 0, 4, 3, 0, 4, 4, 4, 1, 4, 3, 1, 1, 3, 3, 1, 0, 2, 0, 0, 1, 3, 0, 0, 0, 0, 2, 0, 0, 4, 3, 2, 4, 3, 5, 4, 3, 3, 3, 4, 3, 3, 4, 3, 3, 0, 2, 1, 0, 3, 3),
+    (0, 2, 0, 4, 0, 3, 0, 2, 0, 2, 5, 5, 3, 4, 4, 4, 4, 1, 4, 3, 3, 0, 4, 3, 4, 3, 1, 3, 3, 2, 4, 3, 0, 3, 4, 3, 0, 3, 4, 4, 2, 4, 4, 0, 4, 5, 3, 3, 2, 2, 1, 1, 1, 2, 0, 1, 5, 0, 3, 3, 2, 4, 3, 3, 3, 4, 0, 3, 0, 2, 0, 4, 4, 3, 5, 5, 0, 0, 3, 0, 2, 3, 3),
+    (0, 3, 0, 4, 0, 3, 0, 1, 0, 3, 4, 3, 3, 1, 3, 3, 3, 0, 3, 1, 3, 0, 4, 3, 3, 1, 1, 0, 3, 0, 3, 3, 0, 0, 4, 4, 0, 1, 5, 4, 3, 3, 5, 0, 3, 3, 4, 3, 0, 2, 0, 1, 1, 1, 0, 1, 3, 0, 1, 2, 1, 3, 3, 2, 3, 3, 0, 3, 0, 1, 0, 1, 3, 3, 4, 4, 1, 0, 1, 2, 2, 1, 3),
+    (0, 1, 0, 4, 0, 4, 0, 3, 0, 1, 3, 3, 3, 2, 3, 1, 1, 0, 3, 0, 3, 3, 4, 3, 2, 4, 2, 0, 1, 0, 4, 3, 2, 0, 4, 3, 0, 5, 3, 3, 2, 4, 4, 4, 3, 3, 3, 4, 0, 1, 3, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 4, 2, 3, 3, 3, 0, 3, 0, 0, 0, 4, 4, 4, 5, 3, 2, 0, 3, 3, 0, 3, 5),
+    (0, 2, 0, 3, 0, 0, 0, 3, 0, 1, 3, 0, 2, 0, 0, 0, 1, 0, 3, 1, 1, 3, 3, 0, 0, 3, 0, 0, 3, 0, 2, 3, 1, 0, 3, 1, 0, 3, 3, 2, 0, 4, 2, 2, 0, 2, 0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 2, 0, 1, 0, 1, 0, 0, 0, 1, 3, 1, 2, 0, 0, 0, 1, 0, 0, 1, 4),
+    (0, 3, 0, 3, 0, 5, 0, 1, 0, 2, 4, 3, 1, 3, 3, 2, 1, 1, 5, 2, 1, 0, 5, 1, 2, 0, 0, 0, 3, 3, 2, 2, 3, 2, 4, 3, 0, 0, 3, 3, 1, 3, 3, 0, 2, 5, 3, 4, 0, 3, 3, 0, 1, 2, 0, 2, 2, 0, 3, 2, 0, 2, 2, 3, 3, 3, 0, 2, 0, 1, 0, 3, 4, 4, 2, 5, 4, 0, 3, 0, 0, 3, 5),
+    (0, 3, 0, 3, 0, 3, 0, 1, 0, 3, 3, 3, 3, 0, 3, 0, 2, 0, 2, 1, 1, 0, 2, 0, 1, 0, 0, 0, 2, 1, 0, 0, 1, 0, 3, 2, 0, 0, 3, 3, 1, 2, 3, 1, 0, 3, 3, 0, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 2, 3, 1, 2, 3, 0, 3, 0, 1, 0, 3, 2, 1, 0, 4, 3, 0, 1, 1, 0, 3, 3),
+    (0, 4, 0, 5, 0, 3, 0, 3, 0, 4, 5, 5, 4, 3, 5, 3, 4, 3, 5, 3, 3, 2, 5, 3, 4, 4, 4, 3, 4, 3, 4, 5, 5, 3, 4, 4, 3, 4, 4, 5, 4, 4, 4, 3, 4, 5, 5, 4, 2, 3, 4, 2, 3, 4, 0, 3, 3, 1, 4, 3, 2, 4, 3, 3, 5, 5, 0, 3, 0, 3, 0, 5, 5, 5, 5, 4, 4, 0, 4, 0, 1, 4, 4),
+    (0, 4, 0, 4, 0, 3, 0, 3, 0, 3, 5, 4, 4, 2, 3, 2, 5, 1, 3, 2, 5, 1, 4, 2, 3, 2, 3, 3, 4, 3, 3, 3, 3, 2, 5, 4, 1, 3, 3, 5, 3, 4, 4, 0, 4, 4, 3, 1, 1, 3, 1, 0, 2, 3, 0, 2, 3, 0, 3, 0, 0, 4, 3, 1, 3, 4, 0, 3, 0, 2, 0, 4, 4, 4, 3, 4, 5, 0, 4, 0, 0, 3, 4),
+    (0, 3, 0, 3, 0, 3, 1, 2, 0, 3, 4, 4, 3, 3, 3, 0, 2, 2, 4, 3, 3, 1, 3, 3, 3, 1, 1, 0, 3, 1, 4, 3, 2, 3, 4, 4, 2, 4, 4, 4, 3, 4, 4, 3, 2, 4, 4, 3, 1, 3, 3, 1, 3, 3, 0, 4, 1, 0, 2, 2, 1, 4, 3, 2, 3, 3, 5, 4, 3, 3, 5, 4, 4, 3, 3, 0, 4, 0, 3, 2, 2, 4, 4),
+    (0, 2, 0, 1, 0, 0, 0, 0, 0, 1, 2, 1, 3, 0, 0, 0, 0, 0, 2, 0, 1, 2, 1, 0, 0, 1, 0, 0, 0, 0, 3, 0, 0, 1, 0, 1, 1, 3, 1, 0, 0, 0, 1, 1, 0, 1, 1, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 2, 2, 0, 3, 4, 0, 0, 0, 1, 1, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1),
+    (0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 4, 0, 4, 1, 4, 0, 3, 0, 4, 0, 3, 0, 4, 0, 3, 0, 3, 0, 4, 1, 5, 1, 4, 0, 0, 3, 0, 5, 0, 5, 2, 0, 1, 0, 0, 0, 2, 1, 4, 0, 1, 3, 0, 0, 3, 0, 0, 3, 1, 1, 4, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0),
+    (1, 4, 0, 5, 0, 3, 0, 2, 0, 3, 5, 4, 4, 3, 4, 3, 5, 3, 4, 3, 3, 0, 4, 3, 3, 3, 3, 3, 3, 2, 4, 4, 3, 1, 3, 4, 4, 5, 4, 4, 3, 4, 4, 1, 3, 5, 4, 3, 3, 3, 1, 2, 2, 3, 3, 1, 3, 1, 3, 3, 3, 5, 3, 3, 4, 5, 0, 3, 0, 3, 0, 3, 4, 3, 4, 4, 3, 0, 3, 0, 2, 4, 3),
+    (0, 1, 0, 4, 0, 0, 0, 0, 0, 1, 4, 0, 4, 1, 4, 2, 4, 0, 3, 0, 1, 0, 1, 0, 0, 0, 0, 0, 2, 0, 3, 1, 1, 1, 0, 3, 0, 0, 0, 1, 2, 1, 0, 0, 1, 1, 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 3, 0, 0, 0, 0, 3, 2, 0, 2, 2, 0, 1, 0, 0, 0, 2, 3, 2, 3, 3, 0, 0, 0, 0, 2, 1, 0),
+    (0, 5, 1, 5, 0, 3, 0, 3, 0, 5, 4, 4, 5, 1, 5, 3, 3, 0, 4, 3, 4, 3, 5, 3, 4, 3, 3, 2, 4, 3, 4, 3, 3, 0, 3, 3, 1, 4, 4, 3, 4, 4, 4, 3, 4, 5, 5, 3, 2, 3, 1, 1, 3, 3, 1, 3, 1, 1, 3, 3, 2, 4, 5, 3, 3, 5, 0, 4, 0, 3, 0, 4, 4, 3, 5, 3, 3, 0, 3, 4, 0, 4, 3),
+    (0, 5, 0, 5, 0, 3, 0, 2, 0, 4, 4, 3, 5, 2, 4, 3, 3, 3, 4, 4, 4, 3, 5, 3, 5, 3, 3, 1, 4, 0, 4, 3, 3, 0, 3, 3, 0, 4, 4, 4, 4, 5, 4, 3, 3, 5, 5, 3, 2, 3, 1, 2, 3, 2, 0, 1, 0, 0, 3, 2, 2, 4, 4, 3, 1, 5, 0, 4, 0, 3, 0, 4, 3, 1, 3, 2, 1, 0, 3, 3, 0, 3, 3),
+    (0, 4, 0, 5, 0, 5, 0, 4, 0, 4, 5, 5, 5, 3, 4, 3, 3, 2, 5, 4, 4, 3, 5, 3, 5, 3, 4, 0, 4, 3, 4, 4, 3, 2, 4, 4, 3, 4, 5, 4, 4, 5, 5, 0, 3, 5, 5, 4, 1, 3, 3, 2, 3, 3, 1, 3, 1, 0, 4, 3, 1, 4, 4, 3, 4, 5, 0, 4, 0, 2, 0, 4, 3, 4, 4, 3, 3, 0, 4, 0, 0, 5, 5),
+    (0, 4, 0, 4, 0, 5, 0, 1, 1, 3, 3, 4, 4, 3, 4, 1, 3, 0, 5, 1, 3, 0, 3, 1, 3, 1, 1, 0, 3, 0, 3, 3, 4, 0, 4, 3, 0, 4, 4, 4, 3, 4, 4, 0, 3, 5, 4, 1, 0, 3, 0, 0, 2, 3, 0, 3, 1, 0, 3, 1, 0, 3, 2, 1, 3, 5, 0, 3, 0, 1, 0, 3, 2, 3, 3, 4, 4, 0, 2, 2, 0, 4, 4),
+    (2, 4, 0, 5, 0, 4, 0, 3, 0, 4, 5, 5, 4, 3, 5, 3, 5, 3, 5, 3, 5, 2, 5, 3, 4, 3, 3, 4, 3, 4, 5, 3, 2, 1, 5, 4, 3, 2, 3, 4, 5, 3, 4, 1, 2, 5, 4, 3, 0, 3, 3, 0, 3, 2, 0, 2, 3, 0, 4, 1, 0, 3, 4, 3, 3, 5, 0, 3, 0, 1, 0, 4, 5, 5, 5, 4, 3, 0, 4, 2, 0, 3, 5),
+    (0, 5, 0, 4, 0, 4, 0, 2, 0, 5, 4, 3, 4, 3, 4, 3, 3, 3, 4, 3, 4, 2, 5, 3, 5, 3, 4, 1, 4, 3, 4, 4, 4, 0, 3, 5, 0, 4, 4, 4, 4, 5, 3, 1, 3, 4, 5, 3, 3, 3, 3, 3, 3, 3, 0, 2, 2, 0, 3, 3, 2, 4, 3, 3, 3, 5, 3, 4, 1, 3, 3, 5, 3, 2, 0, 0, 0, 0, 4, 3, 1, 3, 3),
+    (0, 1, 0, 3, 0, 3, 0, 1, 0, 1, 3, 3, 3, 2, 3, 3, 3, 0, 3, 0, 0, 0, 3, 1, 3, 0, 0, 0, 2, 2, 2, 3, 0, 0, 3, 2, 0, 1, 2, 4, 1, 3, 3, 0, 0, 3, 3, 3, 0, 1, 0, 0, 2, 1, 0, 0, 3, 0, 3, 1, 0, 3, 0, 0, 1, 3, 0, 2, 0, 1, 0, 3, 3, 1, 3, 3, 0, 0, 1, 1, 0, 3, 3),
+    (0, 2, 0, 3, 0, 2, 1, 4, 0, 2, 2, 3, 1, 1, 3, 1, 1, 0, 2, 0, 3, 1, 2, 3, 1, 3, 0, 0, 1, 0, 4, 3, 2, 3, 3, 3, 1, 4, 2, 3, 3, 3, 3, 1, 0, 3, 1, 4, 0, 1, 1, 0, 1, 2, 0, 1, 1, 0, 1, 1, 0, 3, 1, 3, 2, 2, 0, 1, 0, 0, 0, 2, 3, 3, 3, 1, 0, 0, 0, 0, 0, 2, 3),
+    (0, 5, 0, 4, 0, 5, 0, 2, 0, 4, 5, 5, 3, 3, 4, 3, 3, 1, 5, 4, 4, 2, 4, 4, 4, 3, 4, 2, 4, 3, 5, 5, 4, 3, 3, 4, 3, 3, 5, 5, 4, 5, 5, 1, 3, 4, 5, 3, 1, 4, 3, 1, 3, 3, 0, 3, 3, 1, 4, 3, 1, 4, 5, 3, 3, 5, 0, 4, 0, 3, 0, 5, 3, 3, 1, 4, 3, 0, 4, 0, 1, 5, 3),
+    (0, 5, 0, 5, 0, 4, 0, 2, 0, 4, 4, 3, 4, 3, 3, 3, 3, 3, 5, 4, 4, 4, 4, 4, 4, 5, 3, 3, 5, 2, 4, 4, 4, 3, 4, 4, 3, 3, 4, 4, 5, 5, 3, 3, 4, 3, 4, 3, 3, 4, 3, 3, 3, 3, 1, 2, 2, 1, 4, 3, 3, 5, 4, 4, 3, 4, 0, 4, 0, 3, 0, 4, 4, 4, 4, 4, 1, 0, 4, 2, 0, 2, 4),
+    (0, 4, 0, 4, 0, 3, 0, 1, 0, 3, 5, 2, 3, 0, 3, 0, 2, 1, 4, 2, 3, 3, 4, 1, 4, 3, 3, 2, 4, 1, 3, 3, 3, 0, 3, 3, 0, 0, 3, 3, 3, 5, 3, 3, 3, 3, 3, 2, 0, 2, 0, 0, 2, 0, 0, 2, 0, 0, 1, 0, 0, 3, 1, 2, 2, 3, 0, 3, 0, 2, 0, 4, 4, 3, 3, 4, 1, 0, 3, 0, 0, 2, 4),
+    (0, 0, 0, 4, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 2, 0, 0, 0, 0, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0, 0, 3, 1, 3, 0, 3, 2, 0, 0, 0, 1, 0, 3, 2, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 0, 2, 0, 0, 0, 0, 0, 0, 2),
+    (0, 2, 1, 3, 0, 2, 0, 2, 0, 3, 3, 3, 3, 1, 3, 1, 3, 3, 3, 3, 3, 3, 4, 2, 2, 1, 2, 1, 4, 0, 4, 3, 1, 3, 3, 3, 2, 4, 3, 5, 4, 3, 3, 3, 3, 3, 3, 3, 0, 1, 3, 0, 2, 0, 0, 1, 0, 0, 1, 0, 0, 4, 2, 0, 2, 3, 0, 3, 3, 0, 3, 3, 4, 2, 3, 1, 4, 0, 1, 2, 0, 2, 3),
+    (0, 3, 0, 3, 0, 1, 0, 3, 0, 2, 3, 3, 3, 0, 3, 1, 2, 0, 3, 3, 2, 3, 3, 2, 3, 2, 3, 1, 3, 0, 4, 3, 2, 0, 3, 3, 1, 4, 3, 3, 2, 3, 4, 3, 1, 3, 3, 1, 1, 0, 1, 1, 0, 1, 0, 1, 0, 1, 0, 0, 0, 4, 1, 1, 0, 3, 0, 3, 1, 0, 2, 3, 3, 3, 3, 3, 1, 0, 0, 2, 0, 3, 3),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 3, 0, 3, 0, 3, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 2, 0, 2, 3, 0, 0, 0, 0, 0, 0, 0, 0, 3),
+    (0, 2, 0, 3, 1, 3, 0, 3, 0, 2, 3, 3, 3, 1, 3, 1, 3, 1, 3, 1, 3, 3, 3, 1, 3, 0, 2, 3, 1, 1, 4, 3, 3, 2, 3, 3, 1, 2, 2, 4, 1, 3, 3, 0, 1, 4, 2, 3, 0, 1, 3, 0, 3, 0, 0, 1, 3, 0, 2, 0, 0, 3, 3, 2, 1, 3, 0, 3, 0, 2, 0, 3, 4, 4, 4, 3, 1, 0, 3, 0, 0, 3, 3),
+    (0, 2, 0, 1, 0, 2, 0, 0, 0, 1, 3, 2, 2, 1, 3, 0, 1, 1, 3, 0, 3, 2, 3, 1, 2, 0, 2, 0, 1, 1, 3, 3, 3, 0, 3, 3, 1, 1, 2, 3, 2, 3, 3, 1, 2, 3, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 0, 2, 1, 2, 1, 3, 0, 3, 0, 0, 0, 3, 4, 4, 4, 3, 2, 0, 2, 0, 0, 2, 4),
+    (0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 0, 0, 0, 3),
+    (0, 3, 0, 3, 0, 2, 0, 3, 0, 3, 3, 3, 2, 3, 2, 2, 2, 0, 3, 1, 3, 3, 3, 2, 3, 3, 0, 0, 3, 0, 3, 2, 2, 0, 2, 3, 1, 4, 3, 4, 3, 3, 2, 3, 1, 5, 4, 4, 0, 3, 1, 2, 1, 3, 0, 3, 1, 1, 2, 0, 2, 3, 1, 3, 1, 3, 0, 3, 0, 1, 0, 3, 3, 4, 4, 2, 1, 0, 2, 1, 0, 2, 4),
+    (0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 4, 2, 5, 1, 4, 0, 2, 0, 2, 1, 3, 1, 4, 0, 2, 1, 0, 0, 2, 1, 4, 1, 1, 0, 3, 3, 0, 5, 1, 3, 2, 3, 3, 1, 0, 3, 2, 3, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 4, 0, 1, 0, 3, 0, 2, 0, 1, 0, 3, 3, 3, 4, 3, 3, 0, 0, 0, 0, 2, 3),
+    (0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 2, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 0, 0, 1, 0, 0, 0, 0, 0, 3),
+    (0, 1, 0, 3, 0, 4, 0, 3, 0, 2, 4, 3, 1, 0, 3, 2, 2, 1, 3, 1, 2, 2, 3, 1, 1, 1, 2, 1, 3, 0, 1, 2, 0, 1, 3, 2, 1, 3, 0, 5, 5, 1, 0, 0, 1, 3, 2, 1, 0, 3, 0, 0, 1, 0, 0, 0, 0, 0, 3, 4, 0, 1, 1, 1, 3, 2, 0, 2, 0, 1, 0, 2, 3, 3, 1, 2, 3, 0, 1, 0, 1, 0, 4),
+    (0, 0, 0, 1, 0, 3, 0, 3, 0, 2, 2, 1, 0, 0, 4, 0, 3, 0, 3, 1, 3, 0, 3, 0, 3, 0, 1, 0, 3, 0, 3, 1, 3, 0, 3, 3, 0, 0, 1, 2, 1, 1, 1, 0, 1, 2, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 2, 1, 2, 0, 0, 2, 0, 0, 0, 0, 2, 3, 3, 3, 3, 0, 0, 0, 0, 1, 4),
+    (0, 0, 0, 3, 0, 3, 0, 0, 0, 0, 3, 1, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 0, 2, 0, 2, 3, 0, 0, 2, 2, 3, 1, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 2, 3),
+    (2, 4, 0, 5, 0, 5, 0, 4, 0, 3, 4, 3, 3, 3, 4, 3, 3, 3, 4, 3, 4, 4, 5, 4, 5, 5, 5, 2, 3, 0, 5, 5, 4, 1, 5, 4, 3, 1, 5, 4, 3, 4, 4, 3, 3, 4, 3, 3, 0, 3, 2, 0, 2, 3, 0, 3, 0, 0, 3, 3, 0, 5, 3, 2, 3, 3, 0, 3, 0, 3, 0, 3, 4, 5, 4, 5, 3, 0, 4, 3, 0, 3, 4),
+    (0, 3, 0, 3, 0, 3, 0, 3, 0, 3, 3, 4, 3, 2, 3, 2, 3, 0, 4, 3, 3, 3, 3, 3, 3, 3, 3, 0, 3, 2, 4, 3, 3, 1, 3, 4, 3, 4, 4, 4, 3, 4, 4, 3, 2, 4, 4, 1, 0, 2, 0, 0, 1, 1, 0, 2, 0, 0, 3, 1, 0, 5, 3, 2, 1, 3, 0, 3, 0, 1, 2, 4, 3, 2, 4, 3, 3, 0, 3, 2, 0, 4, 4),
+    (0, 3, 0, 3, 0, 1, 0, 0, 0, 1, 4, 3, 3, 2, 3, 1, 3, 1, 4, 2, 3, 2, 4, 2, 3, 4, 3, 0, 2, 2, 3, 3, 3, 0, 3, 3, 3, 0, 3, 4, 1, 3, 3, 0, 3, 4, 3, 3, 0, 1, 1, 0, 1, 0, 0, 0, 4, 0, 3, 0, 0, 3, 1, 2, 1, 3, 0, 4, 0, 1, 0, 4, 3, 3, 4, 3, 3, 0, 2, 0, 0, 3, 3),
+    (0, 3, 0, 4, 0, 1, 0, 3, 0, 3, 4, 3, 3, 0, 3, 3, 3, 1, 3, 1, 3, 3, 4, 3, 3, 3, 0, 0, 3, 1, 5, 3, 3, 1, 3, 3, 2, 5, 4, 3, 3, 4, 5, 3, 2, 5, 3, 4, 0, 1, 0, 0, 0, 0, 0, 2, 0, 0, 1, 1, 0, 4, 2, 2, 1, 3, 0, 3, 0, 2, 0, 4, 4, 3, 5, 3, 2, 0, 1, 1, 0, 3, 4),
+    (0, 5, 0, 4, 0, 5, 0, 2, 0, 4, 4, 3, 3, 2, 3, 3, 3, 1, 4, 3, 4, 1, 5, 3, 4, 3, 4, 0, 4, 2, 4, 3, 4, 1, 5, 4, 0, 4, 4, 4, 4, 5, 4, 1, 3, 5, 4, 2, 1, 4, 1, 1, 3, 2, 0, 3, 1, 0, 3, 2, 1, 4, 3, 3, 3, 4, 0, 4, 0, 3, 0, 4, 4, 4, 3, 3, 3, 0, 4, 2, 0, 3, 4),
+    (1, 4, 0, 4, 0, 3, 0, 1, 0, 3, 3, 3, 1, 1, 3, 3, 2, 2, 3, 3, 1, 0, 3, 2, 2, 1, 2, 0, 3, 1, 2, 1, 2, 0, 3, 2, 0, 2, 2, 3, 3, 4, 3, 0, 3, 3, 1, 2, 0, 1, 1, 3, 1, 2, 0, 0, 3, 0, 1, 1, 0, 3, 2, 2, 3, 3, 0, 3, 0, 0, 0, 2, 3, 3, 4, 3, 3, 0, 1, 0, 0, 1, 4),
+    (0, 4, 0, 4, 0, 4, 0, 0, 0, 3, 4, 4, 3, 1, 4, 2, 3, 2, 3, 3, 3, 1, 4, 3, 4, 0, 3, 0, 4, 2, 3, 3, 2, 2, 5, 4, 2, 1, 3, 4, 3, 4, 3, 1, 3, 3, 4, 2, 0, 2, 1, 0, 3, 3, 0, 0, 2, 0, 3, 1, 0, 4, 4, 3, 4, 3, 0, 4, 0, 1, 0, 2, 4, 4, 4, 4, 4, 0, 3, 2, 0, 3, 3),
+    (0, 0, 0, 1, 0, 4, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 2, 0, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 2),
+    (0, 2, 0, 3, 0, 4, 0, 4, 0, 1, 3, 3, 3, 0, 4, 0, 2, 1, 2, 1, 1, 1, 2, 0, 3, 1, 1, 0, 1, 0, 3, 1, 0, 0, 3, 3, 2, 0, 1, 1, 0, 0, 0, 0, 0, 1, 0, 2, 0, 2, 2, 0, 3, 1, 0, 0, 1, 0, 1, 1, 0, 1, 2, 0, 3, 0, 0, 0, 0, 1, 0, 0, 3, 3, 4, 3, 1, 0, 1, 0, 3, 0, 2),
+    (0, 0, 0, 3, 0, 5, 0, 0, 0, 0, 1, 0, 2, 0, 3, 1, 0, 1, 3, 0, 0, 0, 2, 0, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 4, 0, 0, 0, 2, 3, 0, 1, 4, 1, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 3, 0, 0, 0, 0, 0, 3),
+    (0, 2, 0, 5, 0, 5, 0, 1, 0, 2, 4, 3, 3, 2, 5, 1, 3, 2, 3, 3, 3, 0, 4, 1, 2, 0, 3, 0, 4, 0, 2, 2, 1, 1, 5, 3, 0, 0, 1, 4, 2, 3, 2, 0, 3, 3, 3, 2, 0, 2, 4, 1, 1, 2, 0, 1, 1, 0, 3, 1, 0, 1, 3, 1, 2, 3, 0, 2, 0, 0, 0, 1, 3, 5, 4, 4, 4, 0, 3, 0, 0, 1, 3),
+    (0, 4, 0, 5, 0, 4, 0, 4, 0, 4, 5, 4, 3, 3, 4, 3, 3, 3, 4, 3, 4, 4, 5, 3, 4, 5, 4, 2, 4, 2, 3, 4, 3, 1, 4, 4, 1, 3, 5, 4, 4, 5, 5, 4, 4, 5, 5, 5, 2, 3, 3, 1, 4, 3, 1, 3, 3, 0, 3, 3, 1, 4, 3, 4, 4, 4, 0, 3, 0, 4, 0, 3, 3, 4, 4, 5, 0, 0, 4, 3, 0, 4, 5),
+    (0, 4, 0, 4, 0, 3, 0, 3, 0, 3, 4, 4, 4, 3, 3, 2, 4, 3, 4, 3, 4, 3, 5, 3, 4, 3, 2, 1, 4, 2, 4, 4, 3, 1, 3, 4, 2, 4, 5, 5, 3, 4, 5, 4, 1, 5, 4, 3, 0, 3, 2, 2, 3, 2, 1, 3, 1, 0, 3, 3, 3, 5, 3, 3, 3, 5, 4, 4, 2, 3, 3, 4, 3, 3, 3, 2, 1, 0, 3, 2, 1, 4, 3),
+    (0, 4, 0, 5, 0, 4, 0, 3, 0, 3, 5, 5, 3, 2, 4, 3, 4, 0, 5, 4, 4, 1, 4, 4, 4, 3, 3, 3, 4, 3, 5, 5, 2, 3, 3, 4, 1, 2, 5, 5, 3, 5, 5, 2, 3, 5, 5, 4, 0, 3, 2, 0, 3, 3, 1, 1, 5, 1, 4, 1, 0, 4, 3, 2, 3, 5, 0, 4, 0, 3, 0, 5, 4, 3, 4, 3, 0, 0, 4, 1, 0, 4, 4),
+    (1, 3, 0, 4, 0, 2, 0, 2, 0, 2, 5, 5, 3, 3, 3, 3, 3, 0, 4, 2, 3, 4, 4, 4, 3, 4, 0, 0, 3, 4, 5, 4, 3, 3, 3, 3, 2, 5, 5, 4, 5, 5, 5, 4, 3, 5, 5, 5, 1, 3, 1, 0, 1, 0, 0, 3, 2, 0, 4, 2, 0, 5, 2, 3, 2, 4, 1, 3, 0, 3, 0, 4, 5, 4, 5, 4, 3, 0, 4, 2, 0, 5, 4),
+    (0, 3, 0, 4, 0, 5, 0, 3, 0, 3, 4, 4, 3, 2, 3, 2, 3, 3, 3, 3, 3, 2, 4, 3, 3, 2, 2, 0, 3, 3, 3, 3, 3, 1, 3, 3, 3, 0, 4, 4, 3, 4, 4, 1, 1, 4, 4, 2, 0, 3, 1, 0, 1, 1, 0, 4, 1, 0, 2, 3, 1, 3, 3, 1, 3, 4, 0, 3, 0, 1, 0, 3, 1, 3, 0, 0, 1, 0, 2, 0, 0, 4, 4),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0),
+    (0, 3, 0, 3, 0, 2, 0, 3, 0, 1, 5, 4, 3, 3, 3, 1, 4, 2, 1, 2, 3, 4, 4, 2, 4, 4, 5, 0, 3, 1, 4, 3, 4, 0, 4, 3, 3, 3, 2, 3, 2, 5, 3, 4, 3, 2, 2, 3, 0, 0, 3, 0, 2, 1, 0, 1, 2, 0, 0, 0, 0, 2, 1, 1, 3, 1, 0, 2, 0, 4, 0, 3, 4, 4, 4, 5, 2, 0, 2, 0, 0, 1, 3),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1, 1, 0, 0, 0, 4, 2, 1, 1, 0, 1, 0, 3, 2, 0, 0, 3, 1, 1, 1, 2, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 1, 0, 0, 0, 2, 0, 0, 0, 1, 4, 0, 4, 2, 1, 0, 0, 0, 0, 0, 1),
+    (0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 0, 0, 0, 3, 1, 0, 0, 0, 2, 0, 2, 1, 0, 0, 1, 2, 1, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 3, 1, 0, 0, 0, 0, 0, 1, 0, 0, 2, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2),
+    (0, 4, 0, 4, 0, 4, 0, 3, 0, 4, 4, 3, 4, 2, 4, 3, 2, 0, 4, 4, 4, 3, 5, 3, 5, 3, 3, 2, 4, 2, 4, 3, 4, 3, 1, 4, 0, 2, 3, 4, 4, 4, 3, 3, 3, 4, 4, 4, 3, 4, 1, 3, 4, 3, 2, 1, 2, 1, 3, 3, 3, 4, 4, 3, 3, 5, 0, 4, 0, 3, 0, 4, 3, 3, 3, 2, 1, 0, 3, 0, 0, 3, 3),
+    (0, 4, 0, 3, 0, 3, 0, 3, 0, 3, 5, 5, 3, 3, 3, 3, 4, 3, 4, 3, 3, 3, 4, 4, 4, 3, 3, 3, 3, 4, 3, 5, 3, 3, 1, 3, 2, 4, 5, 5, 5, 5, 4, 3, 4, 5, 5, 3, 2, 2, 3, 3, 3, 3, 2, 3, 3, 1, 2, 3, 2, 4, 3, 3, 3, 4, 0, 4, 0, 2, 0, 4, 3, 2, 2, 1, 2, 0, 3, 0, 0, 4, 1),
 )
+# fmt: on
 
-class JapaneseContextAnalysis(object):
+
+class JapaneseContextAnalysis:
     NUM_OF_CATEGORY = 6
     DONT_KNOW = -1
     ENOUGH_REL_THRESHOLD = 100
     MAX_REL_THRESHOLD = 1000
     MINIMUM_DATA_THRESHOLD = 4
 
-    def __init__(self):
-        self._total_rel = None
-        self._rel_sample = None
-        self._need_to_skip_char_num = None
-        self._last_char_order = None
-        self._done = None
+    def __init__(self) -> None:
+        self._total_rel = 0
+        self._rel_sample: List[int] = []
+        self._need_to_skip_char_num = 0
+        self._last_char_order = -1
+        self._done = False
         self.reset()
 
-    def reset(self):
+    def reset(self) -> None:
         self._total_rel = 0  # total sequence received
         # category counters, each integer counts sequence in its category
         self._rel_sample = [0] * self.NUM_OF_CATEGORY
@@ -140,7 +144,7 @@ class JapaneseContextAnalysis(object):
         # been made
         self._done = False
 
-    def feed(self, byte_str, num_bytes):
+    def feed(self, byte_str: Union[bytes, bytearray], num_bytes: int) -> None:
         if self._done:
             return
 
@@ -153,7 +157,7 @@ class JapaneseContextAnalysis(object):
         # this character will simply our logic and improve performance.
         i = self._need_to_skip_char_num
         while i < num_bytes:
-            order, char_len = self.get_order(byte_str[i:i + 2])
+            order, char_len = self.get_order(byte_str[i : i + 2])
             i += char_len
             if i > num_bytes:
                 self._need_to_skip_char_num = i - num_bytes
@@ -164,32 +168,34 @@ class JapaneseContextAnalysis(object):
                     if self._total_rel > self.MAX_REL_THRESHOLD:
                         self._done = True
                         break
-                    self._rel_sample[jp2CharContext[self._last_char_order][order]] += 1
+                    self._rel_sample[
+                        jp2_char_context[self._last_char_order][order]
+                    ] += 1
                 self._last_char_order = order
 
-    def got_enough_data(self):
+    def got_enough_data(self) -> bool:
         return self._total_rel > self.ENOUGH_REL_THRESHOLD
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         # This is just one way to calculate confidence. It works well for me.
         if self._total_rel > self.MINIMUM_DATA_THRESHOLD:
             return (self._total_rel - self._rel_sample[0]) / self._total_rel
-        else:
-            return self.DONT_KNOW
+        return self.DONT_KNOW
 
-    def get_order(self, byte_str):
+    def get_order(self, _: Union[bytes, bytearray]) -> Tuple[int, int]:
         return -1, 1
 
+
 class SJISContextAnalysis(JapaneseContextAnalysis):
-    def __init__(self):
-        super(SJISContextAnalysis, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self._charset_name = "SHIFT_JIS"
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return self._charset_name
 
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> Tuple[int, int]:
         if not byte_str:
             return -1, 1
         # find out current char's byte length
@@ -209,8 +215,9 @@ class SJISContextAnalysis(JapaneseContextAnalysis):
 
         return -1, char_len
 
+
 class EUCJPContextAnalysis(JapaneseContextAnalysis):
-    def get_order(self, byte_str):
+    def get_order(self, byte_str: Union[bytes, bytearray]) -> Tuple[int, int]:
         if not byte_str:
             return -1, 1
         # find out current char's byte length
@@ -229,5 +236,3 @@ class EUCJPContextAnalysis(JapaneseContextAnalysis):
                 return second_char - 0xA1, char_len
 
         return -1, char_len
-
-
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py
index e963a509..99466821 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langbulgarianmodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -4115,536 +4111,539 @@ BULGARIAN_LANG_MODEL = {
 
 # Character Mapping Table(s):
 ISO_8859_5_BULGARIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 77,  # 'A'
-     66: 90,  # 'B'
-     67: 99,  # 'C'
-     68: 100,  # 'D'
-     69: 72,  # 'E'
-     70: 109,  # 'F'
-     71: 107,  # 'G'
-     72: 101,  # 'H'
-     73: 79,  # 'I'
-     74: 185,  # 'J'
-     75: 81,  # 'K'
-     76: 102,  # 'L'
-     77: 76,  # 'M'
-     78: 94,  # 'N'
-     79: 82,  # 'O'
-     80: 110,  # 'P'
-     81: 186,  # 'Q'
-     82: 108,  # 'R'
-     83: 91,  # 'S'
-     84: 74,  # 'T'
-     85: 119,  # 'U'
-     86: 84,  # 'V'
-     87: 96,  # 'W'
-     88: 111,  # 'X'
-     89: 187,  # 'Y'
-     90: 115,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 65,  # 'a'
-     98: 69,  # 'b'
-     99: 70,  # 'c'
-     100: 66,  # 'd'
-     101: 63,  # 'e'
-     102: 68,  # 'f'
-     103: 112,  # 'g'
-     104: 103,  # 'h'
-     105: 92,  # 'i'
-     106: 194,  # 'j'
-     107: 104,  # 'k'
-     108: 95,  # 'l'
-     109: 86,  # 'm'
-     110: 87,  # 'n'
-     111: 71,  # 'o'
-     112: 116,  # 'p'
-     113: 195,  # 'q'
-     114: 85,  # 'r'
-     115: 93,  # 's'
-     116: 97,  # 't'
-     117: 113,  # 'u'
-     118: 196,  # 'v'
-     119: 197,  # 'w'
-     120: 198,  # 'x'
-     121: 199,  # 'y'
-     122: 200,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 194,  # '\x80'
-     129: 195,  # '\x81'
-     130: 196,  # '\x82'
-     131: 197,  # '\x83'
-     132: 198,  # '\x84'
-     133: 199,  # '\x85'
-     134: 200,  # '\x86'
-     135: 201,  # '\x87'
-     136: 202,  # '\x88'
-     137: 203,  # '\x89'
-     138: 204,  # '\x8a'
-     139: 205,  # '\x8b'
-     140: 206,  # '\x8c'
-     141: 207,  # '\x8d'
-     142: 208,  # '\x8e'
-     143: 209,  # '\x8f'
-     144: 210,  # '\x90'
-     145: 211,  # '\x91'
-     146: 212,  # '\x92'
-     147: 213,  # '\x93'
-     148: 214,  # '\x94'
-     149: 215,  # '\x95'
-     150: 216,  # '\x96'
-     151: 217,  # '\x97'
-     152: 218,  # '\x98'
-     153: 219,  # '\x99'
-     154: 220,  # '\x9a'
-     155: 221,  # '\x9b'
-     156: 222,  # '\x9c'
-     157: 223,  # '\x9d'
-     158: 224,  # '\x9e'
-     159: 225,  # '\x9f'
-     160: 81,  # '\xa0'
-     161: 226,  # 'Ё'
-     162: 227,  # 'Ђ'
-     163: 228,  # 'Ѓ'
-     164: 229,  # 'Є'
-     165: 230,  # 'Ѕ'
-     166: 105,  # 'І'
-     167: 231,  # 'Ї'
-     168: 232,  # 'Ј'
-     169: 233,  # 'Љ'
-     170: 234,  # 'Њ'
-     171: 235,  # 'Ћ'
-     172: 236,  # 'Ќ'
-     173: 45,  # '\xad'
-     174: 237,  # 'Ў'
-     175: 238,  # 'Џ'
-     176: 31,  # 'А'
-     177: 32,  # 'Б'
-     178: 35,  # 'В'
-     179: 43,  # 'Г'
-     180: 37,  # 'Д'
-     181: 44,  # 'Е'
-     182: 55,  # 'Ж'
-     183: 47,  # 'З'
-     184: 40,  # 'И'
-     185: 59,  # 'Й'
-     186: 33,  # 'К'
-     187: 46,  # 'Л'
-     188: 38,  # 'М'
-     189: 36,  # 'Н'
-     190: 41,  # 'О'
-     191: 30,  # 'П'
-     192: 39,  # 'Р'
-     193: 28,  # 'С'
-     194: 34,  # 'Т'
-     195: 51,  # 'У'
-     196: 48,  # 'Ф'
-     197: 49,  # 'Х'
-     198: 53,  # 'Ц'
-     199: 50,  # 'Ч'
-     200: 54,  # 'Ш'
-     201: 57,  # 'Щ'
-     202: 61,  # 'Ъ'
-     203: 239,  # 'Ы'
-     204: 67,  # 'Ь'
-     205: 240,  # 'Э'
-     206: 60,  # 'Ю'
-     207: 56,  # 'Я'
-     208: 1,  # 'а'
-     209: 18,  # 'б'
-     210: 9,  # 'в'
-     211: 20,  # 'г'
-     212: 11,  # 'д'
-     213: 3,  # 'е'
-     214: 23,  # 'ж'
-     215: 15,  # 'з'
-     216: 2,  # 'и'
-     217: 26,  # 'й'
-     218: 12,  # 'к'
-     219: 10,  # 'л'
-     220: 14,  # 'м'
-     221: 6,  # 'н'
-     222: 4,  # 'о'
-     223: 13,  # 'п'
-     224: 7,  # 'р'
-     225: 8,  # 'с'
-     226: 5,  # 'т'
-     227: 19,  # 'у'
-     228: 29,  # 'ф'
-     229: 25,  # 'х'
-     230: 22,  # 'ц'
-     231: 21,  # 'ч'
-     232: 27,  # 'ш'
-     233: 24,  # 'щ'
-     234: 17,  # 'ъ'
-     235: 75,  # 'ы'
-     236: 52,  # 'ь'
-     237: 241,  # 'э'
-     238: 42,  # 'ю'
-     239: 16,  # 'я'
-     240: 62,  # '№'
-     241: 242,  # 'ё'
-     242: 243,  # 'ђ'
-     243: 244,  # 'ѓ'
-     244: 58,  # 'є'
-     245: 245,  # 'ѕ'
-     246: 98,  # 'і'
-     247: 246,  # 'ї'
-     248: 247,  # 'ј'
-     249: 248,  # 'љ'
-     250: 249,  # 'њ'
-     251: 250,  # 'ћ'
-     252: 251,  # 'ќ'
-     253: 91,  # '§'
-     254: 252,  # 'ў'
-     255: 253,  # 'џ'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 77,  # 'A'
+    66: 90,  # 'B'
+    67: 99,  # 'C'
+    68: 100,  # 'D'
+    69: 72,  # 'E'
+    70: 109,  # 'F'
+    71: 107,  # 'G'
+    72: 101,  # 'H'
+    73: 79,  # 'I'
+    74: 185,  # 'J'
+    75: 81,  # 'K'
+    76: 102,  # 'L'
+    77: 76,  # 'M'
+    78: 94,  # 'N'
+    79: 82,  # 'O'
+    80: 110,  # 'P'
+    81: 186,  # 'Q'
+    82: 108,  # 'R'
+    83: 91,  # 'S'
+    84: 74,  # 'T'
+    85: 119,  # 'U'
+    86: 84,  # 'V'
+    87: 96,  # 'W'
+    88: 111,  # 'X'
+    89: 187,  # 'Y'
+    90: 115,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 65,  # 'a'
+    98: 69,  # 'b'
+    99: 70,  # 'c'
+    100: 66,  # 'd'
+    101: 63,  # 'e'
+    102: 68,  # 'f'
+    103: 112,  # 'g'
+    104: 103,  # 'h'
+    105: 92,  # 'i'
+    106: 194,  # 'j'
+    107: 104,  # 'k'
+    108: 95,  # 'l'
+    109: 86,  # 'm'
+    110: 87,  # 'n'
+    111: 71,  # 'o'
+    112: 116,  # 'p'
+    113: 195,  # 'q'
+    114: 85,  # 'r'
+    115: 93,  # 's'
+    116: 97,  # 't'
+    117: 113,  # 'u'
+    118: 196,  # 'v'
+    119: 197,  # 'w'
+    120: 198,  # 'x'
+    121: 199,  # 'y'
+    122: 200,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 194,  # '\x80'
+    129: 195,  # '\x81'
+    130: 196,  # '\x82'
+    131: 197,  # '\x83'
+    132: 198,  # '\x84'
+    133: 199,  # '\x85'
+    134: 200,  # '\x86'
+    135: 201,  # '\x87'
+    136: 202,  # '\x88'
+    137: 203,  # '\x89'
+    138: 204,  # '\x8a'
+    139: 205,  # '\x8b'
+    140: 206,  # '\x8c'
+    141: 207,  # '\x8d'
+    142: 208,  # '\x8e'
+    143: 209,  # '\x8f'
+    144: 210,  # '\x90'
+    145: 211,  # '\x91'
+    146: 212,  # '\x92'
+    147: 213,  # '\x93'
+    148: 214,  # '\x94'
+    149: 215,  # '\x95'
+    150: 216,  # '\x96'
+    151: 217,  # '\x97'
+    152: 218,  # '\x98'
+    153: 219,  # '\x99'
+    154: 220,  # '\x9a'
+    155: 221,  # '\x9b'
+    156: 222,  # '\x9c'
+    157: 223,  # '\x9d'
+    158: 224,  # '\x9e'
+    159: 225,  # '\x9f'
+    160: 81,  # '\xa0'
+    161: 226,  # 'Ё'
+    162: 227,  # 'Ђ'
+    163: 228,  # 'Ѓ'
+    164: 229,  # 'Є'
+    165: 230,  # 'Ѕ'
+    166: 105,  # 'І'
+    167: 231,  # 'Ї'
+    168: 232,  # 'Ј'
+    169: 233,  # 'Љ'
+    170: 234,  # 'Њ'
+    171: 235,  # 'Ћ'
+    172: 236,  # 'Ќ'
+    173: 45,  # '\xad'
+    174: 237,  # 'Ў'
+    175: 238,  # 'Џ'
+    176: 31,  # 'А'
+    177: 32,  # 'Б'
+    178: 35,  # 'В'
+    179: 43,  # 'Г'
+    180: 37,  # 'Д'
+    181: 44,  # 'Е'
+    182: 55,  # 'Ж'
+    183: 47,  # 'З'
+    184: 40,  # 'И'
+    185: 59,  # 'Й'
+    186: 33,  # 'К'
+    187: 46,  # 'Л'
+    188: 38,  # 'М'
+    189: 36,  # 'Н'
+    190: 41,  # 'О'
+    191: 30,  # 'П'
+    192: 39,  # 'Р'
+    193: 28,  # 'С'
+    194: 34,  # 'Т'
+    195: 51,  # 'У'
+    196: 48,  # 'Ф'
+    197: 49,  # 'Х'
+    198: 53,  # 'Ц'
+    199: 50,  # 'Ч'
+    200: 54,  # 'Ш'
+    201: 57,  # 'Щ'
+    202: 61,  # 'Ъ'
+    203: 239,  # 'Ы'
+    204: 67,  # 'Ь'
+    205: 240,  # 'Э'
+    206: 60,  # 'Ю'
+    207: 56,  # 'Я'
+    208: 1,  # 'а'
+    209: 18,  # 'б'
+    210: 9,  # 'в'
+    211: 20,  # 'г'
+    212: 11,  # 'д'
+    213: 3,  # 'е'
+    214: 23,  # 'ж'
+    215: 15,  # 'з'
+    216: 2,  # 'и'
+    217: 26,  # 'й'
+    218: 12,  # 'к'
+    219: 10,  # 'л'
+    220: 14,  # 'м'
+    221: 6,  # 'н'
+    222: 4,  # 'о'
+    223: 13,  # 'п'
+    224: 7,  # 'р'
+    225: 8,  # 'с'
+    226: 5,  # 'т'
+    227: 19,  # 'у'
+    228: 29,  # 'ф'
+    229: 25,  # 'х'
+    230: 22,  # 'ц'
+    231: 21,  # 'ч'
+    232: 27,  # 'ш'
+    233: 24,  # 'щ'
+    234: 17,  # 'ъ'
+    235: 75,  # 'ы'
+    236: 52,  # 'ь'
+    237: 241,  # 'э'
+    238: 42,  # 'ю'
+    239: 16,  # 'я'
+    240: 62,  # '№'
+    241: 242,  # 'ё'
+    242: 243,  # 'ђ'
+    243: 244,  # 'ѓ'
+    244: 58,  # 'є'
+    245: 245,  # 'ѕ'
+    246: 98,  # 'і'
+    247: 246,  # 'ї'
+    248: 247,  # 'ј'
+    249: 248,  # 'љ'
+    250: 249,  # 'њ'
+    251: 250,  # 'ћ'
+    252: 251,  # 'ќ'
+    253: 91,  # '§'
+    254: 252,  # 'ў'
+    255: 253,  # 'џ'
 }
 
-ISO_8859_5_BULGARIAN_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-5',
-                                                    language='Bulgarian',
-                                                    char_to_order_map=ISO_8859_5_BULGARIAN_CHAR_TO_ORDER,
-                                                    language_model=BULGARIAN_LANG_MODEL,
-                                                    typical_positive_ratio=0.969392,
-                                                    keep_ascii_letters=False,
-                                                    alphabet='АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя')
+ISO_8859_5_BULGARIAN_MODEL = SingleByteCharSetModel(
+    charset_name="ISO-8859-5",
+    language="Bulgarian",
+    char_to_order_map=ISO_8859_5_BULGARIAN_CHAR_TO_ORDER,
+    language_model=BULGARIAN_LANG_MODEL,
+    typical_positive_ratio=0.969392,
+    keep_ascii_letters=False,
+    alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя",
+)
 
 WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 77,  # 'A'
-     66: 90,  # 'B'
-     67: 99,  # 'C'
-     68: 100,  # 'D'
-     69: 72,  # 'E'
-     70: 109,  # 'F'
-     71: 107,  # 'G'
-     72: 101,  # 'H'
-     73: 79,  # 'I'
-     74: 185,  # 'J'
-     75: 81,  # 'K'
-     76: 102,  # 'L'
-     77: 76,  # 'M'
-     78: 94,  # 'N'
-     79: 82,  # 'O'
-     80: 110,  # 'P'
-     81: 186,  # 'Q'
-     82: 108,  # 'R'
-     83: 91,  # 'S'
-     84: 74,  # 'T'
-     85: 119,  # 'U'
-     86: 84,  # 'V'
-     87: 96,  # 'W'
-     88: 111,  # 'X'
-     89: 187,  # 'Y'
-     90: 115,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 65,  # 'a'
-     98: 69,  # 'b'
-     99: 70,  # 'c'
-     100: 66,  # 'd'
-     101: 63,  # 'e'
-     102: 68,  # 'f'
-     103: 112,  # 'g'
-     104: 103,  # 'h'
-     105: 92,  # 'i'
-     106: 194,  # 'j'
-     107: 104,  # 'k'
-     108: 95,  # 'l'
-     109: 86,  # 'm'
-     110: 87,  # 'n'
-     111: 71,  # 'o'
-     112: 116,  # 'p'
-     113: 195,  # 'q'
-     114: 85,  # 'r'
-     115: 93,  # 's'
-     116: 97,  # 't'
-     117: 113,  # 'u'
-     118: 196,  # 'v'
-     119: 197,  # 'w'
-     120: 198,  # 'x'
-     121: 199,  # 'y'
-     122: 200,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 206,  # 'Ђ'
-     129: 207,  # 'Ѓ'
-     130: 208,  # '‚'
-     131: 209,  # 'ѓ'
-     132: 210,  # '„'
-     133: 211,  # '…'
-     134: 212,  # '†'
-     135: 213,  # '‡'
-     136: 120,  # '€'
-     137: 214,  # '‰'
-     138: 215,  # 'Љ'
-     139: 216,  # '‹'
-     140: 217,  # 'Њ'
-     141: 218,  # 'Ќ'
-     142: 219,  # 'Ћ'
-     143: 220,  # 'Џ'
-     144: 221,  # 'ђ'
-     145: 78,  # '‘'
-     146: 64,  # '’'
-     147: 83,  # '“'
-     148: 121,  # '”'
-     149: 98,  # '•'
-     150: 117,  # '–'
-     151: 105,  # '—'
-     152: 222,  # None
-     153: 223,  # '™'
-     154: 224,  # 'љ'
-     155: 225,  # '›'
-     156: 226,  # 'њ'
-     157: 227,  # 'ќ'
-     158: 228,  # 'ћ'
-     159: 229,  # 'џ'
-     160: 88,  # '\xa0'
-     161: 230,  # 'Ў'
-     162: 231,  # 'ў'
-     163: 232,  # 'Ј'
-     164: 233,  # '¤'
-     165: 122,  # 'Ґ'
-     166: 89,  # '¦'
-     167: 106,  # '§'
-     168: 234,  # 'Ё'
-     169: 235,  # '©'
-     170: 236,  # 'Є'
-     171: 237,  # '«'
-     172: 238,  # '¬'
-     173: 45,  # '\xad'
-     174: 239,  # '®'
-     175: 240,  # 'Ї'
-     176: 73,  # '°'
-     177: 80,  # '±'
-     178: 118,  # 'І'
-     179: 114,  # 'і'
-     180: 241,  # 'ґ'
-     181: 242,  # 'µ'
-     182: 243,  # '¶'
-     183: 244,  # '·'
-     184: 245,  # 'ё'
-     185: 62,  # '№'
-     186: 58,  # 'є'
-     187: 246,  # '»'
-     188: 247,  # 'ј'
-     189: 248,  # 'Ѕ'
-     190: 249,  # 'ѕ'
-     191: 250,  # 'ї'
-     192: 31,  # 'А'
-     193: 32,  # 'Б'
-     194: 35,  # 'В'
-     195: 43,  # 'Г'
-     196: 37,  # 'Д'
-     197: 44,  # 'Е'
-     198: 55,  # 'Ж'
-     199: 47,  # 'З'
-     200: 40,  # 'И'
-     201: 59,  # 'Й'
-     202: 33,  # 'К'
-     203: 46,  # 'Л'
-     204: 38,  # 'М'
-     205: 36,  # 'Н'
-     206: 41,  # 'О'
-     207: 30,  # 'П'
-     208: 39,  # 'Р'
-     209: 28,  # 'С'
-     210: 34,  # 'Т'
-     211: 51,  # 'У'
-     212: 48,  # 'Ф'
-     213: 49,  # 'Х'
-     214: 53,  # 'Ц'
-     215: 50,  # 'Ч'
-     216: 54,  # 'Ш'
-     217: 57,  # 'Щ'
-     218: 61,  # 'Ъ'
-     219: 251,  # 'Ы'
-     220: 67,  # 'Ь'
-     221: 252,  # 'Э'
-     222: 60,  # 'Ю'
-     223: 56,  # 'Я'
-     224: 1,  # 'а'
-     225: 18,  # 'б'
-     226: 9,  # 'в'
-     227: 20,  # 'г'
-     228: 11,  # 'д'
-     229: 3,  # 'е'
-     230: 23,  # 'ж'
-     231: 15,  # 'з'
-     232: 2,  # 'и'
-     233: 26,  # 'й'
-     234: 12,  # 'к'
-     235: 10,  # 'л'
-     236: 14,  # 'м'
-     237: 6,  # 'н'
-     238: 4,  # 'о'
-     239: 13,  # 'п'
-     240: 7,  # 'р'
-     241: 8,  # 'с'
-     242: 5,  # 'т'
-     243: 19,  # 'у'
-     244: 29,  # 'ф'
-     245: 25,  # 'х'
-     246: 22,  # 'ц'
-     247: 21,  # 'ч'
-     248: 27,  # 'ш'
-     249: 24,  # 'щ'
-     250: 17,  # 'ъ'
-     251: 75,  # 'ы'
-     252: 52,  # 'ь'
-     253: 253,  # 'э'
-     254: 42,  # 'ю'
-     255: 16,  # 'я'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 77,  # 'A'
+    66: 90,  # 'B'
+    67: 99,  # 'C'
+    68: 100,  # 'D'
+    69: 72,  # 'E'
+    70: 109,  # 'F'
+    71: 107,  # 'G'
+    72: 101,  # 'H'
+    73: 79,  # 'I'
+    74: 185,  # 'J'
+    75: 81,  # 'K'
+    76: 102,  # 'L'
+    77: 76,  # 'M'
+    78: 94,  # 'N'
+    79: 82,  # 'O'
+    80: 110,  # 'P'
+    81: 186,  # 'Q'
+    82: 108,  # 'R'
+    83: 91,  # 'S'
+    84: 74,  # 'T'
+    85: 119,  # 'U'
+    86: 84,  # 'V'
+    87: 96,  # 'W'
+    88: 111,  # 'X'
+    89: 187,  # 'Y'
+    90: 115,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 65,  # 'a'
+    98: 69,  # 'b'
+    99: 70,  # 'c'
+    100: 66,  # 'd'
+    101: 63,  # 'e'
+    102: 68,  # 'f'
+    103: 112,  # 'g'
+    104: 103,  # 'h'
+    105: 92,  # 'i'
+    106: 194,  # 'j'
+    107: 104,  # 'k'
+    108: 95,  # 'l'
+    109: 86,  # 'm'
+    110: 87,  # 'n'
+    111: 71,  # 'o'
+    112: 116,  # 'p'
+    113: 195,  # 'q'
+    114: 85,  # 'r'
+    115: 93,  # 's'
+    116: 97,  # 't'
+    117: 113,  # 'u'
+    118: 196,  # 'v'
+    119: 197,  # 'w'
+    120: 198,  # 'x'
+    121: 199,  # 'y'
+    122: 200,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 206,  # 'Ђ'
+    129: 207,  # 'Ѓ'
+    130: 208,  # '‚'
+    131: 209,  # 'ѓ'
+    132: 210,  # '„'
+    133: 211,  # '…'
+    134: 212,  # '†'
+    135: 213,  # '‡'
+    136: 120,  # '€'
+    137: 214,  # '‰'
+    138: 215,  # 'Љ'
+    139: 216,  # '‹'
+    140: 217,  # 'Њ'
+    141: 218,  # 'Ќ'
+    142: 219,  # 'Ћ'
+    143: 220,  # 'Џ'
+    144: 221,  # 'ђ'
+    145: 78,  # '‘'
+    146: 64,  # '’'
+    147: 83,  # '“'
+    148: 121,  # '”'
+    149: 98,  # '•'
+    150: 117,  # '–'
+    151: 105,  # '—'
+    152: 222,  # None
+    153: 223,  # '™'
+    154: 224,  # 'љ'
+    155: 225,  # '›'
+    156: 226,  # 'њ'
+    157: 227,  # 'ќ'
+    158: 228,  # 'ћ'
+    159: 229,  # 'џ'
+    160: 88,  # '\xa0'
+    161: 230,  # 'Ў'
+    162: 231,  # 'ў'
+    163: 232,  # 'Ј'
+    164: 233,  # '¤'
+    165: 122,  # 'Ґ'
+    166: 89,  # '¦'
+    167: 106,  # '§'
+    168: 234,  # 'Ё'
+    169: 235,  # '©'
+    170: 236,  # 'Є'
+    171: 237,  # '«'
+    172: 238,  # '¬'
+    173: 45,  # '\xad'
+    174: 239,  # '®'
+    175: 240,  # 'Ї'
+    176: 73,  # '°'
+    177: 80,  # '±'
+    178: 118,  # 'І'
+    179: 114,  # 'і'
+    180: 241,  # 'ґ'
+    181: 242,  # 'µ'
+    182: 243,  # '¶'
+    183: 244,  # '·'
+    184: 245,  # 'ё'
+    185: 62,  # '№'
+    186: 58,  # 'є'
+    187: 246,  # '»'
+    188: 247,  # 'ј'
+    189: 248,  # 'Ѕ'
+    190: 249,  # 'ѕ'
+    191: 250,  # 'ї'
+    192: 31,  # 'А'
+    193: 32,  # 'Б'
+    194: 35,  # 'В'
+    195: 43,  # 'Г'
+    196: 37,  # 'Д'
+    197: 44,  # 'Е'
+    198: 55,  # 'Ж'
+    199: 47,  # 'З'
+    200: 40,  # 'И'
+    201: 59,  # 'Й'
+    202: 33,  # 'К'
+    203: 46,  # 'Л'
+    204: 38,  # 'М'
+    205: 36,  # 'Н'
+    206: 41,  # 'О'
+    207: 30,  # 'П'
+    208: 39,  # 'Р'
+    209: 28,  # 'С'
+    210: 34,  # 'Т'
+    211: 51,  # 'У'
+    212: 48,  # 'Ф'
+    213: 49,  # 'Х'
+    214: 53,  # 'Ц'
+    215: 50,  # 'Ч'
+    216: 54,  # 'Ш'
+    217: 57,  # 'Щ'
+    218: 61,  # 'Ъ'
+    219: 251,  # 'Ы'
+    220: 67,  # 'Ь'
+    221: 252,  # 'Э'
+    222: 60,  # 'Ю'
+    223: 56,  # 'Я'
+    224: 1,  # 'а'
+    225: 18,  # 'б'
+    226: 9,  # 'в'
+    227: 20,  # 'г'
+    228: 11,  # 'д'
+    229: 3,  # 'е'
+    230: 23,  # 'ж'
+    231: 15,  # 'з'
+    232: 2,  # 'и'
+    233: 26,  # 'й'
+    234: 12,  # 'к'
+    235: 10,  # 'л'
+    236: 14,  # 'м'
+    237: 6,  # 'н'
+    238: 4,  # 'о'
+    239: 13,  # 'п'
+    240: 7,  # 'р'
+    241: 8,  # 'с'
+    242: 5,  # 'т'
+    243: 19,  # 'у'
+    244: 29,  # 'ф'
+    245: 25,  # 'х'
+    246: 22,  # 'ц'
+    247: 21,  # 'ч'
+    248: 27,  # 'ш'
+    249: 24,  # 'щ'
+    250: 17,  # 'ъ'
+    251: 75,  # 'ы'
+    252: 52,  # 'ь'
+    253: 253,  # 'э'
+    254: 42,  # 'ю'
+    255: 16,  # 'я'
 }
 
-WINDOWS_1251_BULGARIAN_MODEL = SingleByteCharSetModel(charset_name='windows-1251',
-                                                      language='Bulgarian',
-                                                      char_to_order_map=WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER,
-                                                      language_model=BULGARIAN_LANG_MODEL,
-                                                      typical_positive_ratio=0.969392,
-                                                      keep_ascii_letters=False,
-                                                      alphabet='АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя')
-
+WINDOWS_1251_BULGARIAN_MODEL = SingleByteCharSetModel(
+    charset_name="windows-1251",
+    language="Bulgarian",
+    char_to_order_map=WINDOWS_1251_BULGARIAN_CHAR_TO_ORDER,
+    language_model=BULGARIAN_LANG_MODEL,
+    typical_positive_ratio=0.969392,
+    keep_ascii_letters=False,
+    alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py
index d99528ed..cfb8639e 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langgreekmodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -3863,536 +3859,539 @@ GREEK_LANG_MODEL = {
 
 # Character Mapping Table(s):
 WINDOWS_1253_GREEK_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 82,  # 'A'
-     66: 100,  # 'B'
-     67: 104,  # 'C'
-     68: 94,  # 'D'
-     69: 98,  # 'E'
-     70: 101,  # 'F'
-     71: 116,  # 'G'
-     72: 102,  # 'H'
-     73: 111,  # 'I'
-     74: 187,  # 'J'
-     75: 117,  # 'K'
-     76: 92,  # 'L'
-     77: 88,  # 'M'
-     78: 113,  # 'N'
-     79: 85,  # 'O'
-     80: 79,  # 'P'
-     81: 118,  # 'Q'
-     82: 105,  # 'R'
-     83: 83,  # 'S'
-     84: 67,  # 'T'
-     85: 114,  # 'U'
-     86: 119,  # 'V'
-     87: 95,  # 'W'
-     88: 99,  # 'X'
-     89: 109,  # 'Y'
-     90: 188,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 72,  # 'a'
-     98: 70,  # 'b'
-     99: 80,  # 'c'
-     100: 81,  # 'd'
-     101: 60,  # 'e'
-     102: 96,  # 'f'
-     103: 93,  # 'g'
-     104: 89,  # 'h'
-     105: 68,  # 'i'
-     106: 120,  # 'j'
-     107: 97,  # 'k'
-     108: 77,  # 'l'
-     109: 86,  # 'm'
-     110: 69,  # 'n'
-     111: 55,  # 'o'
-     112: 78,  # 'p'
-     113: 115,  # 'q'
-     114: 65,  # 'r'
-     115: 66,  # 's'
-     116: 58,  # 't'
-     117: 76,  # 'u'
-     118: 106,  # 'v'
-     119: 103,  # 'w'
-     120: 87,  # 'x'
-     121: 107,  # 'y'
-     122: 112,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 255,  # '€'
-     129: 255,  # None
-     130: 255,  # '‚'
-     131: 255,  # 'ƒ'
-     132: 255,  # '„'
-     133: 255,  # '…'
-     134: 255,  # '†'
-     135: 255,  # '‡'
-     136: 255,  # None
-     137: 255,  # '‰'
-     138: 255,  # None
-     139: 255,  # '‹'
-     140: 255,  # None
-     141: 255,  # None
-     142: 255,  # None
-     143: 255,  # None
-     144: 255,  # None
-     145: 255,  # '‘'
-     146: 255,  # '’'
-     147: 255,  # '“'
-     148: 255,  # '”'
-     149: 255,  # '•'
-     150: 255,  # '–'
-     151: 255,  # '—'
-     152: 255,  # None
-     153: 255,  # '™'
-     154: 255,  # None
-     155: 255,  # '›'
-     156: 255,  # None
-     157: 255,  # None
-     158: 255,  # None
-     159: 255,  # None
-     160: 253,  # '\xa0'
-     161: 233,  # '΅'
-     162: 61,  # 'Ά'
-     163: 253,  # '£'
-     164: 253,  # '¤'
-     165: 253,  # '¥'
-     166: 253,  # '¦'
-     167: 253,  # '§'
-     168: 253,  # '¨'
-     169: 253,  # '©'
-     170: 253,  # None
-     171: 253,  # '«'
-     172: 253,  # '¬'
-     173: 74,  # '\xad'
-     174: 253,  # '®'
-     175: 253,  # '―'
-     176: 253,  # '°'
-     177: 253,  # '±'
-     178: 253,  # '²'
-     179: 253,  # '³'
-     180: 247,  # '΄'
-     181: 253,  # 'µ'
-     182: 253,  # '¶'
-     183: 36,  # '·'
-     184: 46,  # 'Έ'
-     185: 71,  # 'Ή'
-     186: 73,  # 'Ί'
-     187: 253,  # '»'
-     188: 54,  # 'Ό'
-     189: 253,  # '½'
-     190: 108,  # 'Ύ'
-     191: 123,  # 'Ώ'
-     192: 110,  # 'ΐ'
-     193: 31,  # 'Α'
-     194: 51,  # 'Β'
-     195: 43,  # 'Γ'
-     196: 41,  # 'Δ'
-     197: 34,  # 'Ε'
-     198: 91,  # 'Ζ'
-     199: 40,  # 'Η'
-     200: 52,  # 'Θ'
-     201: 47,  # 'Ι'
-     202: 44,  # 'Κ'
-     203: 53,  # 'Λ'
-     204: 38,  # 'Μ'
-     205: 49,  # 'Ν'
-     206: 59,  # 'Ξ'
-     207: 39,  # 'Ο'
-     208: 35,  # 'Π'
-     209: 48,  # 'Ρ'
-     210: 250,  # None
-     211: 37,  # 'Σ'
-     212: 33,  # 'Τ'
-     213: 45,  # 'Υ'
-     214: 56,  # 'Φ'
-     215: 50,  # 'Χ'
-     216: 84,  # 'Ψ'
-     217: 57,  # 'Ω'
-     218: 120,  # 'Ϊ'
-     219: 121,  # 'Ϋ'
-     220: 17,  # 'ά'
-     221: 18,  # 'έ'
-     222: 22,  # 'ή'
-     223: 15,  # 'ί'
-     224: 124,  # 'ΰ'
-     225: 1,  # 'α'
-     226: 29,  # 'β'
-     227: 20,  # 'γ'
-     228: 21,  # 'δ'
-     229: 3,  # 'ε'
-     230: 32,  # 'ζ'
-     231: 13,  # 'η'
-     232: 25,  # 'θ'
-     233: 5,  # 'ι'
-     234: 11,  # 'κ'
-     235: 16,  # 'λ'
-     236: 10,  # 'μ'
-     237: 6,  # 'ν'
-     238: 30,  # 'ξ'
-     239: 4,  # 'ο'
-     240: 9,  # 'π'
-     241: 8,  # 'ρ'
-     242: 14,  # 'ς'
-     243: 7,  # 'σ'
-     244: 2,  # 'τ'
-     245: 12,  # 'υ'
-     246: 28,  # 'φ'
-     247: 23,  # 'χ'
-     248: 42,  # 'ψ'
-     249: 24,  # 'ω'
-     250: 64,  # 'ϊ'
-     251: 75,  # 'ϋ'
-     252: 19,  # 'ό'
-     253: 26,  # 'ύ'
-     254: 27,  # 'ώ'
-     255: 253,  # None
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 82,  # 'A'
+    66: 100,  # 'B'
+    67: 104,  # 'C'
+    68: 94,  # 'D'
+    69: 98,  # 'E'
+    70: 101,  # 'F'
+    71: 116,  # 'G'
+    72: 102,  # 'H'
+    73: 111,  # 'I'
+    74: 187,  # 'J'
+    75: 117,  # 'K'
+    76: 92,  # 'L'
+    77: 88,  # 'M'
+    78: 113,  # 'N'
+    79: 85,  # 'O'
+    80: 79,  # 'P'
+    81: 118,  # 'Q'
+    82: 105,  # 'R'
+    83: 83,  # 'S'
+    84: 67,  # 'T'
+    85: 114,  # 'U'
+    86: 119,  # 'V'
+    87: 95,  # 'W'
+    88: 99,  # 'X'
+    89: 109,  # 'Y'
+    90: 188,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 72,  # 'a'
+    98: 70,  # 'b'
+    99: 80,  # 'c'
+    100: 81,  # 'd'
+    101: 60,  # 'e'
+    102: 96,  # 'f'
+    103: 93,  # 'g'
+    104: 89,  # 'h'
+    105: 68,  # 'i'
+    106: 120,  # 'j'
+    107: 97,  # 'k'
+    108: 77,  # 'l'
+    109: 86,  # 'm'
+    110: 69,  # 'n'
+    111: 55,  # 'o'
+    112: 78,  # 'p'
+    113: 115,  # 'q'
+    114: 65,  # 'r'
+    115: 66,  # 's'
+    116: 58,  # 't'
+    117: 76,  # 'u'
+    118: 106,  # 'v'
+    119: 103,  # 'w'
+    120: 87,  # 'x'
+    121: 107,  # 'y'
+    122: 112,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 255,  # '€'
+    129: 255,  # None
+    130: 255,  # '‚'
+    131: 255,  # 'ƒ'
+    132: 255,  # '„'
+    133: 255,  # '…'
+    134: 255,  # '†'
+    135: 255,  # '‡'
+    136: 255,  # None
+    137: 255,  # '‰'
+    138: 255,  # None
+    139: 255,  # '‹'
+    140: 255,  # None
+    141: 255,  # None
+    142: 255,  # None
+    143: 255,  # None
+    144: 255,  # None
+    145: 255,  # '‘'
+    146: 255,  # '’'
+    147: 255,  # '“'
+    148: 255,  # '”'
+    149: 255,  # '•'
+    150: 255,  # '–'
+    151: 255,  # '—'
+    152: 255,  # None
+    153: 255,  # '™'
+    154: 255,  # None
+    155: 255,  # '›'
+    156: 255,  # None
+    157: 255,  # None
+    158: 255,  # None
+    159: 255,  # None
+    160: 253,  # '\xa0'
+    161: 233,  # '΅'
+    162: 61,  # 'Ά'
+    163: 253,  # '£'
+    164: 253,  # '¤'
+    165: 253,  # '¥'
+    166: 253,  # '¦'
+    167: 253,  # '§'
+    168: 253,  # '¨'
+    169: 253,  # '©'
+    170: 253,  # None
+    171: 253,  # '«'
+    172: 253,  # '¬'
+    173: 74,  # '\xad'
+    174: 253,  # '®'
+    175: 253,  # '―'
+    176: 253,  # '°'
+    177: 253,  # '±'
+    178: 253,  # '²'
+    179: 253,  # '³'
+    180: 247,  # '΄'
+    181: 253,  # 'µ'
+    182: 253,  # '¶'
+    183: 36,  # '·'
+    184: 46,  # 'Έ'
+    185: 71,  # 'Ή'
+    186: 73,  # 'Ί'
+    187: 253,  # '»'
+    188: 54,  # 'Ό'
+    189: 253,  # '½'
+    190: 108,  # 'Ύ'
+    191: 123,  # 'Ώ'
+    192: 110,  # 'ΐ'
+    193: 31,  # 'Α'
+    194: 51,  # 'Β'
+    195: 43,  # 'Γ'
+    196: 41,  # 'Δ'
+    197: 34,  # 'Ε'
+    198: 91,  # 'Ζ'
+    199: 40,  # 'Η'
+    200: 52,  # 'Θ'
+    201: 47,  # 'Ι'
+    202: 44,  # 'Κ'
+    203: 53,  # 'Λ'
+    204: 38,  # 'Μ'
+    205: 49,  # 'Ν'
+    206: 59,  # 'Ξ'
+    207: 39,  # 'Ο'
+    208: 35,  # 'Π'
+    209: 48,  # 'Ρ'
+    210: 250,  # None
+    211: 37,  # 'Σ'
+    212: 33,  # 'Τ'
+    213: 45,  # 'Υ'
+    214: 56,  # 'Φ'
+    215: 50,  # 'Χ'
+    216: 84,  # 'Ψ'
+    217: 57,  # 'Ω'
+    218: 120,  # 'Ϊ'
+    219: 121,  # 'Ϋ'
+    220: 17,  # 'ά'
+    221: 18,  # 'έ'
+    222: 22,  # 'ή'
+    223: 15,  # 'ί'
+    224: 124,  # 'ΰ'
+    225: 1,  # 'α'
+    226: 29,  # 'β'
+    227: 20,  # 'γ'
+    228: 21,  # 'δ'
+    229: 3,  # 'ε'
+    230: 32,  # 'ζ'
+    231: 13,  # 'η'
+    232: 25,  # 'θ'
+    233: 5,  # 'ι'
+    234: 11,  # 'κ'
+    235: 16,  # 'λ'
+    236: 10,  # 'μ'
+    237: 6,  # 'ν'
+    238: 30,  # 'ξ'
+    239: 4,  # 'ο'
+    240: 9,  # 'π'
+    241: 8,  # 'ρ'
+    242: 14,  # 'ς'
+    243: 7,  # 'σ'
+    244: 2,  # 'τ'
+    245: 12,  # 'υ'
+    246: 28,  # 'φ'
+    247: 23,  # 'χ'
+    248: 42,  # 'ψ'
+    249: 24,  # 'ω'
+    250: 64,  # 'ϊ'
+    251: 75,  # 'ϋ'
+    252: 19,  # 'ό'
+    253: 26,  # 'ύ'
+    254: 27,  # 'ώ'
+    255: 253,  # None
 }
 
-WINDOWS_1253_GREEK_MODEL = SingleByteCharSetModel(charset_name='windows-1253',
-                                                  language='Greek',
-                                                  char_to_order_map=WINDOWS_1253_GREEK_CHAR_TO_ORDER,
-                                                  language_model=GREEK_LANG_MODEL,
-                                                  typical_positive_ratio=0.982851,
-                                                  keep_ascii_letters=False,
-                                                  alphabet='ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ')
+WINDOWS_1253_GREEK_MODEL = SingleByteCharSetModel(
+    charset_name="windows-1253",
+    language="Greek",
+    char_to_order_map=WINDOWS_1253_GREEK_CHAR_TO_ORDER,
+    language_model=GREEK_LANG_MODEL,
+    typical_positive_ratio=0.982851,
+    keep_ascii_letters=False,
+    alphabet="ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ",
+)
 
 ISO_8859_7_GREEK_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 82,  # 'A'
-     66: 100,  # 'B'
-     67: 104,  # 'C'
-     68: 94,  # 'D'
-     69: 98,  # 'E'
-     70: 101,  # 'F'
-     71: 116,  # 'G'
-     72: 102,  # 'H'
-     73: 111,  # 'I'
-     74: 187,  # 'J'
-     75: 117,  # 'K'
-     76: 92,  # 'L'
-     77: 88,  # 'M'
-     78: 113,  # 'N'
-     79: 85,  # 'O'
-     80: 79,  # 'P'
-     81: 118,  # 'Q'
-     82: 105,  # 'R'
-     83: 83,  # 'S'
-     84: 67,  # 'T'
-     85: 114,  # 'U'
-     86: 119,  # 'V'
-     87: 95,  # 'W'
-     88: 99,  # 'X'
-     89: 109,  # 'Y'
-     90: 188,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 72,  # 'a'
-     98: 70,  # 'b'
-     99: 80,  # 'c'
-     100: 81,  # 'd'
-     101: 60,  # 'e'
-     102: 96,  # 'f'
-     103: 93,  # 'g'
-     104: 89,  # 'h'
-     105: 68,  # 'i'
-     106: 120,  # 'j'
-     107: 97,  # 'k'
-     108: 77,  # 'l'
-     109: 86,  # 'm'
-     110: 69,  # 'n'
-     111: 55,  # 'o'
-     112: 78,  # 'p'
-     113: 115,  # 'q'
-     114: 65,  # 'r'
-     115: 66,  # 's'
-     116: 58,  # 't'
-     117: 76,  # 'u'
-     118: 106,  # 'v'
-     119: 103,  # 'w'
-     120: 87,  # 'x'
-     121: 107,  # 'y'
-     122: 112,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 255,  # '\x80'
-     129: 255,  # '\x81'
-     130: 255,  # '\x82'
-     131: 255,  # '\x83'
-     132: 255,  # '\x84'
-     133: 255,  # '\x85'
-     134: 255,  # '\x86'
-     135: 255,  # '\x87'
-     136: 255,  # '\x88'
-     137: 255,  # '\x89'
-     138: 255,  # '\x8a'
-     139: 255,  # '\x8b'
-     140: 255,  # '\x8c'
-     141: 255,  # '\x8d'
-     142: 255,  # '\x8e'
-     143: 255,  # '\x8f'
-     144: 255,  # '\x90'
-     145: 255,  # '\x91'
-     146: 255,  # '\x92'
-     147: 255,  # '\x93'
-     148: 255,  # '\x94'
-     149: 255,  # '\x95'
-     150: 255,  # '\x96'
-     151: 255,  # '\x97'
-     152: 255,  # '\x98'
-     153: 255,  # '\x99'
-     154: 255,  # '\x9a'
-     155: 255,  # '\x9b'
-     156: 255,  # '\x9c'
-     157: 255,  # '\x9d'
-     158: 255,  # '\x9e'
-     159: 255,  # '\x9f'
-     160: 253,  # '\xa0'
-     161: 233,  # '‘'
-     162: 90,  # '’'
-     163: 253,  # '£'
-     164: 253,  # '€'
-     165: 253,  # '₯'
-     166: 253,  # '¦'
-     167: 253,  # '§'
-     168: 253,  # '¨'
-     169: 253,  # '©'
-     170: 253,  # 'ͺ'
-     171: 253,  # '«'
-     172: 253,  # '¬'
-     173: 74,  # '\xad'
-     174: 253,  # None
-     175: 253,  # '―'
-     176: 253,  # '°'
-     177: 253,  # '±'
-     178: 253,  # '²'
-     179: 253,  # '³'
-     180: 247,  # '΄'
-     181: 248,  # '΅'
-     182: 61,  # 'Ά'
-     183: 36,  # '·'
-     184: 46,  # 'Έ'
-     185: 71,  # 'Ή'
-     186: 73,  # 'Ί'
-     187: 253,  # '»'
-     188: 54,  # 'Ό'
-     189: 253,  # '½'
-     190: 108,  # 'Ύ'
-     191: 123,  # 'Ώ'
-     192: 110,  # 'ΐ'
-     193: 31,  # 'Α'
-     194: 51,  # 'Β'
-     195: 43,  # 'Γ'
-     196: 41,  # 'Δ'
-     197: 34,  # 'Ε'
-     198: 91,  # 'Ζ'
-     199: 40,  # 'Η'
-     200: 52,  # 'Θ'
-     201: 47,  # 'Ι'
-     202: 44,  # 'Κ'
-     203: 53,  # 'Λ'
-     204: 38,  # 'Μ'
-     205: 49,  # 'Ν'
-     206: 59,  # 'Ξ'
-     207: 39,  # 'Ο'
-     208: 35,  # 'Π'
-     209: 48,  # 'Ρ'
-     210: 250,  # None
-     211: 37,  # 'Σ'
-     212: 33,  # 'Τ'
-     213: 45,  # 'Υ'
-     214: 56,  # 'Φ'
-     215: 50,  # 'Χ'
-     216: 84,  # 'Ψ'
-     217: 57,  # 'Ω'
-     218: 120,  # 'Ϊ'
-     219: 121,  # 'Ϋ'
-     220: 17,  # 'ά'
-     221: 18,  # 'έ'
-     222: 22,  # 'ή'
-     223: 15,  # 'ί'
-     224: 124,  # 'ΰ'
-     225: 1,  # 'α'
-     226: 29,  # 'β'
-     227: 20,  # 'γ'
-     228: 21,  # 'δ'
-     229: 3,  # 'ε'
-     230: 32,  # 'ζ'
-     231: 13,  # 'η'
-     232: 25,  # 'θ'
-     233: 5,  # 'ι'
-     234: 11,  # 'κ'
-     235: 16,  # 'λ'
-     236: 10,  # 'μ'
-     237: 6,  # 'ν'
-     238: 30,  # 'ξ'
-     239: 4,  # 'ο'
-     240: 9,  # 'π'
-     241: 8,  # 'ρ'
-     242: 14,  # 'ς'
-     243: 7,  # 'σ'
-     244: 2,  # 'τ'
-     245: 12,  # 'υ'
-     246: 28,  # 'φ'
-     247: 23,  # 'χ'
-     248: 42,  # 'ψ'
-     249: 24,  # 'ω'
-     250: 64,  # 'ϊ'
-     251: 75,  # 'ϋ'
-     252: 19,  # 'ό'
-     253: 26,  # 'ύ'
-     254: 27,  # 'ώ'
-     255: 253,  # None
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 82,  # 'A'
+    66: 100,  # 'B'
+    67: 104,  # 'C'
+    68: 94,  # 'D'
+    69: 98,  # 'E'
+    70: 101,  # 'F'
+    71: 116,  # 'G'
+    72: 102,  # 'H'
+    73: 111,  # 'I'
+    74: 187,  # 'J'
+    75: 117,  # 'K'
+    76: 92,  # 'L'
+    77: 88,  # 'M'
+    78: 113,  # 'N'
+    79: 85,  # 'O'
+    80: 79,  # 'P'
+    81: 118,  # 'Q'
+    82: 105,  # 'R'
+    83: 83,  # 'S'
+    84: 67,  # 'T'
+    85: 114,  # 'U'
+    86: 119,  # 'V'
+    87: 95,  # 'W'
+    88: 99,  # 'X'
+    89: 109,  # 'Y'
+    90: 188,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 72,  # 'a'
+    98: 70,  # 'b'
+    99: 80,  # 'c'
+    100: 81,  # 'd'
+    101: 60,  # 'e'
+    102: 96,  # 'f'
+    103: 93,  # 'g'
+    104: 89,  # 'h'
+    105: 68,  # 'i'
+    106: 120,  # 'j'
+    107: 97,  # 'k'
+    108: 77,  # 'l'
+    109: 86,  # 'm'
+    110: 69,  # 'n'
+    111: 55,  # 'o'
+    112: 78,  # 'p'
+    113: 115,  # 'q'
+    114: 65,  # 'r'
+    115: 66,  # 's'
+    116: 58,  # 't'
+    117: 76,  # 'u'
+    118: 106,  # 'v'
+    119: 103,  # 'w'
+    120: 87,  # 'x'
+    121: 107,  # 'y'
+    122: 112,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 255,  # '\x80'
+    129: 255,  # '\x81'
+    130: 255,  # '\x82'
+    131: 255,  # '\x83'
+    132: 255,  # '\x84'
+    133: 255,  # '\x85'
+    134: 255,  # '\x86'
+    135: 255,  # '\x87'
+    136: 255,  # '\x88'
+    137: 255,  # '\x89'
+    138: 255,  # '\x8a'
+    139: 255,  # '\x8b'
+    140: 255,  # '\x8c'
+    141: 255,  # '\x8d'
+    142: 255,  # '\x8e'
+    143: 255,  # '\x8f'
+    144: 255,  # '\x90'
+    145: 255,  # '\x91'
+    146: 255,  # '\x92'
+    147: 255,  # '\x93'
+    148: 255,  # '\x94'
+    149: 255,  # '\x95'
+    150: 255,  # '\x96'
+    151: 255,  # '\x97'
+    152: 255,  # '\x98'
+    153: 255,  # '\x99'
+    154: 255,  # '\x9a'
+    155: 255,  # '\x9b'
+    156: 255,  # '\x9c'
+    157: 255,  # '\x9d'
+    158: 255,  # '\x9e'
+    159: 255,  # '\x9f'
+    160: 253,  # '\xa0'
+    161: 233,  # '‘'
+    162: 90,  # '’'
+    163: 253,  # '£'
+    164: 253,  # '€'
+    165: 253,  # '₯'
+    166: 253,  # '¦'
+    167: 253,  # '§'
+    168: 253,  # '¨'
+    169: 253,  # '©'
+    170: 253,  # 'ͺ'
+    171: 253,  # '«'
+    172: 253,  # '¬'
+    173: 74,  # '\xad'
+    174: 253,  # None
+    175: 253,  # '―'
+    176: 253,  # '°'
+    177: 253,  # '±'
+    178: 253,  # '²'
+    179: 253,  # '³'
+    180: 247,  # '΄'
+    181: 248,  # '΅'
+    182: 61,  # 'Ά'
+    183: 36,  # '·'
+    184: 46,  # 'Έ'
+    185: 71,  # 'Ή'
+    186: 73,  # 'Ί'
+    187: 253,  # '»'
+    188: 54,  # 'Ό'
+    189: 253,  # '½'
+    190: 108,  # 'Ύ'
+    191: 123,  # 'Ώ'
+    192: 110,  # 'ΐ'
+    193: 31,  # 'Α'
+    194: 51,  # 'Β'
+    195: 43,  # 'Γ'
+    196: 41,  # 'Δ'
+    197: 34,  # 'Ε'
+    198: 91,  # 'Ζ'
+    199: 40,  # 'Η'
+    200: 52,  # 'Θ'
+    201: 47,  # 'Ι'
+    202: 44,  # 'Κ'
+    203: 53,  # 'Λ'
+    204: 38,  # 'Μ'
+    205: 49,  # 'Ν'
+    206: 59,  # 'Ξ'
+    207: 39,  # 'Ο'
+    208: 35,  # 'Π'
+    209: 48,  # 'Ρ'
+    210: 250,  # None
+    211: 37,  # 'Σ'
+    212: 33,  # 'Τ'
+    213: 45,  # 'Υ'
+    214: 56,  # 'Φ'
+    215: 50,  # 'Χ'
+    216: 84,  # 'Ψ'
+    217: 57,  # 'Ω'
+    218: 120,  # 'Ϊ'
+    219: 121,  # 'Ϋ'
+    220: 17,  # 'ά'
+    221: 18,  # 'έ'
+    222: 22,  # 'ή'
+    223: 15,  # 'ί'
+    224: 124,  # 'ΰ'
+    225: 1,  # 'α'
+    226: 29,  # 'β'
+    227: 20,  # 'γ'
+    228: 21,  # 'δ'
+    229: 3,  # 'ε'
+    230: 32,  # 'ζ'
+    231: 13,  # 'η'
+    232: 25,  # 'θ'
+    233: 5,  # 'ι'
+    234: 11,  # 'κ'
+    235: 16,  # 'λ'
+    236: 10,  # 'μ'
+    237: 6,  # 'ν'
+    238: 30,  # 'ξ'
+    239: 4,  # 'ο'
+    240: 9,  # 'π'
+    241: 8,  # 'ρ'
+    242: 14,  # 'ς'
+    243: 7,  # 'σ'
+    244: 2,  # 'τ'
+    245: 12,  # 'υ'
+    246: 28,  # 'φ'
+    247: 23,  # 'χ'
+    248: 42,  # 'ψ'
+    249: 24,  # 'ω'
+    250: 64,  # 'ϊ'
+    251: 75,  # 'ϋ'
+    252: 19,  # 'ό'
+    253: 26,  # 'ύ'
+    254: 27,  # 'ώ'
+    255: 253,  # None
 }
 
-ISO_8859_7_GREEK_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-7',
-                                                language='Greek',
-                                                char_to_order_map=ISO_8859_7_GREEK_CHAR_TO_ORDER,
-                                                language_model=GREEK_LANG_MODEL,
-                                                typical_positive_ratio=0.982851,
-                                                keep_ascii_letters=False,
-                                                alphabet='ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ')
-
+ISO_8859_7_GREEK_MODEL = SingleByteCharSetModel(
+    charset_name="ISO-8859-7",
+    language="Greek",
+    char_to_order_map=ISO_8859_7_GREEK_CHAR_TO_ORDER,
+    language_model=GREEK_LANG_MODEL,
+    typical_positive_ratio=0.982851,
+    keep_ascii_letters=False,
+    alphabet="ΆΈΉΊΌΎΏΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩάέήίαβγδεζηθικλμνξοπρςστυφχψωόύώ",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py
index 484c652a..56d29758 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langhebrewmodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -4115,269 +4111,270 @@ HEBREW_LANG_MODEL = {
 
 # Character Mapping Table(s):
 WINDOWS_1255_HEBREW_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 69,  # 'A'
-     66: 91,  # 'B'
-     67: 79,  # 'C'
-     68: 80,  # 'D'
-     69: 92,  # 'E'
-     70: 89,  # 'F'
-     71: 97,  # 'G'
-     72: 90,  # 'H'
-     73: 68,  # 'I'
-     74: 111,  # 'J'
-     75: 112,  # 'K'
-     76: 82,  # 'L'
-     77: 73,  # 'M'
-     78: 95,  # 'N'
-     79: 85,  # 'O'
-     80: 78,  # 'P'
-     81: 121,  # 'Q'
-     82: 86,  # 'R'
-     83: 71,  # 'S'
-     84: 67,  # 'T'
-     85: 102,  # 'U'
-     86: 107,  # 'V'
-     87: 84,  # 'W'
-     88: 114,  # 'X'
-     89: 103,  # 'Y'
-     90: 115,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 50,  # 'a'
-     98: 74,  # 'b'
-     99: 60,  # 'c'
-     100: 61,  # 'd'
-     101: 42,  # 'e'
-     102: 76,  # 'f'
-     103: 70,  # 'g'
-     104: 64,  # 'h'
-     105: 53,  # 'i'
-     106: 105,  # 'j'
-     107: 93,  # 'k'
-     108: 56,  # 'l'
-     109: 65,  # 'm'
-     110: 54,  # 'n'
-     111: 49,  # 'o'
-     112: 66,  # 'p'
-     113: 110,  # 'q'
-     114: 51,  # 'r'
-     115: 43,  # 's'
-     116: 44,  # 't'
-     117: 63,  # 'u'
-     118: 81,  # 'v'
-     119: 77,  # 'w'
-     120: 98,  # 'x'
-     121: 75,  # 'y'
-     122: 108,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 124,  # '€'
-     129: 202,  # None
-     130: 203,  # '‚'
-     131: 204,  # 'ƒ'
-     132: 205,  # '„'
-     133: 40,  # '…'
-     134: 58,  # '†'
-     135: 206,  # '‡'
-     136: 207,  # 'ˆ'
-     137: 208,  # '‰'
-     138: 209,  # None
-     139: 210,  # '‹'
-     140: 211,  # None
-     141: 212,  # None
-     142: 213,  # None
-     143: 214,  # None
-     144: 215,  # None
-     145: 83,  # '‘'
-     146: 52,  # '’'
-     147: 47,  # '“'
-     148: 46,  # '”'
-     149: 72,  # '•'
-     150: 32,  # '–'
-     151: 94,  # '—'
-     152: 216,  # '˜'
-     153: 113,  # '™'
-     154: 217,  # None
-     155: 109,  # '›'
-     156: 218,  # None
-     157: 219,  # None
-     158: 220,  # None
-     159: 221,  # None
-     160: 34,  # '\xa0'
-     161: 116,  # '¡'
-     162: 222,  # '¢'
-     163: 118,  # '£'
-     164: 100,  # '₪'
-     165: 223,  # '¥'
-     166: 224,  # '¦'
-     167: 117,  # '§'
-     168: 119,  # '¨'
-     169: 104,  # '©'
-     170: 125,  # '×'
-     171: 225,  # '«'
-     172: 226,  # '¬'
-     173: 87,  # '\xad'
-     174: 99,  # '®'
-     175: 227,  # '¯'
-     176: 106,  # '°'
-     177: 122,  # '±'
-     178: 123,  # '²'
-     179: 228,  # '³'
-     180: 55,  # '´'
-     181: 229,  # 'µ'
-     182: 230,  # '¶'
-     183: 101,  # '·'
-     184: 231,  # '¸'
-     185: 232,  # '¹'
-     186: 120,  # '÷'
-     187: 233,  # '»'
-     188: 48,  # '¼'
-     189: 39,  # '½'
-     190: 57,  # '¾'
-     191: 234,  # '¿'
-     192: 30,  # 'ְ'
-     193: 59,  # 'ֱ'
-     194: 41,  # 'ֲ'
-     195: 88,  # 'ֳ'
-     196: 33,  # 'ִ'
-     197: 37,  # 'ֵ'
-     198: 36,  # 'ֶ'
-     199: 31,  # 'ַ'
-     200: 29,  # 'ָ'
-     201: 35,  # 'ֹ'
-     202: 235,  # None
-     203: 62,  # 'ֻ'
-     204: 28,  # 'ּ'
-     205: 236,  # 'ֽ'
-     206: 126,  # '־'
-     207: 237,  # 'ֿ'
-     208: 238,  # '׀'
-     209: 38,  # 'ׁ'
-     210: 45,  # 'ׂ'
-     211: 239,  # '׃'
-     212: 240,  # 'װ'
-     213: 241,  # 'ױ'
-     214: 242,  # 'ײ'
-     215: 243,  # '׳'
-     216: 127,  # '״'
-     217: 244,  # None
-     218: 245,  # None
-     219: 246,  # None
-     220: 247,  # None
-     221: 248,  # None
-     222: 249,  # None
-     223: 250,  # None
-     224: 9,  # 'א'
-     225: 8,  # 'ב'
-     226: 20,  # 'ג'
-     227: 16,  # 'ד'
-     228: 3,  # 'ה'
-     229: 2,  # 'ו'
-     230: 24,  # 'ז'
-     231: 14,  # 'ח'
-     232: 22,  # 'ט'
-     233: 1,  # 'י'
-     234: 25,  # 'ך'
-     235: 15,  # 'כ'
-     236: 4,  # 'ל'
-     237: 11,  # 'ם'
-     238: 6,  # 'מ'
-     239: 23,  # 'ן'
-     240: 12,  # 'נ'
-     241: 19,  # 'ס'
-     242: 13,  # 'ע'
-     243: 26,  # 'ף'
-     244: 18,  # 'פ'
-     245: 27,  # 'ץ'
-     246: 21,  # 'צ'
-     247: 17,  # 'ק'
-     248: 7,  # 'ר'
-     249: 10,  # 'ש'
-     250: 5,  # 'ת'
-     251: 251,  # None
-     252: 252,  # None
-     253: 128,  # '\u200e'
-     254: 96,  # '\u200f'
-     255: 253,  # None
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 69,  # 'A'
+    66: 91,  # 'B'
+    67: 79,  # 'C'
+    68: 80,  # 'D'
+    69: 92,  # 'E'
+    70: 89,  # 'F'
+    71: 97,  # 'G'
+    72: 90,  # 'H'
+    73: 68,  # 'I'
+    74: 111,  # 'J'
+    75: 112,  # 'K'
+    76: 82,  # 'L'
+    77: 73,  # 'M'
+    78: 95,  # 'N'
+    79: 85,  # 'O'
+    80: 78,  # 'P'
+    81: 121,  # 'Q'
+    82: 86,  # 'R'
+    83: 71,  # 'S'
+    84: 67,  # 'T'
+    85: 102,  # 'U'
+    86: 107,  # 'V'
+    87: 84,  # 'W'
+    88: 114,  # 'X'
+    89: 103,  # 'Y'
+    90: 115,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 50,  # 'a'
+    98: 74,  # 'b'
+    99: 60,  # 'c'
+    100: 61,  # 'd'
+    101: 42,  # 'e'
+    102: 76,  # 'f'
+    103: 70,  # 'g'
+    104: 64,  # 'h'
+    105: 53,  # 'i'
+    106: 105,  # 'j'
+    107: 93,  # 'k'
+    108: 56,  # 'l'
+    109: 65,  # 'm'
+    110: 54,  # 'n'
+    111: 49,  # 'o'
+    112: 66,  # 'p'
+    113: 110,  # 'q'
+    114: 51,  # 'r'
+    115: 43,  # 's'
+    116: 44,  # 't'
+    117: 63,  # 'u'
+    118: 81,  # 'v'
+    119: 77,  # 'w'
+    120: 98,  # 'x'
+    121: 75,  # 'y'
+    122: 108,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 124,  # '€'
+    129: 202,  # None
+    130: 203,  # '‚'
+    131: 204,  # 'ƒ'
+    132: 205,  # '„'
+    133: 40,  # '…'
+    134: 58,  # '†'
+    135: 206,  # '‡'
+    136: 207,  # 'ˆ'
+    137: 208,  # '‰'
+    138: 209,  # None
+    139: 210,  # '‹'
+    140: 211,  # None
+    141: 212,  # None
+    142: 213,  # None
+    143: 214,  # None
+    144: 215,  # None
+    145: 83,  # '‘'
+    146: 52,  # '’'
+    147: 47,  # '“'
+    148: 46,  # '”'
+    149: 72,  # '•'
+    150: 32,  # '–'
+    151: 94,  # '—'
+    152: 216,  # '˜'
+    153: 113,  # '™'
+    154: 217,  # None
+    155: 109,  # '›'
+    156: 218,  # None
+    157: 219,  # None
+    158: 220,  # None
+    159: 221,  # None
+    160: 34,  # '\xa0'
+    161: 116,  # '¡'
+    162: 222,  # '¢'
+    163: 118,  # '£'
+    164: 100,  # '₪'
+    165: 223,  # '¥'
+    166: 224,  # '¦'
+    167: 117,  # '§'
+    168: 119,  # '¨'
+    169: 104,  # '©'
+    170: 125,  # '×'
+    171: 225,  # '«'
+    172: 226,  # '¬'
+    173: 87,  # '\xad'
+    174: 99,  # '®'
+    175: 227,  # '¯'
+    176: 106,  # '°'
+    177: 122,  # '±'
+    178: 123,  # '²'
+    179: 228,  # '³'
+    180: 55,  # '´'
+    181: 229,  # 'µ'
+    182: 230,  # '¶'
+    183: 101,  # '·'
+    184: 231,  # '¸'
+    185: 232,  # '¹'
+    186: 120,  # '÷'
+    187: 233,  # '»'
+    188: 48,  # '¼'
+    189: 39,  # '½'
+    190: 57,  # '¾'
+    191: 234,  # '¿'
+    192: 30,  # 'ְ'
+    193: 59,  # 'ֱ'
+    194: 41,  # 'ֲ'
+    195: 88,  # 'ֳ'
+    196: 33,  # 'ִ'
+    197: 37,  # 'ֵ'
+    198: 36,  # 'ֶ'
+    199: 31,  # 'ַ'
+    200: 29,  # 'ָ'
+    201: 35,  # 'ֹ'
+    202: 235,  # None
+    203: 62,  # 'ֻ'
+    204: 28,  # 'ּ'
+    205: 236,  # 'ֽ'
+    206: 126,  # '־'
+    207: 237,  # 'ֿ'
+    208: 238,  # '׀'
+    209: 38,  # 'ׁ'
+    210: 45,  # 'ׂ'
+    211: 239,  # '׃'
+    212: 240,  # 'װ'
+    213: 241,  # 'ױ'
+    214: 242,  # 'ײ'
+    215: 243,  # '׳'
+    216: 127,  # '״'
+    217: 244,  # None
+    218: 245,  # None
+    219: 246,  # None
+    220: 247,  # None
+    221: 248,  # None
+    222: 249,  # None
+    223: 250,  # None
+    224: 9,  # 'א'
+    225: 8,  # 'ב'
+    226: 20,  # 'ג'
+    227: 16,  # 'ד'
+    228: 3,  # 'ה'
+    229: 2,  # 'ו'
+    230: 24,  # 'ז'
+    231: 14,  # 'ח'
+    232: 22,  # 'ט'
+    233: 1,  # 'י'
+    234: 25,  # 'ך'
+    235: 15,  # 'כ'
+    236: 4,  # 'ל'
+    237: 11,  # 'ם'
+    238: 6,  # 'מ'
+    239: 23,  # 'ן'
+    240: 12,  # 'נ'
+    241: 19,  # 'ס'
+    242: 13,  # 'ע'
+    243: 26,  # 'ף'
+    244: 18,  # 'פ'
+    245: 27,  # 'ץ'
+    246: 21,  # 'צ'
+    247: 17,  # 'ק'
+    248: 7,  # 'ר'
+    249: 10,  # 'ש'
+    250: 5,  # 'ת'
+    251: 251,  # None
+    252: 252,  # None
+    253: 128,  # '\u200e'
+    254: 96,  # '\u200f'
+    255: 253,  # None
 }
 
-WINDOWS_1255_HEBREW_MODEL = SingleByteCharSetModel(charset_name='windows-1255',
-                                                   language='Hebrew',
-                                                   char_to_order_map=WINDOWS_1255_HEBREW_CHAR_TO_ORDER,
-                                                   language_model=HEBREW_LANG_MODEL,
-                                                   typical_positive_ratio=0.984004,
-                                                   keep_ascii_letters=False,
-                                                   alphabet='אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ')
-
+WINDOWS_1255_HEBREW_MODEL = SingleByteCharSetModel(
+    charset_name="windows-1255",
+    language="Hebrew",
+    char_to_order_map=WINDOWS_1255_HEBREW_CHAR_TO_ORDER,
+    language_model=HEBREW_LANG_MODEL,
+    typical_positive_ratio=0.984004,
+    keep_ascii_letters=False,
+    alphabet="אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py
index bbc5cda6..09a0d326 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langhungarianmodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -4115,536 +4111,539 @@ HUNGARIAN_LANG_MODEL = {
 
 # Character Mapping Table(s):
 WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 28,  # 'A'
-     66: 40,  # 'B'
-     67: 54,  # 'C'
-     68: 45,  # 'D'
-     69: 32,  # 'E'
-     70: 50,  # 'F'
-     71: 49,  # 'G'
-     72: 38,  # 'H'
-     73: 39,  # 'I'
-     74: 53,  # 'J'
-     75: 36,  # 'K'
-     76: 41,  # 'L'
-     77: 34,  # 'M'
-     78: 35,  # 'N'
-     79: 47,  # 'O'
-     80: 46,  # 'P'
-     81: 72,  # 'Q'
-     82: 43,  # 'R'
-     83: 33,  # 'S'
-     84: 37,  # 'T'
-     85: 57,  # 'U'
-     86: 48,  # 'V'
-     87: 64,  # 'W'
-     88: 68,  # 'X'
-     89: 55,  # 'Y'
-     90: 52,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 2,  # 'a'
-     98: 18,  # 'b'
-     99: 26,  # 'c'
-     100: 17,  # 'd'
-     101: 1,  # 'e'
-     102: 27,  # 'f'
-     103: 12,  # 'g'
-     104: 20,  # 'h'
-     105: 9,  # 'i'
-     106: 22,  # 'j'
-     107: 7,  # 'k'
-     108: 6,  # 'l'
-     109: 13,  # 'm'
-     110: 4,  # 'n'
-     111: 8,  # 'o'
-     112: 23,  # 'p'
-     113: 67,  # 'q'
-     114: 10,  # 'r'
-     115: 5,  # 's'
-     116: 3,  # 't'
-     117: 21,  # 'u'
-     118: 19,  # 'v'
-     119: 65,  # 'w'
-     120: 62,  # 'x'
-     121: 16,  # 'y'
-     122: 11,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 161,  # '€'
-     129: 162,  # None
-     130: 163,  # '‚'
-     131: 164,  # None
-     132: 165,  # '„'
-     133: 166,  # '…'
-     134: 167,  # '†'
-     135: 168,  # '‡'
-     136: 169,  # None
-     137: 170,  # '‰'
-     138: 171,  # 'Š'
-     139: 172,  # '‹'
-     140: 173,  # 'Ś'
-     141: 174,  # 'Ť'
-     142: 175,  # 'Ž'
-     143: 176,  # 'Ź'
-     144: 177,  # None
-     145: 178,  # '‘'
-     146: 179,  # '’'
-     147: 180,  # '“'
-     148: 78,  # '”'
-     149: 181,  # '•'
-     150: 69,  # '–'
-     151: 182,  # '—'
-     152: 183,  # None
-     153: 184,  # '™'
-     154: 185,  # 'š'
-     155: 186,  # '›'
-     156: 187,  # 'ś'
-     157: 188,  # 'ť'
-     158: 189,  # 'ž'
-     159: 190,  # 'ź'
-     160: 191,  # '\xa0'
-     161: 192,  # 'ˇ'
-     162: 193,  # '˘'
-     163: 194,  # 'Ł'
-     164: 195,  # '¤'
-     165: 196,  # 'Ą'
-     166: 197,  # '¦'
-     167: 76,  # '§'
-     168: 198,  # '¨'
-     169: 199,  # '©'
-     170: 200,  # 'Ş'
-     171: 201,  # '«'
-     172: 202,  # '¬'
-     173: 203,  # '\xad'
-     174: 204,  # '®'
-     175: 205,  # 'Ż'
-     176: 81,  # '°'
-     177: 206,  # '±'
-     178: 207,  # '˛'
-     179: 208,  # 'ł'
-     180: 209,  # '´'
-     181: 210,  # 'µ'
-     182: 211,  # '¶'
-     183: 212,  # '·'
-     184: 213,  # '¸'
-     185: 214,  # 'ą'
-     186: 215,  # 'ş'
-     187: 216,  # '»'
-     188: 217,  # 'Ľ'
-     189: 218,  # '˝'
-     190: 219,  # 'ľ'
-     191: 220,  # 'ż'
-     192: 221,  # 'Ŕ'
-     193: 51,  # 'Á'
-     194: 83,  # 'Â'
-     195: 222,  # 'Ă'
-     196: 80,  # 'Ä'
-     197: 223,  # 'Ĺ'
-     198: 224,  # 'Ć'
-     199: 225,  # 'Ç'
-     200: 226,  # 'Č'
-     201: 44,  # 'É'
-     202: 227,  # 'Ę'
-     203: 228,  # 'Ë'
-     204: 229,  # 'Ě'
-     205: 61,  # 'Í'
-     206: 230,  # 'Î'
-     207: 231,  # 'Ď'
-     208: 232,  # 'Đ'
-     209: 233,  # 'Ń'
-     210: 234,  # 'Ň'
-     211: 58,  # 'Ó'
-     212: 235,  # 'Ô'
-     213: 66,  # 'Ő'
-     214: 59,  # 'Ö'
-     215: 236,  # '×'
-     216: 237,  # 'Ř'
-     217: 238,  # 'Ů'
-     218: 60,  # 'Ú'
-     219: 70,  # 'Ű'
-     220: 63,  # 'Ü'
-     221: 239,  # 'Ý'
-     222: 240,  # 'Ţ'
-     223: 241,  # 'ß'
-     224: 84,  # 'ŕ'
-     225: 14,  # 'á'
-     226: 75,  # 'â'
-     227: 242,  # 'ă'
-     228: 71,  # 'ä'
-     229: 82,  # 'ĺ'
-     230: 243,  # 'ć'
-     231: 73,  # 'ç'
-     232: 244,  # 'č'
-     233: 15,  # 'é'
-     234: 85,  # 'ę'
-     235: 79,  # 'ë'
-     236: 86,  # 'ě'
-     237: 30,  # 'í'
-     238: 77,  # 'î'
-     239: 87,  # 'ď'
-     240: 245,  # 'đ'
-     241: 246,  # 'ń'
-     242: 247,  # 'ň'
-     243: 25,  # 'ó'
-     244: 74,  # 'ô'
-     245: 42,  # 'ő'
-     246: 24,  # 'ö'
-     247: 248,  # '÷'
-     248: 249,  # 'ř'
-     249: 250,  # 'ů'
-     250: 31,  # 'ú'
-     251: 56,  # 'ű'
-     252: 29,  # 'ü'
-     253: 251,  # 'ý'
-     254: 252,  # 'ţ'
-     255: 253,  # '˙'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 28,  # 'A'
+    66: 40,  # 'B'
+    67: 54,  # 'C'
+    68: 45,  # 'D'
+    69: 32,  # 'E'
+    70: 50,  # 'F'
+    71: 49,  # 'G'
+    72: 38,  # 'H'
+    73: 39,  # 'I'
+    74: 53,  # 'J'
+    75: 36,  # 'K'
+    76: 41,  # 'L'
+    77: 34,  # 'M'
+    78: 35,  # 'N'
+    79: 47,  # 'O'
+    80: 46,  # 'P'
+    81: 72,  # 'Q'
+    82: 43,  # 'R'
+    83: 33,  # 'S'
+    84: 37,  # 'T'
+    85: 57,  # 'U'
+    86: 48,  # 'V'
+    87: 64,  # 'W'
+    88: 68,  # 'X'
+    89: 55,  # 'Y'
+    90: 52,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 2,  # 'a'
+    98: 18,  # 'b'
+    99: 26,  # 'c'
+    100: 17,  # 'd'
+    101: 1,  # 'e'
+    102: 27,  # 'f'
+    103: 12,  # 'g'
+    104: 20,  # 'h'
+    105: 9,  # 'i'
+    106: 22,  # 'j'
+    107: 7,  # 'k'
+    108: 6,  # 'l'
+    109: 13,  # 'm'
+    110: 4,  # 'n'
+    111: 8,  # 'o'
+    112: 23,  # 'p'
+    113: 67,  # 'q'
+    114: 10,  # 'r'
+    115: 5,  # 's'
+    116: 3,  # 't'
+    117: 21,  # 'u'
+    118: 19,  # 'v'
+    119: 65,  # 'w'
+    120: 62,  # 'x'
+    121: 16,  # 'y'
+    122: 11,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 161,  # '€'
+    129: 162,  # None
+    130: 163,  # '‚'
+    131: 164,  # None
+    132: 165,  # '„'
+    133: 166,  # '…'
+    134: 167,  # '†'
+    135: 168,  # '‡'
+    136: 169,  # None
+    137: 170,  # '‰'
+    138: 171,  # 'Š'
+    139: 172,  # '‹'
+    140: 173,  # 'Ś'
+    141: 174,  # 'Ť'
+    142: 175,  # 'Ž'
+    143: 176,  # 'Ź'
+    144: 177,  # None
+    145: 178,  # '‘'
+    146: 179,  # '’'
+    147: 180,  # '“'
+    148: 78,  # '”'
+    149: 181,  # '•'
+    150: 69,  # '–'
+    151: 182,  # '—'
+    152: 183,  # None
+    153: 184,  # '™'
+    154: 185,  # 'š'
+    155: 186,  # '›'
+    156: 187,  # 'ś'
+    157: 188,  # 'ť'
+    158: 189,  # 'ž'
+    159: 190,  # 'ź'
+    160: 191,  # '\xa0'
+    161: 192,  # 'ˇ'
+    162: 193,  # '˘'
+    163: 194,  # 'Ł'
+    164: 195,  # '¤'
+    165: 196,  # 'Ą'
+    166: 197,  # '¦'
+    167: 76,  # '§'
+    168: 198,  # '¨'
+    169: 199,  # '©'
+    170: 200,  # 'Ş'
+    171: 201,  # '«'
+    172: 202,  # '¬'
+    173: 203,  # '\xad'
+    174: 204,  # '®'
+    175: 205,  # 'Ż'
+    176: 81,  # '°'
+    177: 206,  # '±'
+    178: 207,  # '˛'
+    179: 208,  # 'ł'
+    180: 209,  # '´'
+    181: 210,  # 'µ'
+    182: 211,  # '¶'
+    183: 212,  # '·'
+    184: 213,  # '¸'
+    185: 214,  # 'ą'
+    186: 215,  # 'ş'
+    187: 216,  # '»'
+    188: 217,  # 'Ľ'
+    189: 218,  # '˝'
+    190: 219,  # 'ľ'
+    191: 220,  # 'ż'
+    192: 221,  # 'Ŕ'
+    193: 51,  # 'Á'
+    194: 83,  # 'Â'
+    195: 222,  # 'Ă'
+    196: 80,  # 'Ä'
+    197: 223,  # 'Ĺ'
+    198: 224,  # 'Ć'
+    199: 225,  # 'Ç'
+    200: 226,  # 'Č'
+    201: 44,  # 'É'
+    202: 227,  # 'Ę'
+    203: 228,  # 'Ë'
+    204: 229,  # 'Ě'
+    205: 61,  # 'Í'
+    206: 230,  # 'Î'
+    207: 231,  # 'Ď'
+    208: 232,  # 'Đ'
+    209: 233,  # 'Ń'
+    210: 234,  # 'Ň'
+    211: 58,  # 'Ó'
+    212: 235,  # 'Ô'
+    213: 66,  # 'Ő'
+    214: 59,  # 'Ö'
+    215: 236,  # '×'
+    216: 237,  # 'Ř'
+    217: 238,  # 'Ů'
+    218: 60,  # 'Ú'
+    219: 70,  # 'Ű'
+    220: 63,  # 'Ü'
+    221: 239,  # 'Ý'
+    222: 240,  # 'Ţ'
+    223: 241,  # 'ß'
+    224: 84,  # 'ŕ'
+    225: 14,  # 'á'
+    226: 75,  # 'â'
+    227: 242,  # 'ă'
+    228: 71,  # 'ä'
+    229: 82,  # 'ĺ'
+    230: 243,  # 'ć'
+    231: 73,  # 'ç'
+    232: 244,  # 'č'
+    233: 15,  # 'é'
+    234: 85,  # 'ę'
+    235: 79,  # 'ë'
+    236: 86,  # 'ě'
+    237: 30,  # 'í'
+    238: 77,  # 'î'
+    239: 87,  # 'ď'
+    240: 245,  # 'đ'
+    241: 246,  # 'ń'
+    242: 247,  # 'ň'
+    243: 25,  # 'ó'
+    244: 74,  # 'ô'
+    245: 42,  # 'ő'
+    246: 24,  # 'ö'
+    247: 248,  # '÷'
+    248: 249,  # 'ř'
+    249: 250,  # 'ů'
+    250: 31,  # 'ú'
+    251: 56,  # 'ű'
+    252: 29,  # 'ü'
+    253: 251,  # 'ý'
+    254: 252,  # 'ţ'
+    255: 253,  # '˙'
 }
 
-WINDOWS_1250_HUNGARIAN_MODEL = SingleByteCharSetModel(charset_name='windows-1250',
-                                                      language='Hungarian',
-                                                      char_to_order_map=WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER,
-                                                      language_model=HUNGARIAN_LANG_MODEL,
-                                                      typical_positive_ratio=0.947368,
-                                                      keep_ascii_letters=True,
-                                                      alphabet='ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű')
+WINDOWS_1250_HUNGARIAN_MODEL = SingleByteCharSetModel(
+    charset_name="windows-1250",
+    language="Hungarian",
+    char_to_order_map=WINDOWS_1250_HUNGARIAN_CHAR_TO_ORDER,
+    language_model=HUNGARIAN_LANG_MODEL,
+    typical_positive_ratio=0.947368,
+    keep_ascii_letters=True,
+    alphabet="ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű",
+)
 
 ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 28,  # 'A'
-     66: 40,  # 'B'
-     67: 54,  # 'C'
-     68: 45,  # 'D'
-     69: 32,  # 'E'
-     70: 50,  # 'F'
-     71: 49,  # 'G'
-     72: 38,  # 'H'
-     73: 39,  # 'I'
-     74: 53,  # 'J'
-     75: 36,  # 'K'
-     76: 41,  # 'L'
-     77: 34,  # 'M'
-     78: 35,  # 'N'
-     79: 47,  # 'O'
-     80: 46,  # 'P'
-     81: 71,  # 'Q'
-     82: 43,  # 'R'
-     83: 33,  # 'S'
-     84: 37,  # 'T'
-     85: 57,  # 'U'
-     86: 48,  # 'V'
-     87: 64,  # 'W'
-     88: 68,  # 'X'
-     89: 55,  # 'Y'
-     90: 52,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 2,  # 'a'
-     98: 18,  # 'b'
-     99: 26,  # 'c'
-     100: 17,  # 'd'
-     101: 1,  # 'e'
-     102: 27,  # 'f'
-     103: 12,  # 'g'
-     104: 20,  # 'h'
-     105: 9,  # 'i'
-     106: 22,  # 'j'
-     107: 7,  # 'k'
-     108: 6,  # 'l'
-     109: 13,  # 'm'
-     110: 4,  # 'n'
-     111: 8,  # 'o'
-     112: 23,  # 'p'
-     113: 67,  # 'q'
-     114: 10,  # 'r'
-     115: 5,  # 's'
-     116: 3,  # 't'
-     117: 21,  # 'u'
-     118: 19,  # 'v'
-     119: 65,  # 'w'
-     120: 62,  # 'x'
-     121: 16,  # 'y'
-     122: 11,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 159,  # '\x80'
-     129: 160,  # '\x81'
-     130: 161,  # '\x82'
-     131: 162,  # '\x83'
-     132: 163,  # '\x84'
-     133: 164,  # '\x85'
-     134: 165,  # '\x86'
-     135: 166,  # '\x87'
-     136: 167,  # '\x88'
-     137: 168,  # '\x89'
-     138: 169,  # '\x8a'
-     139: 170,  # '\x8b'
-     140: 171,  # '\x8c'
-     141: 172,  # '\x8d'
-     142: 173,  # '\x8e'
-     143: 174,  # '\x8f'
-     144: 175,  # '\x90'
-     145: 176,  # '\x91'
-     146: 177,  # '\x92'
-     147: 178,  # '\x93'
-     148: 179,  # '\x94'
-     149: 180,  # '\x95'
-     150: 181,  # '\x96'
-     151: 182,  # '\x97'
-     152: 183,  # '\x98'
-     153: 184,  # '\x99'
-     154: 185,  # '\x9a'
-     155: 186,  # '\x9b'
-     156: 187,  # '\x9c'
-     157: 188,  # '\x9d'
-     158: 189,  # '\x9e'
-     159: 190,  # '\x9f'
-     160: 191,  # '\xa0'
-     161: 192,  # 'Ą'
-     162: 193,  # '˘'
-     163: 194,  # 'Ł'
-     164: 195,  # '¤'
-     165: 196,  # 'Ľ'
-     166: 197,  # 'Ś'
-     167: 75,  # '§'
-     168: 198,  # '¨'
-     169: 199,  # 'Š'
-     170: 200,  # 'Ş'
-     171: 201,  # 'Ť'
-     172: 202,  # 'Ź'
-     173: 203,  # '\xad'
-     174: 204,  # 'Ž'
-     175: 205,  # 'Ż'
-     176: 79,  # '°'
-     177: 206,  # 'ą'
-     178: 207,  # '˛'
-     179: 208,  # 'ł'
-     180: 209,  # '´'
-     181: 210,  # 'ľ'
-     182: 211,  # 'ś'
-     183: 212,  # 'ˇ'
-     184: 213,  # '¸'
-     185: 214,  # 'š'
-     186: 215,  # 'ş'
-     187: 216,  # 'ť'
-     188: 217,  # 'ź'
-     189: 218,  # '˝'
-     190: 219,  # 'ž'
-     191: 220,  # 'ż'
-     192: 221,  # 'Ŕ'
-     193: 51,  # 'Á'
-     194: 81,  # 'Â'
-     195: 222,  # 'Ă'
-     196: 78,  # 'Ä'
-     197: 223,  # 'Ĺ'
-     198: 224,  # 'Ć'
-     199: 225,  # 'Ç'
-     200: 226,  # 'Č'
-     201: 44,  # 'É'
-     202: 227,  # 'Ę'
-     203: 228,  # 'Ë'
-     204: 229,  # 'Ě'
-     205: 61,  # 'Í'
-     206: 230,  # 'Î'
-     207: 231,  # 'Ď'
-     208: 232,  # 'Đ'
-     209: 233,  # 'Ń'
-     210: 234,  # 'Ň'
-     211: 58,  # 'Ó'
-     212: 235,  # 'Ô'
-     213: 66,  # 'Ő'
-     214: 59,  # 'Ö'
-     215: 236,  # '×'
-     216: 237,  # 'Ř'
-     217: 238,  # 'Ů'
-     218: 60,  # 'Ú'
-     219: 69,  # 'Ű'
-     220: 63,  # 'Ü'
-     221: 239,  # 'Ý'
-     222: 240,  # 'Ţ'
-     223: 241,  # 'ß'
-     224: 82,  # 'ŕ'
-     225: 14,  # 'á'
-     226: 74,  # 'â'
-     227: 242,  # 'ă'
-     228: 70,  # 'ä'
-     229: 80,  # 'ĺ'
-     230: 243,  # 'ć'
-     231: 72,  # 'ç'
-     232: 244,  # 'č'
-     233: 15,  # 'é'
-     234: 83,  # 'ę'
-     235: 77,  # 'ë'
-     236: 84,  # 'ě'
-     237: 30,  # 'í'
-     238: 76,  # 'î'
-     239: 85,  # 'ď'
-     240: 245,  # 'đ'
-     241: 246,  # 'ń'
-     242: 247,  # 'ň'
-     243: 25,  # 'ó'
-     244: 73,  # 'ô'
-     245: 42,  # 'ő'
-     246: 24,  # 'ö'
-     247: 248,  # '÷'
-     248: 249,  # 'ř'
-     249: 250,  # 'ů'
-     250: 31,  # 'ú'
-     251: 56,  # 'ű'
-     252: 29,  # 'ü'
-     253: 251,  # 'ý'
-     254: 252,  # 'ţ'
-     255: 253,  # '˙'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 28,  # 'A'
+    66: 40,  # 'B'
+    67: 54,  # 'C'
+    68: 45,  # 'D'
+    69: 32,  # 'E'
+    70: 50,  # 'F'
+    71: 49,  # 'G'
+    72: 38,  # 'H'
+    73: 39,  # 'I'
+    74: 53,  # 'J'
+    75: 36,  # 'K'
+    76: 41,  # 'L'
+    77: 34,  # 'M'
+    78: 35,  # 'N'
+    79: 47,  # 'O'
+    80: 46,  # 'P'
+    81: 71,  # 'Q'
+    82: 43,  # 'R'
+    83: 33,  # 'S'
+    84: 37,  # 'T'
+    85: 57,  # 'U'
+    86: 48,  # 'V'
+    87: 64,  # 'W'
+    88: 68,  # 'X'
+    89: 55,  # 'Y'
+    90: 52,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 2,  # 'a'
+    98: 18,  # 'b'
+    99: 26,  # 'c'
+    100: 17,  # 'd'
+    101: 1,  # 'e'
+    102: 27,  # 'f'
+    103: 12,  # 'g'
+    104: 20,  # 'h'
+    105: 9,  # 'i'
+    106: 22,  # 'j'
+    107: 7,  # 'k'
+    108: 6,  # 'l'
+    109: 13,  # 'm'
+    110: 4,  # 'n'
+    111: 8,  # 'o'
+    112: 23,  # 'p'
+    113: 67,  # 'q'
+    114: 10,  # 'r'
+    115: 5,  # 's'
+    116: 3,  # 't'
+    117: 21,  # 'u'
+    118: 19,  # 'v'
+    119: 65,  # 'w'
+    120: 62,  # 'x'
+    121: 16,  # 'y'
+    122: 11,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 159,  # '\x80'
+    129: 160,  # '\x81'
+    130: 161,  # '\x82'
+    131: 162,  # '\x83'
+    132: 163,  # '\x84'
+    133: 164,  # '\x85'
+    134: 165,  # '\x86'
+    135: 166,  # '\x87'
+    136: 167,  # '\x88'
+    137: 168,  # '\x89'
+    138: 169,  # '\x8a'
+    139: 170,  # '\x8b'
+    140: 171,  # '\x8c'
+    141: 172,  # '\x8d'
+    142: 173,  # '\x8e'
+    143: 174,  # '\x8f'
+    144: 175,  # '\x90'
+    145: 176,  # '\x91'
+    146: 177,  # '\x92'
+    147: 178,  # '\x93'
+    148: 179,  # '\x94'
+    149: 180,  # '\x95'
+    150: 181,  # '\x96'
+    151: 182,  # '\x97'
+    152: 183,  # '\x98'
+    153: 184,  # '\x99'
+    154: 185,  # '\x9a'
+    155: 186,  # '\x9b'
+    156: 187,  # '\x9c'
+    157: 188,  # '\x9d'
+    158: 189,  # '\x9e'
+    159: 190,  # '\x9f'
+    160: 191,  # '\xa0'
+    161: 192,  # 'Ą'
+    162: 193,  # '˘'
+    163: 194,  # 'Ł'
+    164: 195,  # '¤'
+    165: 196,  # 'Ľ'
+    166: 197,  # 'Ś'
+    167: 75,  # '§'
+    168: 198,  # '¨'
+    169: 199,  # 'Š'
+    170: 200,  # 'Ş'
+    171: 201,  # 'Ť'
+    172: 202,  # 'Ź'
+    173: 203,  # '\xad'
+    174: 204,  # 'Ž'
+    175: 205,  # 'Ż'
+    176: 79,  # '°'
+    177: 206,  # 'ą'
+    178: 207,  # '˛'
+    179: 208,  # 'ł'
+    180: 209,  # '´'
+    181: 210,  # 'ľ'
+    182: 211,  # 'ś'
+    183: 212,  # 'ˇ'
+    184: 213,  # '¸'
+    185: 214,  # 'š'
+    186: 215,  # 'ş'
+    187: 216,  # 'ť'
+    188: 217,  # 'ź'
+    189: 218,  # '˝'
+    190: 219,  # 'ž'
+    191: 220,  # 'ż'
+    192: 221,  # 'Ŕ'
+    193: 51,  # 'Á'
+    194: 81,  # 'Â'
+    195: 222,  # 'Ă'
+    196: 78,  # 'Ä'
+    197: 223,  # 'Ĺ'
+    198: 224,  # 'Ć'
+    199: 225,  # 'Ç'
+    200: 226,  # 'Č'
+    201: 44,  # 'É'
+    202: 227,  # 'Ę'
+    203: 228,  # 'Ë'
+    204: 229,  # 'Ě'
+    205: 61,  # 'Í'
+    206: 230,  # 'Î'
+    207: 231,  # 'Ď'
+    208: 232,  # 'Đ'
+    209: 233,  # 'Ń'
+    210: 234,  # 'Ň'
+    211: 58,  # 'Ó'
+    212: 235,  # 'Ô'
+    213: 66,  # 'Ő'
+    214: 59,  # 'Ö'
+    215: 236,  # '×'
+    216: 237,  # 'Ř'
+    217: 238,  # 'Ů'
+    218: 60,  # 'Ú'
+    219: 69,  # 'Ű'
+    220: 63,  # 'Ü'
+    221: 239,  # 'Ý'
+    222: 240,  # 'Ţ'
+    223: 241,  # 'ß'
+    224: 82,  # 'ŕ'
+    225: 14,  # 'á'
+    226: 74,  # 'â'
+    227: 242,  # 'ă'
+    228: 70,  # 'ä'
+    229: 80,  # 'ĺ'
+    230: 243,  # 'ć'
+    231: 72,  # 'ç'
+    232: 244,  # 'č'
+    233: 15,  # 'é'
+    234: 83,  # 'ę'
+    235: 77,  # 'ë'
+    236: 84,  # 'ě'
+    237: 30,  # 'í'
+    238: 76,  # 'î'
+    239: 85,  # 'ď'
+    240: 245,  # 'đ'
+    241: 246,  # 'ń'
+    242: 247,  # 'ň'
+    243: 25,  # 'ó'
+    244: 73,  # 'ô'
+    245: 42,  # 'ő'
+    246: 24,  # 'ö'
+    247: 248,  # '÷'
+    248: 249,  # 'ř'
+    249: 250,  # 'ů'
+    250: 31,  # 'ú'
+    251: 56,  # 'ű'
+    252: 29,  # 'ü'
+    253: 251,  # 'ý'
+    254: 252,  # 'ţ'
+    255: 253,  # '˙'
 }
 
-ISO_8859_2_HUNGARIAN_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-2',
-                                                    language='Hungarian',
-                                                    char_to_order_map=ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER,
-                                                    language_model=HUNGARIAN_LANG_MODEL,
-                                                    typical_positive_ratio=0.947368,
-                                                    keep_ascii_letters=True,
-                                                    alphabet='ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű')
-
+ISO_8859_2_HUNGARIAN_MODEL = SingleByteCharSetModel(
+    charset_name="ISO-8859-2",
+    language="Hungarian",
+    char_to_order_map=ISO_8859_2_HUNGARIAN_CHAR_TO_ORDER,
+    language_model=HUNGARIAN_LANG_MODEL,
+    typical_positive_ratio=0.947368,
+    keep_ascii_letters=True,
+    alphabet="ABCDEFGHIJKLMNOPRSTUVZabcdefghijklmnoprstuvzÁÉÍÓÖÚÜáéíóöúüŐőŰű",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py
index 5594452b..39a53889 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langrussianmodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -4115,1604 +4111,1615 @@ RUSSIAN_LANG_MODEL = {
 
 # Character Mapping Table(s):
 IBM866_RUSSIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 142,  # 'A'
-     66: 143,  # 'B'
-     67: 144,  # 'C'
-     68: 145,  # 'D'
-     69: 146,  # 'E'
-     70: 147,  # 'F'
-     71: 148,  # 'G'
-     72: 149,  # 'H'
-     73: 150,  # 'I'
-     74: 151,  # 'J'
-     75: 152,  # 'K'
-     76: 74,  # 'L'
-     77: 153,  # 'M'
-     78: 75,  # 'N'
-     79: 154,  # 'O'
-     80: 155,  # 'P'
-     81: 156,  # 'Q'
-     82: 157,  # 'R'
-     83: 158,  # 'S'
-     84: 159,  # 'T'
-     85: 160,  # 'U'
-     86: 161,  # 'V'
-     87: 162,  # 'W'
-     88: 163,  # 'X'
-     89: 164,  # 'Y'
-     90: 165,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 71,  # 'a'
-     98: 172,  # 'b'
-     99: 66,  # 'c'
-     100: 173,  # 'd'
-     101: 65,  # 'e'
-     102: 174,  # 'f'
-     103: 76,  # 'g'
-     104: 175,  # 'h'
-     105: 64,  # 'i'
-     106: 176,  # 'j'
-     107: 177,  # 'k'
-     108: 77,  # 'l'
-     109: 72,  # 'm'
-     110: 178,  # 'n'
-     111: 69,  # 'o'
-     112: 67,  # 'p'
-     113: 179,  # 'q'
-     114: 78,  # 'r'
-     115: 73,  # 's'
-     116: 180,  # 't'
-     117: 181,  # 'u'
-     118: 79,  # 'v'
-     119: 182,  # 'w'
-     120: 183,  # 'x'
-     121: 184,  # 'y'
-     122: 185,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 37,  # 'А'
-     129: 44,  # 'Б'
-     130: 33,  # 'В'
-     131: 46,  # 'Г'
-     132: 41,  # 'Д'
-     133: 48,  # 'Е'
-     134: 56,  # 'Ж'
-     135: 51,  # 'З'
-     136: 42,  # 'И'
-     137: 60,  # 'Й'
-     138: 36,  # 'К'
-     139: 49,  # 'Л'
-     140: 38,  # 'М'
-     141: 31,  # 'Н'
-     142: 34,  # 'О'
-     143: 35,  # 'П'
-     144: 45,  # 'Р'
-     145: 32,  # 'С'
-     146: 40,  # 'Т'
-     147: 52,  # 'У'
-     148: 53,  # 'Ф'
-     149: 55,  # 'Х'
-     150: 58,  # 'Ц'
-     151: 50,  # 'Ч'
-     152: 57,  # 'Ш'
-     153: 63,  # 'Щ'
-     154: 70,  # 'Ъ'
-     155: 62,  # 'Ы'
-     156: 61,  # 'Ь'
-     157: 47,  # 'Э'
-     158: 59,  # 'Ю'
-     159: 43,  # 'Я'
-     160: 3,  # 'а'
-     161: 21,  # 'б'
-     162: 10,  # 'в'
-     163: 19,  # 'г'
-     164: 13,  # 'д'
-     165: 2,  # 'е'
-     166: 24,  # 'ж'
-     167: 20,  # 'з'
-     168: 4,  # 'и'
-     169: 23,  # 'й'
-     170: 11,  # 'к'
-     171: 8,  # 'л'
-     172: 12,  # 'м'
-     173: 5,  # 'н'
-     174: 1,  # 'о'
-     175: 15,  # 'п'
-     176: 191,  # '░'
-     177: 192,  # '▒'
-     178: 193,  # '▓'
-     179: 194,  # '│'
-     180: 195,  # '┤'
-     181: 196,  # '╡'
-     182: 197,  # '╢'
-     183: 198,  # '╖'
-     184: 199,  # '╕'
-     185: 200,  # '╣'
-     186: 201,  # '║'
-     187: 202,  # '╗'
-     188: 203,  # '╝'
-     189: 204,  # '╜'
-     190: 205,  # '╛'
-     191: 206,  # '┐'
-     192: 207,  # '└'
-     193: 208,  # '┴'
-     194: 209,  # '┬'
-     195: 210,  # '├'
-     196: 211,  # '─'
-     197: 212,  # '┼'
-     198: 213,  # '╞'
-     199: 214,  # '╟'
-     200: 215,  # '╚'
-     201: 216,  # '╔'
-     202: 217,  # '╩'
-     203: 218,  # '╦'
-     204: 219,  # '╠'
-     205: 220,  # '═'
-     206: 221,  # '╬'
-     207: 222,  # '╧'
-     208: 223,  # '╨'
-     209: 224,  # '╤'
-     210: 225,  # '╥'
-     211: 226,  # '╙'
-     212: 227,  # '╘'
-     213: 228,  # '╒'
-     214: 229,  # '╓'
-     215: 230,  # '╫'
-     216: 231,  # '╪'
-     217: 232,  # '┘'
-     218: 233,  # '┌'
-     219: 234,  # '█'
-     220: 235,  # '▄'
-     221: 236,  # '▌'
-     222: 237,  # '▐'
-     223: 238,  # '▀'
-     224: 9,  # 'р'
-     225: 7,  # 'с'
-     226: 6,  # 'т'
-     227: 14,  # 'у'
-     228: 39,  # 'ф'
-     229: 26,  # 'х'
-     230: 28,  # 'ц'
-     231: 22,  # 'ч'
-     232: 25,  # 'ш'
-     233: 29,  # 'щ'
-     234: 54,  # 'ъ'
-     235: 18,  # 'ы'
-     236: 17,  # 'ь'
-     237: 30,  # 'э'
-     238: 27,  # 'ю'
-     239: 16,  # 'я'
-     240: 239,  # 'Ё'
-     241: 68,  # 'ё'
-     242: 240,  # 'Є'
-     243: 241,  # 'є'
-     244: 242,  # 'Ї'
-     245: 243,  # 'ї'
-     246: 244,  # 'Ў'
-     247: 245,  # 'ў'
-     248: 246,  # '°'
-     249: 247,  # '∙'
-     250: 248,  # '·'
-     251: 249,  # '√'
-     252: 250,  # '№'
-     253: 251,  # '¤'
-     254: 252,  # '■'
-     255: 255,  # '\xa0'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 142,  # 'A'
+    66: 143,  # 'B'
+    67: 144,  # 'C'
+    68: 145,  # 'D'
+    69: 146,  # 'E'
+    70: 147,  # 'F'
+    71: 148,  # 'G'
+    72: 149,  # 'H'
+    73: 150,  # 'I'
+    74: 151,  # 'J'
+    75: 152,  # 'K'
+    76: 74,  # 'L'
+    77: 153,  # 'M'
+    78: 75,  # 'N'
+    79: 154,  # 'O'
+    80: 155,  # 'P'
+    81: 156,  # 'Q'
+    82: 157,  # 'R'
+    83: 158,  # 'S'
+    84: 159,  # 'T'
+    85: 160,  # 'U'
+    86: 161,  # 'V'
+    87: 162,  # 'W'
+    88: 163,  # 'X'
+    89: 164,  # 'Y'
+    90: 165,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 71,  # 'a'
+    98: 172,  # 'b'
+    99: 66,  # 'c'
+    100: 173,  # 'd'
+    101: 65,  # 'e'
+    102: 174,  # 'f'
+    103: 76,  # 'g'
+    104: 175,  # 'h'
+    105: 64,  # 'i'
+    106: 176,  # 'j'
+    107: 177,  # 'k'
+    108: 77,  # 'l'
+    109: 72,  # 'm'
+    110: 178,  # 'n'
+    111: 69,  # 'o'
+    112: 67,  # 'p'
+    113: 179,  # 'q'
+    114: 78,  # 'r'
+    115: 73,  # 's'
+    116: 180,  # 't'
+    117: 181,  # 'u'
+    118: 79,  # 'v'
+    119: 182,  # 'w'
+    120: 183,  # 'x'
+    121: 184,  # 'y'
+    122: 185,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 37,  # 'А'
+    129: 44,  # 'Б'
+    130: 33,  # 'В'
+    131: 46,  # 'Г'
+    132: 41,  # 'Д'
+    133: 48,  # 'Е'
+    134: 56,  # 'Ж'
+    135: 51,  # 'З'
+    136: 42,  # 'И'
+    137: 60,  # 'Й'
+    138: 36,  # 'К'
+    139: 49,  # 'Л'
+    140: 38,  # 'М'
+    141: 31,  # 'Н'
+    142: 34,  # 'О'
+    143: 35,  # 'П'
+    144: 45,  # 'Р'
+    145: 32,  # 'С'
+    146: 40,  # 'Т'
+    147: 52,  # 'У'
+    148: 53,  # 'Ф'
+    149: 55,  # 'Х'
+    150: 58,  # 'Ц'
+    151: 50,  # 'Ч'
+    152: 57,  # 'Ш'
+    153: 63,  # 'Щ'
+    154: 70,  # 'Ъ'
+    155: 62,  # 'Ы'
+    156: 61,  # 'Ь'
+    157: 47,  # 'Э'
+    158: 59,  # 'Ю'
+    159: 43,  # 'Я'
+    160: 3,  # 'а'
+    161: 21,  # 'б'
+    162: 10,  # 'в'
+    163: 19,  # 'г'
+    164: 13,  # 'д'
+    165: 2,  # 'е'
+    166: 24,  # 'ж'
+    167: 20,  # 'з'
+    168: 4,  # 'и'
+    169: 23,  # 'й'
+    170: 11,  # 'к'
+    171: 8,  # 'л'
+    172: 12,  # 'м'
+    173: 5,  # 'н'
+    174: 1,  # 'о'
+    175: 15,  # 'п'
+    176: 191,  # '░'
+    177: 192,  # '▒'
+    178: 193,  # '▓'
+    179: 194,  # '│'
+    180: 195,  # '┤'
+    181: 196,  # '╡'
+    182: 197,  # '╢'
+    183: 198,  # '╖'
+    184: 199,  # '╕'
+    185: 200,  # '╣'
+    186: 201,  # '║'
+    187: 202,  # '╗'
+    188: 203,  # '╝'
+    189: 204,  # '╜'
+    190: 205,  # '╛'
+    191: 206,  # '┐'
+    192: 207,  # '└'
+    193: 208,  # '┴'
+    194: 209,  # '┬'
+    195: 210,  # '├'
+    196: 211,  # '─'
+    197: 212,  # '┼'
+    198: 213,  # '╞'
+    199: 214,  # '╟'
+    200: 215,  # '╚'
+    201: 216,  # '╔'
+    202: 217,  # '╩'
+    203: 218,  # '╦'
+    204: 219,  # '╠'
+    205: 220,  # '═'
+    206: 221,  # '╬'
+    207: 222,  # '╧'
+    208: 223,  # '╨'
+    209: 224,  # '╤'
+    210: 225,  # '╥'
+    211: 226,  # '╙'
+    212: 227,  # '╘'
+    213: 228,  # '╒'
+    214: 229,  # '╓'
+    215: 230,  # '╫'
+    216: 231,  # '╪'
+    217: 232,  # '┘'
+    218: 233,  # '┌'
+    219: 234,  # '█'
+    220: 235,  # '▄'
+    221: 236,  # '▌'
+    222: 237,  # '▐'
+    223: 238,  # '▀'
+    224: 9,  # 'р'
+    225: 7,  # 'с'
+    226: 6,  # 'т'
+    227: 14,  # 'у'
+    228: 39,  # 'ф'
+    229: 26,  # 'х'
+    230: 28,  # 'ц'
+    231: 22,  # 'ч'
+    232: 25,  # 'ш'
+    233: 29,  # 'щ'
+    234: 54,  # 'ъ'
+    235: 18,  # 'ы'
+    236: 17,  # 'ь'
+    237: 30,  # 'э'
+    238: 27,  # 'ю'
+    239: 16,  # 'я'
+    240: 239,  # 'Ё'
+    241: 68,  # 'ё'
+    242: 240,  # 'Є'
+    243: 241,  # 'є'
+    244: 242,  # 'Ї'
+    245: 243,  # 'ї'
+    246: 244,  # 'Ў'
+    247: 245,  # 'ў'
+    248: 246,  # '°'
+    249: 247,  # '∙'
+    250: 248,  # '·'
+    251: 249,  # '√'
+    252: 250,  # '№'
+    253: 251,  # '¤'
+    254: 252,  # '■'
+    255: 255,  # '\xa0'
 }
 
-IBM866_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='IBM866',
-                                              language='Russian',
-                                              char_to_order_map=IBM866_RUSSIAN_CHAR_TO_ORDER,
-                                              language_model=RUSSIAN_LANG_MODEL,
-                                              typical_positive_ratio=0.976601,
-                                              keep_ascii_letters=False,
-                                              alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё')
+IBM866_RUSSIAN_MODEL = SingleByteCharSetModel(
+    charset_name="IBM866",
+    language="Russian",
+    char_to_order_map=IBM866_RUSSIAN_CHAR_TO_ORDER,
+    language_model=RUSSIAN_LANG_MODEL,
+    typical_positive_ratio=0.976601,
+    keep_ascii_letters=False,
+    alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё",
+)
 
 WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 142,  # 'A'
-     66: 143,  # 'B'
-     67: 144,  # 'C'
-     68: 145,  # 'D'
-     69: 146,  # 'E'
-     70: 147,  # 'F'
-     71: 148,  # 'G'
-     72: 149,  # 'H'
-     73: 150,  # 'I'
-     74: 151,  # 'J'
-     75: 152,  # 'K'
-     76: 74,  # 'L'
-     77: 153,  # 'M'
-     78: 75,  # 'N'
-     79: 154,  # 'O'
-     80: 155,  # 'P'
-     81: 156,  # 'Q'
-     82: 157,  # 'R'
-     83: 158,  # 'S'
-     84: 159,  # 'T'
-     85: 160,  # 'U'
-     86: 161,  # 'V'
-     87: 162,  # 'W'
-     88: 163,  # 'X'
-     89: 164,  # 'Y'
-     90: 165,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 71,  # 'a'
-     98: 172,  # 'b'
-     99: 66,  # 'c'
-     100: 173,  # 'd'
-     101: 65,  # 'e'
-     102: 174,  # 'f'
-     103: 76,  # 'g'
-     104: 175,  # 'h'
-     105: 64,  # 'i'
-     106: 176,  # 'j'
-     107: 177,  # 'k'
-     108: 77,  # 'l'
-     109: 72,  # 'm'
-     110: 178,  # 'n'
-     111: 69,  # 'o'
-     112: 67,  # 'p'
-     113: 179,  # 'q'
-     114: 78,  # 'r'
-     115: 73,  # 's'
-     116: 180,  # 't'
-     117: 181,  # 'u'
-     118: 79,  # 'v'
-     119: 182,  # 'w'
-     120: 183,  # 'x'
-     121: 184,  # 'y'
-     122: 185,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 191,  # 'Ђ'
-     129: 192,  # 'Ѓ'
-     130: 193,  # '‚'
-     131: 194,  # 'ѓ'
-     132: 195,  # '„'
-     133: 196,  # '…'
-     134: 197,  # '†'
-     135: 198,  # '‡'
-     136: 199,  # '€'
-     137: 200,  # '‰'
-     138: 201,  # 'Љ'
-     139: 202,  # '‹'
-     140: 203,  # 'Њ'
-     141: 204,  # 'Ќ'
-     142: 205,  # 'Ћ'
-     143: 206,  # 'Џ'
-     144: 207,  # 'ђ'
-     145: 208,  # '‘'
-     146: 209,  # '’'
-     147: 210,  # '“'
-     148: 211,  # '”'
-     149: 212,  # '•'
-     150: 213,  # '–'
-     151: 214,  # '—'
-     152: 215,  # None
-     153: 216,  # '™'
-     154: 217,  # 'љ'
-     155: 218,  # '›'
-     156: 219,  # 'њ'
-     157: 220,  # 'ќ'
-     158: 221,  # 'ћ'
-     159: 222,  # 'џ'
-     160: 223,  # '\xa0'
-     161: 224,  # 'Ў'
-     162: 225,  # 'ў'
-     163: 226,  # 'Ј'
-     164: 227,  # '¤'
-     165: 228,  # 'Ґ'
-     166: 229,  # '¦'
-     167: 230,  # '§'
-     168: 231,  # 'Ё'
-     169: 232,  # '©'
-     170: 233,  # 'Є'
-     171: 234,  # '«'
-     172: 235,  # '¬'
-     173: 236,  # '\xad'
-     174: 237,  # '®'
-     175: 238,  # 'Ї'
-     176: 239,  # '°'
-     177: 240,  # '±'
-     178: 241,  # 'І'
-     179: 242,  # 'і'
-     180: 243,  # 'ґ'
-     181: 244,  # 'µ'
-     182: 245,  # '¶'
-     183: 246,  # '·'
-     184: 68,  # 'ё'
-     185: 247,  # '№'
-     186: 248,  # 'є'
-     187: 249,  # '»'
-     188: 250,  # 'ј'
-     189: 251,  # 'Ѕ'
-     190: 252,  # 'ѕ'
-     191: 253,  # 'ї'
-     192: 37,  # 'А'
-     193: 44,  # 'Б'
-     194: 33,  # 'В'
-     195: 46,  # 'Г'
-     196: 41,  # 'Д'
-     197: 48,  # 'Е'
-     198: 56,  # 'Ж'
-     199: 51,  # 'З'
-     200: 42,  # 'И'
-     201: 60,  # 'Й'
-     202: 36,  # 'К'
-     203: 49,  # 'Л'
-     204: 38,  # 'М'
-     205: 31,  # 'Н'
-     206: 34,  # 'О'
-     207: 35,  # 'П'
-     208: 45,  # 'Р'
-     209: 32,  # 'С'
-     210: 40,  # 'Т'
-     211: 52,  # 'У'
-     212: 53,  # 'Ф'
-     213: 55,  # 'Х'
-     214: 58,  # 'Ц'
-     215: 50,  # 'Ч'
-     216: 57,  # 'Ш'
-     217: 63,  # 'Щ'
-     218: 70,  # 'Ъ'
-     219: 62,  # 'Ы'
-     220: 61,  # 'Ь'
-     221: 47,  # 'Э'
-     222: 59,  # 'Ю'
-     223: 43,  # 'Я'
-     224: 3,  # 'а'
-     225: 21,  # 'б'
-     226: 10,  # 'в'
-     227: 19,  # 'г'
-     228: 13,  # 'д'
-     229: 2,  # 'е'
-     230: 24,  # 'ж'
-     231: 20,  # 'з'
-     232: 4,  # 'и'
-     233: 23,  # 'й'
-     234: 11,  # 'к'
-     235: 8,  # 'л'
-     236: 12,  # 'м'
-     237: 5,  # 'н'
-     238: 1,  # 'о'
-     239: 15,  # 'п'
-     240: 9,  # 'р'
-     241: 7,  # 'с'
-     242: 6,  # 'т'
-     243: 14,  # 'у'
-     244: 39,  # 'ф'
-     245: 26,  # 'х'
-     246: 28,  # 'ц'
-     247: 22,  # 'ч'
-     248: 25,  # 'ш'
-     249: 29,  # 'щ'
-     250: 54,  # 'ъ'
-     251: 18,  # 'ы'
-     252: 17,  # 'ь'
-     253: 30,  # 'э'
-     254: 27,  # 'ю'
-     255: 16,  # 'я'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 142,  # 'A'
+    66: 143,  # 'B'
+    67: 144,  # 'C'
+    68: 145,  # 'D'
+    69: 146,  # 'E'
+    70: 147,  # 'F'
+    71: 148,  # 'G'
+    72: 149,  # 'H'
+    73: 150,  # 'I'
+    74: 151,  # 'J'
+    75: 152,  # 'K'
+    76: 74,  # 'L'
+    77: 153,  # 'M'
+    78: 75,  # 'N'
+    79: 154,  # 'O'
+    80: 155,  # 'P'
+    81: 156,  # 'Q'
+    82: 157,  # 'R'
+    83: 158,  # 'S'
+    84: 159,  # 'T'
+    85: 160,  # 'U'
+    86: 161,  # 'V'
+    87: 162,  # 'W'
+    88: 163,  # 'X'
+    89: 164,  # 'Y'
+    90: 165,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 71,  # 'a'
+    98: 172,  # 'b'
+    99: 66,  # 'c'
+    100: 173,  # 'd'
+    101: 65,  # 'e'
+    102: 174,  # 'f'
+    103: 76,  # 'g'
+    104: 175,  # 'h'
+    105: 64,  # 'i'
+    106: 176,  # 'j'
+    107: 177,  # 'k'
+    108: 77,  # 'l'
+    109: 72,  # 'm'
+    110: 178,  # 'n'
+    111: 69,  # 'o'
+    112: 67,  # 'p'
+    113: 179,  # 'q'
+    114: 78,  # 'r'
+    115: 73,  # 's'
+    116: 180,  # 't'
+    117: 181,  # 'u'
+    118: 79,  # 'v'
+    119: 182,  # 'w'
+    120: 183,  # 'x'
+    121: 184,  # 'y'
+    122: 185,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 191,  # 'Ђ'
+    129: 192,  # 'Ѓ'
+    130: 193,  # '‚'
+    131: 194,  # 'ѓ'
+    132: 195,  # '„'
+    133: 196,  # '…'
+    134: 197,  # '†'
+    135: 198,  # '‡'
+    136: 199,  # '€'
+    137: 200,  # '‰'
+    138: 201,  # 'Љ'
+    139: 202,  # '‹'
+    140: 203,  # 'Њ'
+    141: 204,  # 'Ќ'
+    142: 205,  # 'Ћ'
+    143: 206,  # 'Џ'
+    144: 207,  # 'ђ'
+    145: 208,  # '‘'
+    146: 209,  # '’'
+    147: 210,  # '“'
+    148: 211,  # '”'
+    149: 212,  # '•'
+    150: 213,  # '–'
+    151: 214,  # '—'
+    152: 215,  # None
+    153: 216,  # '™'
+    154: 217,  # 'љ'
+    155: 218,  # '›'
+    156: 219,  # 'њ'
+    157: 220,  # 'ќ'
+    158: 221,  # 'ћ'
+    159: 222,  # 'џ'
+    160: 223,  # '\xa0'
+    161: 224,  # 'Ў'
+    162: 225,  # 'ў'
+    163: 226,  # 'Ј'
+    164: 227,  # '¤'
+    165: 228,  # 'Ґ'
+    166: 229,  # '¦'
+    167: 230,  # '§'
+    168: 231,  # 'Ё'
+    169: 232,  # '©'
+    170: 233,  # 'Є'
+    171: 234,  # '«'
+    172: 235,  # '¬'
+    173: 236,  # '\xad'
+    174: 237,  # '®'
+    175: 238,  # 'Ї'
+    176: 239,  # '°'
+    177: 240,  # '±'
+    178: 241,  # 'І'
+    179: 242,  # 'і'
+    180: 243,  # 'ґ'
+    181: 244,  # 'µ'
+    182: 245,  # '¶'
+    183: 246,  # '·'
+    184: 68,  # 'ё'
+    185: 247,  # '№'
+    186: 248,  # 'є'
+    187: 249,  # '»'
+    188: 250,  # 'ј'
+    189: 251,  # 'Ѕ'
+    190: 252,  # 'ѕ'
+    191: 253,  # 'ї'
+    192: 37,  # 'А'
+    193: 44,  # 'Б'
+    194: 33,  # 'В'
+    195: 46,  # 'Г'
+    196: 41,  # 'Д'
+    197: 48,  # 'Е'
+    198: 56,  # 'Ж'
+    199: 51,  # 'З'
+    200: 42,  # 'И'
+    201: 60,  # 'Й'
+    202: 36,  # 'К'
+    203: 49,  # 'Л'
+    204: 38,  # 'М'
+    205: 31,  # 'Н'
+    206: 34,  # 'О'
+    207: 35,  # 'П'
+    208: 45,  # 'Р'
+    209: 32,  # 'С'
+    210: 40,  # 'Т'
+    211: 52,  # 'У'
+    212: 53,  # 'Ф'
+    213: 55,  # 'Х'
+    214: 58,  # 'Ц'
+    215: 50,  # 'Ч'
+    216: 57,  # 'Ш'
+    217: 63,  # 'Щ'
+    218: 70,  # 'Ъ'
+    219: 62,  # 'Ы'
+    220: 61,  # 'Ь'
+    221: 47,  # 'Э'
+    222: 59,  # 'Ю'
+    223: 43,  # 'Я'
+    224: 3,  # 'а'
+    225: 21,  # 'б'
+    226: 10,  # 'в'
+    227: 19,  # 'г'
+    228: 13,  # 'д'
+    229: 2,  # 'е'
+    230: 24,  # 'ж'
+    231: 20,  # 'з'
+    232: 4,  # 'и'
+    233: 23,  # 'й'
+    234: 11,  # 'к'
+    235: 8,  # 'л'
+    236: 12,  # 'м'
+    237: 5,  # 'н'
+    238: 1,  # 'о'
+    239: 15,  # 'п'
+    240: 9,  # 'р'
+    241: 7,  # 'с'
+    242: 6,  # 'т'
+    243: 14,  # 'у'
+    244: 39,  # 'ф'
+    245: 26,  # 'х'
+    246: 28,  # 'ц'
+    247: 22,  # 'ч'
+    248: 25,  # 'ш'
+    249: 29,  # 'щ'
+    250: 54,  # 'ъ'
+    251: 18,  # 'ы'
+    252: 17,  # 'ь'
+    253: 30,  # 'э'
+    254: 27,  # 'ю'
+    255: 16,  # 'я'
 }
 
-WINDOWS_1251_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='windows-1251',
-                                                    language='Russian',
-                                                    char_to_order_map=WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER,
-                                                    language_model=RUSSIAN_LANG_MODEL,
-                                                    typical_positive_ratio=0.976601,
-                                                    keep_ascii_letters=False,
-                                                    alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё')
+WINDOWS_1251_RUSSIAN_MODEL = SingleByteCharSetModel(
+    charset_name="windows-1251",
+    language="Russian",
+    char_to_order_map=WINDOWS_1251_RUSSIAN_CHAR_TO_ORDER,
+    language_model=RUSSIAN_LANG_MODEL,
+    typical_positive_ratio=0.976601,
+    keep_ascii_letters=False,
+    alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё",
+)
 
 IBM855_RUSSIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 142,  # 'A'
-     66: 143,  # 'B'
-     67: 144,  # 'C'
-     68: 145,  # 'D'
-     69: 146,  # 'E'
-     70: 147,  # 'F'
-     71: 148,  # 'G'
-     72: 149,  # 'H'
-     73: 150,  # 'I'
-     74: 151,  # 'J'
-     75: 152,  # 'K'
-     76: 74,  # 'L'
-     77: 153,  # 'M'
-     78: 75,  # 'N'
-     79: 154,  # 'O'
-     80: 155,  # 'P'
-     81: 156,  # 'Q'
-     82: 157,  # 'R'
-     83: 158,  # 'S'
-     84: 159,  # 'T'
-     85: 160,  # 'U'
-     86: 161,  # 'V'
-     87: 162,  # 'W'
-     88: 163,  # 'X'
-     89: 164,  # 'Y'
-     90: 165,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 71,  # 'a'
-     98: 172,  # 'b'
-     99: 66,  # 'c'
-     100: 173,  # 'd'
-     101: 65,  # 'e'
-     102: 174,  # 'f'
-     103: 76,  # 'g'
-     104: 175,  # 'h'
-     105: 64,  # 'i'
-     106: 176,  # 'j'
-     107: 177,  # 'k'
-     108: 77,  # 'l'
-     109: 72,  # 'm'
-     110: 178,  # 'n'
-     111: 69,  # 'o'
-     112: 67,  # 'p'
-     113: 179,  # 'q'
-     114: 78,  # 'r'
-     115: 73,  # 's'
-     116: 180,  # 't'
-     117: 181,  # 'u'
-     118: 79,  # 'v'
-     119: 182,  # 'w'
-     120: 183,  # 'x'
-     121: 184,  # 'y'
-     122: 185,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 191,  # 'ђ'
-     129: 192,  # 'Ђ'
-     130: 193,  # 'ѓ'
-     131: 194,  # 'Ѓ'
-     132: 68,  # 'ё'
-     133: 195,  # 'Ё'
-     134: 196,  # 'є'
-     135: 197,  # 'Є'
-     136: 198,  # 'ѕ'
-     137: 199,  # 'Ѕ'
-     138: 200,  # 'і'
-     139: 201,  # 'І'
-     140: 202,  # 'ї'
-     141: 203,  # 'Ї'
-     142: 204,  # 'ј'
-     143: 205,  # 'Ј'
-     144: 206,  # 'љ'
-     145: 207,  # 'Љ'
-     146: 208,  # 'њ'
-     147: 209,  # 'Њ'
-     148: 210,  # 'ћ'
-     149: 211,  # 'Ћ'
-     150: 212,  # 'ќ'
-     151: 213,  # 'Ќ'
-     152: 214,  # 'ў'
-     153: 215,  # 'Ў'
-     154: 216,  # 'џ'
-     155: 217,  # 'Џ'
-     156: 27,  # 'ю'
-     157: 59,  # 'Ю'
-     158: 54,  # 'ъ'
-     159: 70,  # 'Ъ'
-     160: 3,  # 'а'
-     161: 37,  # 'А'
-     162: 21,  # 'б'
-     163: 44,  # 'Б'
-     164: 28,  # 'ц'
-     165: 58,  # 'Ц'
-     166: 13,  # 'д'
-     167: 41,  # 'Д'
-     168: 2,  # 'е'
-     169: 48,  # 'Е'
-     170: 39,  # 'ф'
-     171: 53,  # 'Ф'
-     172: 19,  # 'г'
-     173: 46,  # 'Г'
-     174: 218,  # '«'
-     175: 219,  # '»'
-     176: 220,  # '░'
-     177: 221,  # '▒'
-     178: 222,  # '▓'
-     179: 223,  # '│'
-     180: 224,  # '┤'
-     181: 26,  # 'х'
-     182: 55,  # 'Х'
-     183: 4,  # 'и'
-     184: 42,  # 'И'
-     185: 225,  # '╣'
-     186: 226,  # '║'
-     187: 227,  # '╗'
-     188: 228,  # '╝'
-     189: 23,  # 'й'
-     190: 60,  # 'Й'
-     191: 229,  # '┐'
-     192: 230,  # '└'
-     193: 231,  # '┴'
-     194: 232,  # '┬'
-     195: 233,  # '├'
-     196: 234,  # '─'
-     197: 235,  # '┼'
-     198: 11,  # 'к'
-     199: 36,  # 'К'
-     200: 236,  # '╚'
-     201: 237,  # '╔'
-     202: 238,  # '╩'
-     203: 239,  # '╦'
-     204: 240,  # '╠'
-     205: 241,  # '═'
-     206: 242,  # '╬'
-     207: 243,  # '¤'
-     208: 8,  # 'л'
-     209: 49,  # 'Л'
-     210: 12,  # 'м'
-     211: 38,  # 'М'
-     212: 5,  # 'н'
-     213: 31,  # 'Н'
-     214: 1,  # 'о'
-     215: 34,  # 'О'
-     216: 15,  # 'п'
-     217: 244,  # '┘'
-     218: 245,  # '┌'
-     219: 246,  # '█'
-     220: 247,  # '▄'
-     221: 35,  # 'П'
-     222: 16,  # 'я'
-     223: 248,  # '▀'
-     224: 43,  # 'Я'
-     225: 9,  # 'р'
-     226: 45,  # 'Р'
-     227: 7,  # 'с'
-     228: 32,  # 'С'
-     229: 6,  # 'т'
-     230: 40,  # 'Т'
-     231: 14,  # 'у'
-     232: 52,  # 'У'
-     233: 24,  # 'ж'
-     234: 56,  # 'Ж'
-     235: 10,  # 'в'
-     236: 33,  # 'В'
-     237: 17,  # 'ь'
-     238: 61,  # 'Ь'
-     239: 249,  # '№'
-     240: 250,  # '\xad'
-     241: 18,  # 'ы'
-     242: 62,  # 'Ы'
-     243: 20,  # 'з'
-     244: 51,  # 'З'
-     245: 25,  # 'ш'
-     246: 57,  # 'Ш'
-     247: 30,  # 'э'
-     248: 47,  # 'Э'
-     249: 29,  # 'щ'
-     250: 63,  # 'Щ'
-     251: 22,  # 'ч'
-     252: 50,  # 'Ч'
-     253: 251,  # '§'
-     254: 252,  # '■'
-     255: 255,  # '\xa0'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 142,  # 'A'
+    66: 143,  # 'B'
+    67: 144,  # 'C'
+    68: 145,  # 'D'
+    69: 146,  # 'E'
+    70: 147,  # 'F'
+    71: 148,  # 'G'
+    72: 149,  # 'H'
+    73: 150,  # 'I'
+    74: 151,  # 'J'
+    75: 152,  # 'K'
+    76: 74,  # 'L'
+    77: 153,  # 'M'
+    78: 75,  # 'N'
+    79: 154,  # 'O'
+    80: 155,  # 'P'
+    81: 156,  # 'Q'
+    82: 157,  # 'R'
+    83: 158,  # 'S'
+    84: 159,  # 'T'
+    85: 160,  # 'U'
+    86: 161,  # 'V'
+    87: 162,  # 'W'
+    88: 163,  # 'X'
+    89: 164,  # 'Y'
+    90: 165,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 71,  # 'a'
+    98: 172,  # 'b'
+    99: 66,  # 'c'
+    100: 173,  # 'd'
+    101: 65,  # 'e'
+    102: 174,  # 'f'
+    103: 76,  # 'g'
+    104: 175,  # 'h'
+    105: 64,  # 'i'
+    106: 176,  # 'j'
+    107: 177,  # 'k'
+    108: 77,  # 'l'
+    109: 72,  # 'm'
+    110: 178,  # 'n'
+    111: 69,  # 'o'
+    112: 67,  # 'p'
+    113: 179,  # 'q'
+    114: 78,  # 'r'
+    115: 73,  # 's'
+    116: 180,  # 't'
+    117: 181,  # 'u'
+    118: 79,  # 'v'
+    119: 182,  # 'w'
+    120: 183,  # 'x'
+    121: 184,  # 'y'
+    122: 185,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 191,  # 'ђ'
+    129: 192,  # 'Ђ'
+    130: 193,  # 'ѓ'
+    131: 194,  # 'Ѓ'
+    132: 68,  # 'ё'
+    133: 195,  # 'Ё'
+    134: 196,  # 'є'
+    135: 197,  # 'Є'
+    136: 198,  # 'ѕ'
+    137: 199,  # 'Ѕ'
+    138: 200,  # 'і'
+    139: 201,  # 'І'
+    140: 202,  # 'ї'
+    141: 203,  # 'Ї'
+    142: 204,  # 'ј'
+    143: 205,  # 'Ј'
+    144: 206,  # 'љ'
+    145: 207,  # 'Љ'
+    146: 208,  # 'њ'
+    147: 209,  # 'Њ'
+    148: 210,  # 'ћ'
+    149: 211,  # 'Ћ'
+    150: 212,  # 'ќ'
+    151: 213,  # 'Ќ'
+    152: 214,  # 'ў'
+    153: 215,  # 'Ў'
+    154: 216,  # 'џ'
+    155: 217,  # 'Џ'
+    156: 27,  # 'ю'
+    157: 59,  # 'Ю'
+    158: 54,  # 'ъ'
+    159: 70,  # 'Ъ'
+    160: 3,  # 'а'
+    161: 37,  # 'А'
+    162: 21,  # 'б'
+    163: 44,  # 'Б'
+    164: 28,  # 'ц'
+    165: 58,  # 'Ц'
+    166: 13,  # 'д'
+    167: 41,  # 'Д'
+    168: 2,  # 'е'
+    169: 48,  # 'Е'
+    170: 39,  # 'ф'
+    171: 53,  # 'Ф'
+    172: 19,  # 'г'
+    173: 46,  # 'Г'
+    174: 218,  # '«'
+    175: 219,  # '»'
+    176: 220,  # '░'
+    177: 221,  # '▒'
+    178: 222,  # '▓'
+    179: 223,  # '│'
+    180: 224,  # '┤'
+    181: 26,  # 'х'
+    182: 55,  # 'Х'
+    183: 4,  # 'и'
+    184: 42,  # 'И'
+    185: 225,  # '╣'
+    186: 226,  # '║'
+    187: 227,  # '╗'
+    188: 228,  # '╝'
+    189: 23,  # 'й'
+    190: 60,  # 'Й'
+    191: 229,  # '┐'
+    192: 230,  # '└'
+    193: 231,  # '┴'
+    194: 232,  # '┬'
+    195: 233,  # '├'
+    196: 234,  # '─'
+    197: 235,  # '┼'
+    198: 11,  # 'к'
+    199: 36,  # 'К'
+    200: 236,  # '╚'
+    201: 237,  # '╔'
+    202: 238,  # '╩'
+    203: 239,  # '╦'
+    204: 240,  # '╠'
+    205: 241,  # '═'
+    206: 242,  # '╬'
+    207: 243,  # '¤'
+    208: 8,  # 'л'
+    209: 49,  # 'Л'
+    210: 12,  # 'м'
+    211: 38,  # 'М'
+    212: 5,  # 'н'
+    213: 31,  # 'Н'
+    214: 1,  # 'о'
+    215: 34,  # 'О'
+    216: 15,  # 'п'
+    217: 244,  # '┘'
+    218: 245,  # '┌'
+    219: 246,  # '█'
+    220: 247,  # '▄'
+    221: 35,  # 'П'
+    222: 16,  # 'я'
+    223: 248,  # '▀'
+    224: 43,  # 'Я'
+    225: 9,  # 'р'
+    226: 45,  # 'Р'
+    227: 7,  # 'с'
+    228: 32,  # 'С'
+    229: 6,  # 'т'
+    230: 40,  # 'Т'
+    231: 14,  # 'у'
+    232: 52,  # 'У'
+    233: 24,  # 'ж'
+    234: 56,  # 'Ж'
+    235: 10,  # 'в'
+    236: 33,  # 'В'
+    237: 17,  # 'ь'
+    238: 61,  # 'Ь'
+    239: 249,  # '№'
+    240: 250,  # '\xad'
+    241: 18,  # 'ы'
+    242: 62,  # 'Ы'
+    243: 20,  # 'з'
+    244: 51,  # 'З'
+    245: 25,  # 'ш'
+    246: 57,  # 'Ш'
+    247: 30,  # 'э'
+    248: 47,  # 'Э'
+    249: 29,  # 'щ'
+    250: 63,  # 'Щ'
+    251: 22,  # 'ч'
+    252: 50,  # 'Ч'
+    253: 251,  # '§'
+    254: 252,  # '■'
+    255: 255,  # '\xa0'
 }
 
-IBM855_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='IBM855',
-                                              language='Russian',
-                                              char_to_order_map=IBM855_RUSSIAN_CHAR_TO_ORDER,
-                                              language_model=RUSSIAN_LANG_MODEL,
-                                              typical_positive_ratio=0.976601,
-                                              keep_ascii_letters=False,
-                                              alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё')
+IBM855_RUSSIAN_MODEL = SingleByteCharSetModel(
+    charset_name="IBM855",
+    language="Russian",
+    char_to_order_map=IBM855_RUSSIAN_CHAR_TO_ORDER,
+    language_model=RUSSIAN_LANG_MODEL,
+    typical_positive_ratio=0.976601,
+    keep_ascii_letters=False,
+    alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё",
+)
 
 KOI8_R_RUSSIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 142,  # 'A'
-     66: 143,  # 'B'
-     67: 144,  # 'C'
-     68: 145,  # 'D'
-     69: 146,  # 'E'
-     70: 147,  # 'F'
-     71: 148,  # 'G'
-     72: 149,  # 'H'
-     73: 150,  # 'I'
-     74: 151,  # 'J'
-     75: 152,  # 'K'
-     76: 74,  # 'L'
-     77: 153,  # 'M'
-     78: 75,  # 'N'
-     79: 154,  # 'O'
-     80: 155,  # 'P'
-     81: 156,  # 'Q'
-     82: 157,  # 'R'
-     83: 158,  # 'S'
-     84: 159,  # 'T'
-     85: 160,  # 'U'
-     86: 161,  # 'V'
-     87: 162,  # 'W'
-     88: 163,  # 'X'
-     89: 164,  # 'Y'
-     90: 165,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 71,  # 'a'
-     98: 172,  # 'b'
-     99: 66,  # 'c'
-     100: 173,  # 'd'
-     101: 65,  # 'e'
-     102: 174,  # 'f'
-     103: 76,  # 'g'
-     104: 175,  # 'h'
-     105: 64,  # 'i'
-     106: 176,  # 'j'
-     107: 177,  # 'k'
-     108: 77,  # 'l'
-     109: 72,  # 'm'
-     110: 178,  # 'n'
-     111: 69,  # 'o'
-     112: 67,  # 'p'
-     113: 179,  # 'q'
-     114: 78,  # 'r'
-     115: 73,  # 's'
-     116: 180,  # 't'
-     117: 181,  # 'u'
-     118: 79,  # 'v'
-     119: 182,  # 'w'
-     120: 183,  # 'x'
-     121: 184,  # 'y'
-     122: 185,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 191,  # '─'
-     129: 192,  # '│'
-     130: 193,  # '┌'
-     131: 194,  # '┐'
-     132: 195,  # '└'
-     133: 196,  # '┘'
-     134: 197,  # '├'
-     135: 198,  # '┤'
-     136: 199,  # '┬'
-     137: 200,  # '┴'
-     138: 201,  # '┼'
-     139: 202,  # '▀'
-     140: 203,  # '▄'
-     141: 204,  # '█'
-     142: 205,  # '▌'
-     143: 206,  # '▐'
-     144: 207,  # '░'
-     145: 208,  # '▒'
-     146: 209,  # '▓'
-     147: 210,  # '⌠'
-     148: 211,  # '■'
-     149: 212,  # '∙'
-     150: 213,  # '√'
-     151: 214,  # '≈'
-     152: 215,  # '≤'
-     153: 216,  # '≥'
-     154: 217,  # '\xa0'
-     155: 218,  # '⌡'
-     156: 219,  # '°'
-     157: 220,  # '²'
-     158: 221,  # '·'
-     159: 222,  # '÷'
-     160: 223,  # '═'
-     161: 224,  # '║'
-     162: 225,  # '╒'
-     163: 68,  # 'ё'
-     164: 226,  # '╓'
-     165: 227,  # '╔'
-     166: 228,  # '╕'
-     167: 229,  # '╖'
-     168: 230,  # '╗'
-     169: 231,  # '╘'
-     170: 232,  # '╙'
-     171: 233,  # '╚'
-     172: 234,  # '╛'
-     173: 235,  # '╜'
-     174: 236,  # '╝'
-     175: 237,  # '╞'
-     176: 238,  # '╟'
-     177: 239,  # '╠'
-     178: 240,  # '╡'
-     179: 241,  # 'Ё'
-     180: 242,  # '╢'
-     181: 243,  # '╣'
-     182: 244,  # '╤'
-     183: 245,  # '╥'
-     184: 246,  # '╦'
-     185: 247,  # '╧'
-     186: 248,  # '╨'
-     187: 249,  # '╩'
-     188: 250,  # '╪'
-     189: 251,  # '╫'
-     190: 252,  # '╬'
-     191: 253,  # '©'
-     192: 27,  # 'ю'
-     193: 3,  # 'а'
-     194: 21,  # 'б'
-     195: 28,  # 'ц'
-     196: 13,  # 'д'
-     197: 2,  # 'е'
-     198: 39,  # 'ф'
-     199: 19,  # 'г'
-     200: 26,  # 'х'
-     201: 4,  # 'и'
-     202: 23,  # 'й'
-     203: 11,  # 'к'
-     204: 8,  # 'л'
-     205: 12,  # 'м'
-     206: 5,  # 'н'
-     207: 1,  # 'о'
-     208: 15,  # 'п'
-     209: 16,  # 'я'
-     210: 9,  # 'р'
-     211: 7,  # 'с'
-     212: 6,  # 'т'
-     213: 14,  # 'у'
-     214: 24,  # 'ж'
-     215: 10,  # 'в'
-     216: 17,  # 'ь'
-     217: 18,  # 'ы'
-     218: 20,  # 'з'
-     219: 25,  # 'ш'
-     220: 30,  # 'э'
-     221: 29,  # 'щ'
-     222: 22,  # 'ч'
-     223: 54,  # 'ъ'
-     224: 59,  # 'Ю'
-     225: 37,  # 'А'
-     226: 44,  # 'Б'
-     227: 58,  # 'Ц'
-     228: 41,  # 'Д'
-     229: 48,  # 'Е'
-     230: 53,  # 'Ф'
-     231: 46,  # 'Г'
-     232: 55,  # 'Х'
-     233: 42,  # 'И'
-     234: 60,  # 'Й'
-     235: 36,  # 'К'
-     236: 49,  # 'Л'
-     237: 38,  # 'М'
-     238: 31,  # 'Н'
-     239: 34,  # 'О'
-     240: 35,  # 'П'
-     241: 43,  # 'Я'
-     242: 45,  # 'Р'
-     243: 32,  # 'С'
-     244: 40,  # 'Т'
-     245: 52,  # 'У'
-     246: 56,  # 'Ж'
-     247: 33,  # 'В'
-     248: 61,  # 'Ь'
-     249: 62,  # 'Ы'
-     250: 51,  # 'З'
-     251: 57,  # 'Ш'
-     252: 47,  # 'Э'
-     253: 63,  # 'Щ'
-     254: 50,  # 'Ч'
-     255: 70,  # 'Ъ'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 142,  # 'A'
+    66: 143,  # 'B'
+    67: 144,  # 'C'
+    68: 145,  # 'D'
+    69: 146,  # 'E'
+    70: 147,  # 'F'
+    71: 148,  # 'G'
+    72: 149,  # 'H'
+    73: 150,  # 'I'
+    74: 151,  # 'J'
+    75: 152,  # 'K'
+    76: 74,  # 'L'
+    77: 153,  # 'M'
+    78: 75,  # 'N'
+    79: 154,  # 'O'
+    80: 155,  # 'P'
+    81: 156,  # 'Q'
+    82: 157,  # 'R'
+    83: 158,  # 'S'
+    84: 159,  # 'T'
+    85: 160,  # 'U'
+    86: 161,  # 'V'
+    87: 162,  # 'W'
+    88: 163,  # 'X'
+    89: 164,  # 'Y'
+    90: 165,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 71,  # 'a'
+    98: 172,  # 'b'
+    99: 66,  # 'c'
+    100: 173,  # 'd'
+    101: 65,  # 'e'
+    102: 174,  # 'f'
+    103: 76,  # 'g'
+    104: 175,  # 'h'
+    105: 64,  # 'i'
+    106: 176,  # 'j'
+    107: 177,  # 'k'
+    108: 77,  # 'l'
+    109: 72,  # 'm'
+    110: 178,  # 'n'
+    111: 69,  # 'o'
+    112: 67,  # 'p'
+    113: 179,  # 'q'
+    114: 78,  # 'r'
+    115: 73,  # 's'
+    116: 180,  # 't'
+    117: 181,  # 'u'
+    118: 79,  # 'v'
+    119: 182,  # 'w'
+    120: 183,  # 'x'
+    121: 184,  # 'y'
+    122: 185,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 191,  # '─'
+    129: 192,  # '│'
+    130: 193,  # '┌'
+    131: 194,  # '┐'
+    132: 195,  # '└'
+    133: 196,  # '┘'
+    134: 197,  # '├'
+    135: 198,  # '┤'
+    136: 199,  # '┬'
+    137: 200,  # '┴'
+    138: 201,  # '┼'
+    139: 202,  # '▀'
+    140: 203,  # '▄'
+    141: 204,  # '█'
+    142: 205,  # '▌'
+    143: 206,  # '▐'
+    144: 207,  # '░'
+    145: 208,  # '▒'
+    146: 209,  # '▓'
+    147: 210,  # '⌠'
+    148: 211,  # '■'
+    149: 212,  # '∙'
+    150: 213,  # '√'
+    151: 214,  # '≈'
+    152: 215,  # '≤'
+    153: 216,  # '≥'
+    154: 217,  # '\xa0'
+    155: 218,  # '⌡'
+    156: 219,  # '°'
+    157: 220,  # '²'
+    158: 221,  # '·'
+    159: 222,  # '÷'
+    160: 223,  # '═'
+    161: 224,  # '║'
+    162: 225,  # '╒'
+    163: 68,  # 'ё'
+    164: 226,  # '╓'
+    165: 227,  # '╔'
+    166: 228,  # '╕'
+    167: 229,  # '╖'
+    168: 230,  # '╗'
+    169: 231,  # '╘'
+    170: 232,  # '╙'
+    171: 233,  # '╚'
+    172: 234,  # '╛'
+    173: 235,  # '╜'
+    174: 236,  # '╝'
+    175: 237,  # '╞'
+    176: 238,  # '╟'
+    177: 239,  # '╠'
+    178: 240,  # '╡'
+    179: 241,  # 'Ё'
+    180: 242,  # '╢'
+    181: 243,  # '╣'
+    182: 244,  # '╤'
+    183: 245,  # '╥'
+    184: 246,  # '╦'
+    185: 247,  # '╧'
+    186: 248,  # '╨'
+    187: 249,  # '╩'
+    188: 250,  # '╪'
+    189: 251,  # '╫'
+    190: 252,  # '╬'
+    191: 253,  # '©'
+    192: 27,  # 'ю'
+    193: 3,  # 'а'
+    194: 21,  # 'б'
+    195: 28,  # 'ц'
+    196: 13,  # 'д'
+    197: 2,  # 'е'
+    198: 39,  # 'ф'
+    199: 19,  # 'г'
+    200: 26,  # 'х'
+    201: 4,  # 'и'
+    202: 23,  # 'й'
+    203: 11,  # 'к'
+    204: 8,  # 'л'
+    205: 12,  # 'м'
+    206: 5,  # 'н'
+    207: 1,  # 'о'
+    208: 15,  # 'п'
+    209: 16,  # 'я'
+    210: 9,  # 'р'
+    211: 7,  # 'с'
+    212: 6,  # 'т'
+    213: 14,  # 'у'
+    214: 24,  # 'ж'
+    215: 10,  # 'в'
+    216: 17,  # 'ь'
+    217: 18,  # 'ы'
+    218: 20,  # 'з'
+    219: 25,  # 'ш'
+    220: 30,  # 'э'
+    221: 29,  # 'щ'
+    222: 22,  # 'ч'
+    223: 54,  # 'ъ'
+    224: 59,  # 'Ю'
+    225: 37,  # 'А'
+    226: 44,  # 'Б'
+    227: 58,  # 'Ц'
+    228: 41,  # 'Д'
+    229: 48,  # 'Е'
+    230: 53,  # 'Ф'
+    231: 46,  # 'Г'
+    232: 55,  # 'Х'
+    233: 42,  # 'И'
+    234: 60,  # 'Й'
+    235: 36,  # 'К'
+    236: 49,  # 'Л'
+    237: 38,  # 'М'
+    238: 31,  # 'Н'
+    239: 34,  # 'О'
+    240: 35,  # 'П'
+    241: 43,  # 'Я'
+    242: 45,  # 'Р'
+    243: 32,  # 'С'
+    244: 40,  # 'Т'
+    245: 52,  # 'У'
+    246: 56,  # 'Ж'
+    247: 33,  # 'В'
+    248: 61,  # 'Ь'
+    249: 62,  # 'Ы'
+    250: 51,  # 'З'
+    251: 57,  # 'Ш'
+    252: 47,  # 'Э'
+    253: 63,  # 'Щ'
+    254: 50,  # 'Ч'
+    255: 70,  # 'Ъ'
 }
 
-KOI8_R_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='KOI8-R',
-                                              language='Russian',
-                                              char_to_order_map=KOI8_R_RUSSIAN_CHAR_TO_ORDER,
-                                              language_model=RUSSIAN_LANG_MODEL,
-                                              typical_positive_ratio=0.976601,
-                                              keep_ascii_letters=False,
-                                              alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё')
+KOI8_R_RUSSIAN_MODEL = SingleByteCharSetModel(
+    charset_name="KOI8-R",
+    language="Russian",
+    char_to_order_map=KOI8_R_RUSSIAN_CHAR_TO_ORDER,
+    language_model=RUSSIAN_LANG_MODEL,
+    typical_positive_ratio=0.976601,
+    keep_ascii_letters=False,
+    alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё",
+)
 
 MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 142,  # 'A'
-     66: 143,  # 'B'
-     67: 144,  # 'C'
-     68: 145,  # 'D'
-     69: 146,  # 'E'
-     70: 147,  # 'F'
-     71: 148,  # 'G'
-     72: 149,  # 'H'
-     73: 150,  # 'I'
-     74: 151,  # 'J'
-     75: 152,  # 'K'
-     76: 74,  # 'L'
-     77: 153,  # 'M'
-     78: 75,  # 'N'
-     79: 154,  # 'O'
-     80: 155,  # 'P'
-     81: 156,  # 'Q'
-     82: 157,  # 'R'
-     83: 158,  # 'S'
-     84: 159,  # 'T'
-     85: 160,  # 'U'
-     86: 161,  # 'V'
-     87: 162,  # 'W'
-     88: 163,  # 'X'
-     89: 164,  # 'Y'
-     90: 165,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 71,  # 'a'
-     98: 172,  # 'b'
-     99: 66,  # 'c'
-     100: 173,  # 'd'
-     101: 65,  # 'e'
-     102: 174,  # 'f'
-     103: 76,  # 'g'
-     104: 175,  # 'h'
-     105: 64,  # 'i'
-     106: 176,  # 'j'
-     107: 177,  # 'k'
-     108: 77,  # 'l'
-     109: 72,  # 'm'
-     110: 178,  # 'n'
-     111: 69,  # 'o'
-     112: 67,  # 'p'
-     113: 179,  # 'q'
-     114: 78,  # 'r'
-     115: 73,  # 's'
-     116: 180,  # 't'
-     117: 181,  # 'u'
-     118: 79,  # 'v'
-     119: 182,  # 'w'
-     120: 183,  # 'x'
-     121: 184,  # 'y'
-     122: 185,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 37,  # 'А'
-     129: 44,  # 'Б'
-     130: 33,  # 'В'
-     131: 46,  # 'Г'
-     132: 41,  # 'Д'
-     133: 48,  # 'Е'
-     134: 56,  # 'Ж'
-     135: 51,  # 'З'
-     136: 42,  # 'И'
-     137: 60,  # 'Й'
-     138: 36,  # 'К'
-     139: 49,  # 'Л'
-     140: 38,  # 'М'
-     141: 31,  # 'Н'
-     142: 34,  # 'О'
-     143: 35,  # 'П'
-     144: 45,  # 'Р'
-     145: 32,  # 'С'
-     146: 40,  # 'Т'
-     147: 52,  # 'У'
-     148: 53,  # 'Ф'
-     149: 55,  # 'Х'
-     150: 58,  # 'Ц'
-     151: 50,  # 'Ч'
-     152: 57,  # 'Ш'
-     153: 63,  # 'Щ'
-     154: 70,  # 'Ъ'
-     155: 62,  # 'Ы'
-     156: 61,  # 'Ь'
-     157: 47,  # 'Э'
-     158: 59,  # 'Ю'
-     159: 43,  # 'Я'
-     160: 191,  # '†'
-     161: 192,  # '°'
-     162: 193,  # 'Ґ'
-     163: 194,  # '£'
-     164: 195,  # '§'
-     165: 196,  # '•'
-     166: 197,  # '¶'
-     167: 198,  # 'І'
-     168: 199,  # '®'
-     169: 200,  # '©'
-     170: 201,  # '™'
-     171: 202,  # 'Ђ'
-     172: 203,  # 'ђ'
-     173: 204,  # '≠'
-     174: 205,  # 'Ѓ'
-     175: 206,  # 'ѓ'
-     176: 207,  # '∞'
-     177: 208,  # '±'
-     178: 209,  # '≤'
-     179: 210,  # '≥'
-     180: 211,  # 'і'
-     181: 212,  # 'µ'
-     182: 213,  # 'ґ'
-     183: 214,  # 'Ј'
-     184: 215,  # 'Є'
-     185: 216,  # 'є'
-     186: 217,  # 'Ї'
-     187: 218,  # 'ї'
-     188: 219,  # 'Љ'
-     189: 220,  # 'љ'
-     190: 221,  # 'Њ'
-     191: 222,  # 'њ'
-     192: 223,  # 'ј'
-     193: 224,  # 'Ѕ'
-     194: 225,  # '¬'
-     195: 226,  # '√'
-     196: 227,  # 'ƒ'
-     197: 228,  # '≈'
-     198: 229,  # '∆'
-     199: 230,  # '«'
-     200: 231,  # '»'
-     201: 232,  # '…'
-     202: 233,  # '\xa0'
-     203: 234,  # 'Ћ'
-     204: 235,  # 'ћ'
-     205: 236,  # 'Ќ'
-     206: 237,  # 'ќ'
-     207: 238,  # 'ѕ'
-     208: 239,  # '–'
-     209: 240,  # '—'
-     210: 241,  # '“'
-     211: 242,  # '”'
-     212: 243,  # '‘'
-     213: 244,  # '’'
-     214: 245,  # '÷'
-     215: 246,  # '„'
-     216: 247,  # 'Ў'
-     217: 248,  # 'ў'
-     218: 249,  # 'Џ'
-     219: 250,  # 'џ'
-     220: 251,  # '№'
-     221: 252,  # 'Ё'
-     222: 68,  # 'ё'
-     223: 16,  # 'я'
-     224: 3,  # 'а'
-     225: 21,  # 'б'
-     226: 10,  # 'в'
-     227: 19,  # 'г'
-     228: 13,  # 'д'
-     229: 2,  # 'е'
-     230: 24,  # 'ж'
-     231: 20,  # 'з'
-     232: 4,  # 'и'
-     233: 23,  # 'й'
-     234: 11,  # 'к'
-     235: 8,  # 'л'
-     236: 12,  # 'м'
-     237: 5,  # 'н'
-     238: 1,  # 'о'
-     239: 15,  # 'п'
-     240: 9,  # 'р'
-     241: 7,  # 'с'
-     242: 6,  # 'т'
-     243: 14,  # 'у'
-     244: 39,  # 'ф'
-     245: 26,  # 'х'
-     246: 28,  # 'ц'
-     247: 22,  # 'ч'
-     248: 25,  # 'ш'
-     249: 29,  # 'щ'
-     250: 54,  # 'ъ'
-     251: 18,  # 'ы'
-     252: 17,  # 'ь'
-     253: 30,  # 'э'
-     254: 27,  # 'ю'
-     255: 255,  # '€'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 142,  # 'A'
+    66: 143,  # 'B'
+    67: 144,  # 'C'
+    68: 145,  # 'D'
+    69: 146,  # 'E'
+    70: 147,  # 'F'
+    71: 148,  # 'G'
+    72: 149,  # 'H'
+    73: 150,  # 'I'
+    74: 151,  # 'J'
+    75: 152,  # 'K'
+    76: 74,  # 'L'
+    77: 153,  # 'M'
+    78: 75,  # 'N'
+    79: 154,  # 'O'
+    80: 155,  # 'P'
+    81: 156,  # 'Q'
+    82: 157,  # 'R'
+    83: 158,  # 'S'
+    84: 159,  # 'T'
+    85: 160,  # 'U'
+    86: 161,  # 'V'
+    87: 162,  # 'W'
+    88: 163,  # 'X'
+    89: 164,  # 'Y'
+    90: 165,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 71,  # 'a'
+    98: 172,  # 'b'
+    99: 66,  # 'c'
+    100: 173,  # 'd'
+    101: 65,  # 'e'
+    102: 174,  # 'f'
+    103: 76,  # 'g'
+    104: 175,  # 'h'
+    105: 64,  # 'i'
+    106: 176,  # 'j'
+    107: 177,  # 'k'
+    108: 77,  # 'l'
+    109: 72,  # 'm'
+    110: 178,  # 'n'
+    111: 69,  # 'o'
+    112: 67,  # 'p'
+    113: 179,  # 'q'
+    114: 78,  # 'r'
+    115: 73,  # 's'
+    116: 180,  # 't'
+    117: 181,  # 'u'
+    118: 79,  # 'v'
+    119: 182,  # 'w'
+    120: 183,  # 'x'
+    121: 184,  # 'y'
+    122: 185,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 37,  # 'А'
+    129: 44,  # 'Б'
+    130: 33,  # 'В'
+    131: 46,  # 'Г'
+    132: 41,  # 'Д'
+    133: 48,  # 'Е'
+    134: 56,  # 'Ж'
+    135: 51,  # 'З'
+    136: 42,  # 'И'
+    137: 60,  # 'Й'
+    138: 36,  # 'К'
+    139: 49,  # 'Л'
+    140: 38,  # 'М'
+    141: 31,  # 'Н'
+    142: 34,  # 'О'
+    143: 35,  # 'П'
+    144: 45,  # 'Р'
+    145: 32,  # 'С'
+    146: 40,  # 'Т'
+    147: 52,  # 'У'
+    148: 53,  # 'Ф'
+    149: 55,  # 'Х'
+    150: 58,  # 'Ц'
+    151: 50,  # 'Ч'
+    152: 57,  # 'Ш'
+    153: 63,  # 'Щ'
+    154: 70,  # 'Ъ'
+    155: 62,  # 'Ы'
+    156: 61,  # 'Ь'
+    157: 47,  # 'Э'
+    158: 59,  # 'Ю'
+    159: 43,  # 'Я'
+    160: 191,  # '†'
+    161: 192,  # '°'
+    162: 193,  # 'Ґ'
+    163: 194,  # '£'
+    164: 195,  # '§'
+    165: 196,  # '•'
+    166: 197,  # '¶'
+    167: 198,  # 'І'
+    168: 199,  # '®'
+    169: 200,  # '©'
+    170: 201,  # '™'
+    171: 202,  # 'Ђ'
+    172: 203,  # 'ђ'
+    173: 204,  # '≠'
+    174: 205,  # 'Ѓ'
+    175: 206,  # 'ѓ'
+    176: 207,  # '∞'
+    177: 208,  # '±'
+    178: 209,  # '≤'
+    179: 210,  # '≥'
+    180: 211,  # 'і'
+    181: 212,  # 'µ'
+    182: 213,  # 'ґ'
+    183: 214,  # 'Ј'
+    184: 215,  # 'Є'
+    185: 216,  # 'є'
+    186: 217,  # 'Ї'
+    187: 218,  # 'ї'
+    188: 219,  # 'Љ'
+    189: 220,  # 'љ'
+    190: 221,  # 'Њ'
+    191: 222,  # 'њ'
+    192: 223,  # 'ј'
+    193: 224,  # 'Ѕ'
+    194: 225,  # '¬'
+    195: 226,  # '√'
+    196: 227,  # 'ƒ'
+    197: 228,  # '≈'
+    198: 229,  # '∆'
+    199: 230,  # '«'
+    200: 231,  # '»'
+    201: 232,  # '…'
+    202: 233,  # '\xa0'
+    203: 234,  # 'Ћ'
+    204: 235,  # 'ћ'
+    205: 236,  # 'Ќ'
+    206: 237,  # 'ќ'
+    207: 238,  # 'ѕ'
+    208: 239,  # '–'
+    209: 240,  # '—'
+    210: 241,  # '“'
+    211: 242,  # '”'
+    212: 243,  # '‘'
+    213: 244,  # '’'
+    214: 245,  # '÷'
+    215: 246,  # '„'
+    216: 247,  # 'Ў'
+    217: 248,  # 'ў'
+    218: 249,  # 'Џ'
+    219: 250,  # 'џ'
+    220: 251,  # '№'
+    221: 252,  # 'Ё'
+    222: 68,  # 'ё'
+    223: 16,  # 'я'
+    224: 3,  # 'а'
+    225: 21,  # 'б'
+    226: 10,  # 'в'
+    227: 19,  # 'г'
+    228: 13,  # 'д'
+    229: 2,  # 'е'
+    230: 24,  # 'ж'
+    231: 20,  # 'з'
+    232: 4,  # 'и'
+    233: 23,  # 'й'
+    234: 11,  # 'к'
+    235: 8,  # 'л'
+    236: 12,  # 'м'
+    237: 5,  # 'н'
+    238: 1,  # 'о'
+    239: 15,  # 'п'
+    240: 9,  # 'р'
+    241: 7,  # 'с'
+    242: 6,  # 'т'
+    243: 14,  # 'у'
+    244: 39,  # 'ф'
+    245: 26,  # 'х'
+    246: 28,  # 'ц'
+    247: 22,  # 'ч'
+    248: 25,  # 'ш'
+    249: 29,  # 'щ'
+    250: 54,  # 'ъ'
+    251: 18,  # 'ы'
+    252: 17,  # 'ь'
+    253: 30,  # 'э'
+    254: 27,  # 'ю'
+    255: 255,  # '€'
 }
 
-MACCYRILLIC_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='MacCyrillic',
-                                                   language='Russian',
-                                                   char_to_order_map=MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER,
-                                                   language_model=RUSSIAN_LANG_MODEL,
-                                                   typical_positive_ratio=0.976601,
-                                                   keep_ascii_letters=False,
-                                                   alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё')
+MACCYRILLIC_RUSSIAN_MODEL = SingleByteCharSetModel(
+    charset_name="MacCyrillic",
+    language="Russian",
+    char_to_order_map=MACCYRILLIC_RUSSIAN_CHAR_TO_ORDER,
+    language_model=RUSSIAN_LANG_MODEL,
+    typical_positive_ratio=0.976601,
+    keep_ascii_letters=False,
+    alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё",
+)
 
 ISO_8859_5_RUSSIAN_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 142,  # 'A'
-     66: 143,  # 'B'
-     67: 144,  # 'C'
-     68: 145,  # 'D'
-     69: 146,  # 'E'
-     70: 147,  # 'F'
-     71: 148,  # 'G'
-     72: 149,  # 'H'
-     73: 150,  # 'I'
-     74: 151,  # 'J'
-     75: 152,  # 'K'
-     76: 74,  # 'L'
-     77: 153,  # 'M'
-     78: 75,  # 'N'
-     79: 154,  # 'O'
-     80: 155,  # 'P'
-     81: 156,  # 'Q'
-     82: 157,  # 'R'
-     83: 158,  # 'S'
-     84: 159,  # 'T'
-     85: 160,  # 'U'
-     86: 161,  # 'V'
-     87: 162,  # 'W'
-     88: 163,  # 'X'
-     89: 164,  # 'Y'
-     90: 165,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 71,  # 'a'
-     98: 172,  # 'b'
-     99: 66,  # 'c'
-     100: 173,  # 'd'
-     101: 65,  # 'e'
-     102: 174,  # 'f'
-     103: 76,  # 'g'
-     104: 175,  # 'h'
-     105: 64,  # 'i'
-     106: 176,  # 'j'
-     107: 177,  # 'k'
-     108: 77,  # 'l'
-     109: 72,  # 'm'
-     110: 178,  # 'n'
-     111: 69,  # 'o'
-     112: 67,  # 'p'
-     113: 179,  # 'q'
-     114: 78,  # 'r'
-     115: 73,  # 's'
-     116: 180,  # 't'
-     117: 181,  # 'u'
-     118: 79,  # 'v'
-     119: 182,  # 'w'
-     120: 183,  # 'x'
-     121: 184,  # 'y'
-     122: 185,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 191,  # '\x80'
-     129: 192,  # '\x81'
-     130: 193,  # '\x82'
-     131: 194,  # '\x83'
-     132: 195,  # '\x84'
-     133: 196,  # '\x85'
-     134: 197,  # '\x86'
-     135: 198,  # '\x87'
-     136: 199,  # '\x88'
-     137: 200,  # '\x89'
-     138: 201,  # '\x8a'
-     139: 202,  # '\x8b'
-     140: 203,  # '\x8c'
-     141: 204,  # '\x8d'
-     142: 205,  # '\x8e'
-     143: 206,  # '\x8f'
-     144: 207,  # '\x90'
-     145: 208,  # '\x91'
-     146: 209,  # '\x92'
-     147: 210,  # '\x93'
-     148: 211,  # '\x94'
-     149: 212,  # '\x95'
-     150: 213,  # '\x96'
-     151: 214,  # '\x97'
-     152: 215,  # '\x98'
-     153: 216,  # '\x99'
-     154: 217,  # '\x9a'
-     155: 218,  # '\x9b'
-     156: 219,  # '\x9c'
-     157: 220,  # '\x9d'
-     158: 221,  # '\x9e'
-     159: 222,  # '\x9f'
-     160: 223,  # '\xa0'
-     161: 224,  # 'Ё'
-     162: 225,  # 'Ђ'
-     163: 226,  # 'Ѓ'
-     164: 227,  # 'Є'
-     165: 228,  # 'Ѕ'
-     166: 229,  # 'І'
-     167: 230,  # 'Ї'
-     168: 231,  # 'Ј'
-     169: 232,  # 'Љ'
-     170: 233,  # 'Њ'
-     171: 234,  # 'Ћ'
-     172: 235,  # 'Ќ'
-     173: 236,  # '\xad'
-     174: 237,  # 'Ў'
-     175: 238,  # 'Џ'
-     176: 37,  # 'А'
-     177: 44,  # 'Б'
-     178: 33,  # 'В'
-     179: 46,  # 'Г'
-     180: 41,  # 'Д'
-     181: 48,  # 'Е'
-     182: 56,  # 'Ж'
-     183: 51,  # 'З'
-     184: 42,  # 'И'
-     185: 60,  # 'Й'
-     186: 36,  # 'К'
-     187: 49,  # 'Л'
-     188: 38,  # 'М'
-     189: 31,  # 'Н'
-     190: 34,  # 'О'
-     191: 35,  # 'П'
-     192: 45,  # 'Р'
-     193: 32,  # 'С'
-     194: 40,  # 'Т'
-     195: 52,  # 'У'
-     196: 53,  # 'Ф'
-     197: 55,  # 'Х'
-     198: 58,  # 'Ц'
-     199: 50,  # 'Ч'
-     200: 57,  # 'Ш'
-     201: 63,  # 'Щ'
-     202: 70,  # 'Ъ'
-     203: 62,  # 'Ы'
-     204: 61,  # 'Ь'
-     205: 47,  # 'Э'
-     206: 59,  # 'Ю'
-     207: 43,  # 'Я'
-     208: 3,  # 'а'
-     209: 21,  # 'б'
-     210: 10,  # 'в'
-     211: 19,  # 'г'
-     212: 13,  # 'д'
-     213: 2,  # 'е'
-     214: 24,  # 'ж'
-     215: 20,  # 'з'
-     216: 4,  # 'и'
-     217: 23,  # 'й'
-     218: 11,  # 'к'
-     219: 8,  # 'л'
-     220: 12,  # 'м'
-     221: 5,  # 'н'
-     222: 1,  # 'о'
-     223: 15,  # 'п'
-     224: 9,  # 'р'
-     225: 7,  # 'с'
-     226: 6,  # 'т'
-     227: 14,  # 'у'
-     228: 39,  # 'ф'
-     229: 26,  # 'х'
-     230: 28,  # 'ц'
-     231: 22,  # 'ч'
-     232: 25,  # 'ш'
-     233: 29,  # 'щ'
-     234: 54,  # 'ъ'
-     235: 18,  # 'ы'
-     236: 17,  # 'ь'
-     237: 30,  # 'э'
-     238: 27,  # 'ю'
-     239: 16,  # 'я'
-     240: 239,  # '№'
-     241: 68,  # 'ё'
-     242: 240,  # 'ђ'
-     243: 241,  # 'ѓ'
-     244: 242,  # 'є'
-     245: 243,  # 'ѕ'
-     246: 244,  # 'і'
-     247: 245,  # 'ї'
-     248: 246,  # 'ј'
-     249: 247,  # 'љ'
-     250: 248,  # 'њ'
-     251: 249,  # 'ћ'
-     252: 250,  # 'ќ'
-     253: 251,  # '§'
-     254: 252,  # 'ў'
-     255: 255,  # 'џ'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 142,  # 'A'
+    66: 143,  # 'B'
+    67: 144,  # 'C'
+    68: 145,  # 'D'
+    69: 146,  # 'E'
+    70: 147,  # 'F'
+    71: 148,  # 'G'
+    72: 149,  # 'H'
+    73: 150,  # 'I'
+    74: 151,  # 'J'
+    75: 152,  # 'K'
+    76: 74,  # 'L'
+    77: 153,  # 'M'
+    78: 75,  # 'N'
+    79: 154,  # 'O'
+    80: 155,  # 'P'
+    81: 156,  # 'Q'
+    82: 157,  # 'R'
+    83: 158,  # 'S'
+    84: 159,  # 'T'
+    85: 160,  # 'U'
+    86: 161,  # 'V'
+    87: 162,  # 'W'
+    88: 163,  # 'X'
+    89: 164,  # 'Y'
+    90: 165,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 71,  # 'a'
+    98: 172,  # 'b'
+    99: 66,  # 'c'
+    100: 173,  # 'd'
+    101: 65,  # 'e'
+    102: 174,  # 'f'
+    103: 76,  # 'g'
+    104: 175,  # 'h'
+    105: 64,  # 'i'
+    106: 176,  # 'j'
+    107: 177,  # 'k'
+    108: 77,  # 'l'
+    109: 72,  # 'm'
+    110: 178,  # 'n'
+    111: 69,  # 'o'
+    112: 67,  # 'p'
+    113: 179,  # 'q'
+    114: 78,  # 'r'
+    115: 73,  # 's'
+    116: 180,  # 't'
+    117: 181,  # 'u'
+    118: 79,  # 'v'
+    119: 182,  # 'w'
+    120: 183,  # 'x'
+    121: 184,  # 'y'
+    122: 185,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 191,  # '\x80'
+    129: 192,  # '\x81'
+    130: 193,  # '\x82'
+    131: 194,  # '\x83'
+    132: 195,  # '\x84'
+    133: 196,  # '\x85'
+    134: 197,  # '\x86'
+    135: 198,  # '\x87'
+    136: 199,  # '\x88'
+    137: 200,  # '\x89'
+    138: 201,  # '\x8a'
+    139: 202,  # '\x8b'
+    140: 203,  # '\x8c'
+    141: 204,  # '\x8d'
+    142: 205,  # '\x8e'
+    143: 206,  # '\x8f'
+    144: 207,  # '\x90'
+    145: 208,  # '\x91'
+    146: 209,  # '\x92'
+    147: 210,  # '\x93'
+    148: 211,  # '\x94'
+    149: 212,  # '\x95'
+    150: 213,  # '\x96'
+    151: 214,  # '\x97'
+    152: 215,  # '\x98'
+    153: 216,  # '\x99'
+    154: 217,  # '\x9a'
+    155: 218,  # '\x9b'
+    156: 219,  # '\x9c'
+    157: 220,  # '\x9d'
+    158: 221,  # '\x9e'
+    159: 222,  # '\x9f'
+    160: 223,  # '\xa0'
+    161: 224,  # 'Ё'
+    162: 225,  # 'Ђ'
+    163: 226,  # 'Ѓ'
+    164: 227,  # 'Є'
+    165: 228,  # 'Ѕ'
+    166: 229,  # 'І'
+    167: 230,  # 'Ї'
+    168: 231,  # 'Ј'
+    169: 232,  # 'Љ'
+    170: 233,  # 'Њ'
+    171: 234,  # 'Ћ'
+    172: 235,  # 'Ќ'
+    173: 236,  # '\xad'
+    174: 237,  # 'Ў'
+    175: 238,  # 'Џ'
+    176: 37,  # 'А'
+    177: 44,  # 'Б'
+    178: 33,  # 'В'
+    179: 46,  # 'Г'
+    180: 41,  # 'Д'
+    181: 48,  # 'Е'
+    182: 56,  # 'Ж'
+    183: 51,  # 'З'
+    184: 42,  # 'И'
+    185: 60,  # 'Й'
+    186: 36,  # 'К'
+    187: 49,  # 'Л'
+    188: 38,  # 'М'
+    189: 31,  # 'Н'
+    190: 34,  # 'О'
+    191: 35,  # 'П'
+    192: 45,  # 'Р'
+    193: 32,  # 'С'
+    194: 40,  # 'Т'
+    195: 52,  # 'У'
+    196: 53,  # 'Ф'
+    197: 55,  # 'Х'
+    198: 58,  # 'Ц'
+    199: 50,  # 'Ч'
+    200: 57,  # 'Ш'
+    201: 63,  # 'Щ'
+    202: 70,  # 'Ъ'
+    203: 62,  # 'Ы'
+    204: 61,  # 'Ь'
+    205: 47,  # 'Э'
+    206: 59,  # 'Ю'
+    207: 43,  # 'Я'
+    208: 3,  # 'а'
+    209: 21,  # 'б'
+    210: 10,  # 'в'
+    211: 19,  # 'г'
+    212: 13,  # 'д'
+    213: 2,  # 'е'
+    214: 24,  # 'ж'
+    215: 20,  # 'з'
+    216: 4,  # 'и'
+    217: 23,  # 'й'
+    218: 11,  # 'к'
+    219: 8,  # 'л'
+    220: 12,  # 'м'
+    221: 5,  # 'н'
+    222: 1,  # 'о'
+    223: 15,  # 'п'
+    224: 9,  # 'р'
+    225: 7,  # 'с'
+    226: 6,  # 'т'
+    227: 14,  # 'у'
+    228: 39,  # 'ф'
+    229: 26,  # 'х'
+    230: 28,  # 'ц'
+    231: 22,  # 'ч'
+    232: 25,  # 'ш'
+    233: 29,  # 'щ'
+    234: 54,  # 'ъ'
+    235: 18,  # 'ы'
+    236: 17,  # 'ь'
+    237: 30,  # 'э'
+    238: 27,  # 'ю'
+    239: 16,  # 'я'
+    240: 239,  # '№'
+    241: 68,  # 'ё'
+    242: 240,  # 'ђ'
+    243: 241,  # 'ѓ'
+    244: 242,  # 'є'
+    245: 243,  # 'ѕ'
+    246: 244,  # 'і'
+    247: 245,  # 'ї'
+    248: 246,  # 'ј'
+    249: 247,  # 'љ'
+    250: 248,  # 'њ'
+    251: 249,  # 'ћ'
+    252: 250,  # 'ќ'
+    253: 251,  # '§'
+    254: 252,  # 'ў'
+    255: 255,  # 'џ'
 }
 
-ISO_8859_5_RUSSIAN_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-5',
-                                                  language='Russian',
-                                                  char_to_order_map=ISO_8859_5_RUSSIAN_CHAR_TO_ORDER,
-                                                  language_model=RUSSIAN_LANG_MODEL,
-                                                  typical_positive_ratio=0.976601,
-                                                  keep_ascii_letters=False,
-                                                  alphabet='ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё')
-
+ISO_8859_5_RUSSIAN_MODEL = SingleByteCharSetModel(
+    charset_name="ISO-8859-5",
+    language="Russian",
+    char_to_order_map=ISO_8859_5_RUSSIAN_CHAR_TO_ORDER,
+    language_model=RUSSIAN_LANG_MODEL,
+    typical_positive_ratio=0.976601,
+    keep_ascii_letters=False,
+    alphabet="ЁАБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдежзийклмнопрстуфхцчшщъыьэюяё",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py
index 9a37db57..489cad93 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langthaimodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -4115,269 +4111,270 @@ THAI_LANG_MODEL = {
 
 # Character Mapping Table(s):
 TIS_620_THAI_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 254,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 254,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 253,  # ' '
-     33: 253,  # '!'
-     34: 253,  # '"'
-     35: 253,  # '#'
-     36: 253,  # '$'
-     37: 253,  # '%'
-     38: 253,  # '&'
-     39: 253,  # "'"
-     40: 253,  # '('
-     41: 253,  # ')'
-     42: 253,  # '*'
-     43: 253,  # '+'
-     44: 253,  # ','
-     45: 253,  # '-'
-     46: 253,  # '.'
-     47: 253,  # '/'
-     48: 252,  # '0'
-     49: 252,  # '1'
-     50: 252,  # '2'
-     51: 252,  # '3'
-     52: 252,  # '4'
-     53: 252,  # '5'
-     54: 252,  # '6'
-     55: 252,  # '7'
-     56: 252,  # '8'
-     57: 252,  # '9'
-     58: 253,  # ':'
-     59: 253,  # ';'
-     60: 253,  # '<'
-     61: 253,  # '='
-     62: 253,  # '>'
-     63: 253,  # '?'
-     64: 253,  # '@'
-     65: 182,  # 'A'
-     66: 106,  # 'B'
-     67: 107,  # 'C'
-     68: 100,  # 'D'
-     69: 183,  # 'E'
-     70: 184,  # 'F'
-     71: 185,  # 'G'
-     72: 101,  # 'H'
-     73: 94,  # 'I'
-     74: 186,  # 'J'
-     75: 187,  # 'K'
-     76: 108,  # 'L'
-     77: 109,  # 'M'
-     78: 110,  # 'N'
-     79: 111,  # 'O'
-     80: 188,  # 'P'
-     81: 189,  # 'Q'
-     82: 190,  # 'R'
-     83: 89,  # 'S'
-     84: 95,  # 'T'
-     85: 112,  # 'U'
-     86: 113,  # 'V'
-     87: 191,  # 'W'
-     88: 192,  # 'X'
-     89: 193,  # 'Y'
-     90: 194,  # 'Z'
-     91: 253,  # '['
-     92: 253,  # '\\'
-     93: 253,  # ']'
-     94: 253,  # '^'
-     95: 253,  # '_'
-     96: 253,  # '`'
-     97: 64,  # 'a'
-     98: 72,  # 'b'
-     99: 73,  # 'c'
-     100: 114,  # 'd'
-     101: 74,  # 'e'
-     102: 115,  # 'f'
-     103: 116,  # 'g'
-     104: 102,  # 'h'
-     105: 81,  # 'i'
-     106: 201,  # 'j'
-     107: 117,  # 'k'
-     108: 90,  # 'l'
-     109: 103,  # 'm'
-     110: 78,  # 'n'
-     111: 82,  # 'o'
-     112: 96,  # 'p'
-     113: 202,  # 'q'
-     114: 91,  # 'r'
-     115: 79,  # 's'
-     116: 84,  # 't'
-     117: 104,  # 'u'
-     118: 105,  # 'v'
-     119: 97,  # 'w'
-     120: 98,  # 'x'
-     121: 92,  # 'y'
-     122: 203,  # 'z'
-     123: 253,  # '{'
-     124: 253,  # '|'
-     125: 253,  # '}'
-     126: 253,  # '~'
-     127: 253,  # '\x7f'
-     128: 209,  # '\x80'
-     129: 210,  # '\x81'
-     130: 211,  # '\x82'
-     131: 212,  # '\x83'
-     132: 213,  # '\x84'
-     133: 88,  # '\x85'
-     134: 214,  # '\x86'
-     135: 215,  # '\x87'
-     136: 216,  # '\x88'
-     137: 217,  # '\x89'
-     138: 218,  # '\x8a'
-     139: 219,  # '\x8b'
-     140: 220,  # '\x8c'
-     141: 118,  # '\x8d'
-     142: 221,  # '\x8e'
-     143: 222,  # '\x8f'
-     144: 223,  # '\x90'
-     145: 224,  # '\x91'
-     146: 99,  # '\x92'
-     147: 85,  # '\x93'
-     148: 83,  # '\x94'
-     149: 225,  # '\x95'
-     150: 226,  # '\x96'
-     151: 227,  # '\x97'
-     152: 228,  # '\x98'
-     153: 229,  # '\x99'
-     154: 230,  # '\x9a'
-     155: 231,  # '\x9b'
-     156: 232,  # '\x9c'
-     157: 233,  # '\x9d'
-     158: 234,  # '\x9e'
-     159: 235,  # '\x9f'
-     160: 236,  # None
-     161: 5,  # 'ก'
-     162: 30,  # 'ข'
-     163: 237,  # 'ฃ'
-     164: 24,  # 'ค'
-     165: 238,  # 'ฅ'
-     166: 75,  # 'ฆ'
-     167: 8,  # 'ง'
-     168: 26,  # 'จ'
-     169: 52,  # 'ฉ'
-     170: 34,  # 'ช'
-     171: 51,  # 'ซ'
-     172: 119,  # 'ฌ'
-     173: 47,  # 'ญ'
-     174: 58,  # 'ฎ'
-     175: 57,  # 'ฏ'
-     176: 49,  # 'ฐ'
-     177: 53,  # 'ฑ'
-     178: 55,  # 'ฒ'
-     179: 43,  # 'ณ'
-     180: 20,  # 'ด'
-     181: 19,  # 'ต'
-     182: 44,  # 'ถ'
-     183: 14,  # 'ท'
-     184: 48,  # 'ธ'
-     185: 3,  # 'น'
-     186: 17,  # 'บ'
-     187: 25,  # 'ป'
-     188: 39,  # 'ผ'
-     189: 62,  # 'ฝ'
-     190: 31,  # 'พ'
-     191: 54,  # 'ฟ'
-     192: 45,  # 'ภ'
-     193: 9,  # 'ม'
-     194: 16,  # 'ย'
-     195: 2,  # 'ร'
-     196: 61,  # 'ฤ'
-     197: 15,  # 'ล'
-     198: 239,  # 'ฦ'
-     199: 12,  # 'ว'
-     200: 42,  # 'ศ'
-     201: 46,  # 'ษ'
-     202: 18,  # 'ส'
-     203: 21,  # 'ห'
-     204: 76,  # 'ฬ'
-     205: 4,  # 'อ'
-     206: 66,  # 'ฮ'
-     207: 63,  # 'ฯ'
-     208: 22,  # 'ะ'
-     209: 10,  # 'ั'
-     210: 1,  # 'า'
-     211: 36,  # 'ำ'
-     212: 23,  # 'ิ'
-     213: 13,  # 'ี'
-     214: 40,  # 'ึ'
-     215: 27,  # 'ื'
-     216: 32,  # 'ุ'
-     217: 35,  # 'ู'
-     218: 86,  # 'ฺ'
-     219: 240,  # None
-     220: 241,  # None
-     221: 242,  # None
-     222: 243,  # None
-     223: 244,  # '฿'
-     224: 11,  # 'เ'
-     225: 28,  # 'แ'
-     226: 41,  # 'โ'
-     227: 29,  # 'ใ'
-     228: 33,  # 'ไ'
-     229: 245,  # 'ๅ'
-     230: 50,  # 'ๆ'
-     231: 37,  # '็'
-     232: 6,  # '่'
-     233: 7,  # '้'
-     234: 67,  # '๊'
-     235: 77,  # '๋'
-     236: 38,  # '์'
-     237: 93,  # 'ํ'
-     238: 246,  # '๎'
-     239: 247,  # '๏'
-     240: 68,  # '๐'
-     241: 56,  # '๑'
-     242: 59,  # '๒'
-     243: 65,  # '๓'
-     244: 69,  # '๔'
-     245: 60,  # '๕'
-     246: 70,  # '๖'
-     247: 80,  # '๗'
-     248: 71,  # '๘'
-     249: 87,  # '๙'
-     250: 248,  # '๚'
-     251: 249,  # '๛'
-     252: 250,  # None
-     253: 251,  # None
-     254: 252,  # None
-     255: 253,  # None
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 254,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 254,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 253,  # ' '
+    33: 253,  # '!'
+    34: 253,  # '"'
+    35: 253,  # '#'
+    36: 253,  # '$'
+    37: 253,  # '%'
+    38: 253,  # '&'
+    39: 253,  # "'"
+    40: 253,  # '('
+    41: 253,  # ')'
+    42: 253,  # '*'
+    43: 253,  # '+'
+    44: 253,  # ','
+    45: 253,  # '-'
+    46: 253,  # '.'
+    47: 253,  # '/'
+    48: 252,  # '0'
+    49: 252,  # '1'
+    50: 252,  # '2'
+    51: 252,  # '3'
+    52: 252,  # '4'
+    53: 252,  # '5'
+    54: 252,  # '6'
+    55: 252,  # '7'
+    56: 252,  # '8'
+    57: 252,  # '9'
+    58: 253,  # ':'
+    59: 253,  # ';'
+    60: 253,  # '<'
+    61: 253,  # '='
+    62: 253,  # '>'
+    63: 253,  # '?'
+    64: 253,  # '@'
+    65: 182,  # 'A'
+    66: 106,  # 'B'
+    67: 107,  # 'C'
+    68: 100,  # 'D'
+    69: 183,  # 'E'
+    70: 184,  # 'F'
+    71: 185,  # 'G'
+    72: 101,  # 'H'
+    73: 94,  # 'I'
+    74: 186,  # 'J'
+    75: 187,  # 'K'
+    76: 108,  # 'L'
+    77: 109,  # 'M'
+    78: 110,  # 'N'
+    79: 111,  # 'O'
+    80: 188,  # 'P'
+    81: 189,  # 'Q'
+    82: 190,  # 'R'
+    83: 89,  # 'S'
+    84: 95,  # 'T'
+    85: 112,  # 'U'
+    86: 113,  # 'V'
+    87: 191,  # 'W'
+    88: 192,  # 'X'
+    89: 193,  # 'Y'
+    90: 194,  # 'Z'
+    91: 253,  # '['
+    92: 253,  # '\\'
+    93: 253,  # ']'
+    94: 253,  # '^'
+    95: 253,  # '_'
+    96: 253,  # '`'
+    97: 64,  # 'a'
+    98: 72,  # 'b'
+    99: 73,  # 'c'
+    100: 114,  # 'd'
+    101: 74,  # 'e'
+    102: 115,  # 'f'
+    103: 116,  # 'g'
+    104: 102,  # 'h'
+    105: 81,  # 'i'
+    106: 201,  # 'j'
+    107: 117,  # 'k'
+    108: 90,  # 'l'
+    109: 103,  # 'm'
+    110: 78,  # 'n'
+    111: 82,  # 'o'
+    112: 96,  # 'p'
+    113: 202,  # 'q'
+    114: 91,  # 'r'
+    115: 79,  # 's'
+    116: 84,  # 't'
+    117: 104,  # 'u'
+    118: 105,  # 'v'
+    119: 97,  # 'w'
+    120: 98,  # 'x'
+    121: 92,  # 'y'
+    122: 203,  # 'z'
+    123: 253,  # '{'
+    124: 253,  # '|'
+    125: 253,  # '}'
+    126: 253,  # '~'
+    127: 253,  # '\x7f'
+    128: 209,  # '\x80'
+    129: 210,  # '\x81'
+    130: 211,  # '\x82'
+    131: 212,  # '\x83'
+    132: 213,  # '\x84'
+    133: 88,  # '\x85'
+    134: 214,  # '\x86'
+    135: 215,  # '\x87'
+    136: 216,  # '\x88'
+    137: 217,  # '\x89'
+    138: 218,  # '\x8a'
+    139: 219,  # '\x8b'
+    140: 220,  # '\x8c'
+    141: 118,  # '\x8d'
+    142: 221,  # '\x8e'
+    143: 222,  # '\x8f'
+    144: 223,  # '\x90'
+    145: 224,  # '\x91'
+    146: 99,  # '\x92'
+    147: 85,  # '\x93'
+    148: 83,  # '\x94'
+    149: 225,  # '\x95'
+    150: 226,  # '\x96'
+    151: 227,  # '\x97'
+    152: 228,  # '\x98'
+    153: 229,  # '\x99'
+    154: 230,  # '\x9a'
+    155: 231,  # '\x9b'
+    156: 232,  # '\x9c'
+    157: 233,  # '\x9d'
+    158: 234,  # '\x9e'
+    159: 235,  # '\x9f'
+    160: 236,  # None
+    161: 5,  # 'ก'
+    162: 30,  # 'ข'
+    163: 237,  # 'ฃ'
+    164: 24,  # 'ค'
+    165: 238,  # 'ฅ'
+    166: 75,  # 'ฆ'
+    167: 8,  # 'ง'
+    168: 26,  # 'จ'
+    169: 52,  # 'ฉ'
+    170: 34,  # 'ช'
+    171: 51,  # 'ซ'
+    172: 119,  # 'ฌ'
+    173: 47,  # 'ญ'
+    174: 58,  # 'ฎ'
+    175: 57,  # 'ฏ'
+    176: 49,  # 'ฐ'
+    177: 53,  # 'ฑ'
+    178: 55,  # 'ฒ'
+    179: 43,  # 'ณ'
+    180: 20,  # 'ด'
+    181: 19,  # 'ต'
+    182: 44,  # 'ถ'
+    183: 14,  # 'ท'
+    184: 48,  # 'ธ'
+    185: 3,  # 'น'
+    186: 17,  # 'บ'
+    187: 25,  # 'ป'
+    188: 39,  # 'ผ'
+    189: 62,  # 'ฝ'
+    190: 31,  # 'พ'
+    191: 54,  # 'ฟ'
+    192: 45,  # 'ภ'
+    193: 9,  # 'ม'
+    194: 16,  # 'ย'
+    195: 2,  # 'ร'
+    196: 61,  # 'ฤ'
+    197: 15,  # 'ล'
+    198: 239,  # 'ฦ'
+    199: 12,  # 'ว'
+    200: 42,  # 'ศ'
+    201: 46,  # 'ษ'
+    202: 18,  # 'ส'
+    203: 21,  # 'ห'
+    204: 76,  # 'ฬ'
+    205: 4,  # 'อ'
+    206: 66,  # 'ฮ'
+    207: 63,  # 'ฯ'
+    208: 22,  # 'ะ'
+    209: 10,  # 'ั'
+    210: 1,  # 'า'
+    211: 36,  # 'ำ'
+    212: 23,  # 'ิ'
+    213: 13,  # 'ี'
+    214: 40,  # 'ึ'
+    215: 27,  # 'ื'
+    216: 32,  # 'ุ'
+    217: 35,  # 'ู'
+    218: 86,  # 'ฺ'
+    219: 240,  # None
+    220: 241,  # None
+    221: 242,  # None
+    222: 243,  # None
+    223: 244,  # '฿'
+    224: 11,  # 'เ'
+    225: 28,  # 'แ'
+    226: 41,  # 'โ'
+    227: 29,  # 'ใ'
+    228: 33,  # 'ไ'
+    229: 245,  # 'ๅ'
+    230: 50,  # 'ๆ'
+    231: 37,  # '็'
+    232: 6,  # '่'
+    233: 7,  # '้'
+    234: 67,  # '๊'
+    235: 77,  # '๋'
+    236: 38,  # '์'
+    237: 93,  # 'ํ'
+    238: 246,  # '๎'
+    239: 247,  # '๏'
+    240: 68,  # '๐'
+    241: 56,  # '๑'
+    242: 59,  # '๒'
+    243: 65,  # '๓'
+    244: 69,  # '๔'
+    245: 60,  # '๕'
+    246: 70,  # '๖'
+    247: 80,  # '๗'
+    248: 71,  # '๘'
+    249: 87,  # '๙'
+    250: 248,  # '๚'
+    251: 249,  # '๛'
+    252: 250,  # None
+    253: 251,  # None
+    254: 252,  # None
+    255: 253,  # None
 }
 
-TIS_620_THAI_MODEL = SingleByteCharSetModel(charset_name='TIS-620',
-                                            language='Thai',
-                                            char_to_order_map=TIS_620_THAI_CHAR_TO_ORDER,
-                                            language_model=THAI_LANG_MODEL,
-                                            typical_positive_ratio=0.926386,
-                                            keep_ascii_letters=False,
-                                            alphabet='กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛')
-
+TIS_620_THAI_MODEL = SingleByteCharSetModel(
+    charset_name="TIS-620",
+    language="Thai",
+    char_to_order_map=TIS_620_THAI_CHAR_TO_ORDER,
+    language_model=THAI_LANG_MODEL,
+    typical_positive_ratio=0.926386,
+    keep_ascii_letters=False,
+    alphabet="กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py b/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py
index 43f4230a..291857c2 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/langturkishmodel.py
@@ -1,9 +1,5 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
-
 from pip._vendor.chardet.sbcharsetprober import SingleByteCharSetModel
 
-
 # 3: Positive
 # 2: Likely
 # 1: Unlikely
@@ -4115,269 +4111,270 @@ TURKISH_LANG_MODEL = {
 
 # Character Mapping Table(s):
 ISO_8859_9_TURKISH_CHAR_TO_ORDER = {
-     0: 255,  # '\x00'
-     1: 255,  # '\x01'
-     2: 255,  # '\x02'
-     3: 255,  # '\x03'
-     4: 255,  # '\x04'
-     5: 255,  # '\x05'
-     6: 255,  # '\x06'
-     7: 255,  # '\x07'
-     8: 255,  # '\x08'
-     9: 255,  # '\t'
-     10: 255,  # '\n'
-     11: 255,  # '\x0b'
-     12: 255,  # '\x0c'
-     13: 255,  # '\r'
-     14: 255,  # '\x0e'
-     15: 255,  # '\x0f'
-     16: 255,  # '\x10'
-     17: 255,  # '\x11'
-     18: 255,  # '\x12'
-     19: 255,  # '\x13'
-     20: 255,  # '\x14'
-     21: 255,  # '\x15'
-     22: 255,  # '\x16'
-     23: 255,  # '\x17'
-     24: 255,  # '\x18'
-     25: 255,  # '\x19'
-     26: 255,  # '\x1a'
-     27: 255,  # '\x1b'
-     28: 255,  # '\x1c'
-     29: 255,  # '\x1d'
-     30: 255,  # '\x1e'
-     31: 255,  # '\x1f'
-     32: 255,  # ' '
-     33: 255,  # '!'
-     34: 255,  # '"'
-     35: 255,  # '#'
-     36: 255,  # '$'
-     37: 255,  # '%'
-     38: 255,  # '&'
-     39: 255,  # "'"
-     40: 255,  # '('
-     41: 255,  # ')'
-     42: 255,  # '*'
-     43: 255,  # '+'
-     44: 255,  # ','
-     45: 255,  # '-'
-     46: 255,  # '.'
-     47: 255,  # '/'
-     48: 255,  # '0'
-     49: 255,  # '1'
-     50: 255,  # '2'
-     51: 255,  # '3'
-     52: 255,  # '4'
-     53: 255,  # '5'
-     54: 255,  # '6'
-     55: 255,  # '7'
-     56: 255,  # '8'
-     57: 255,  # '9'
-     58: 255,  # ':'
-     59: 255,  # ';'
-     60: 255,  # '<'
-     61: 255,  # '='
-     62: 255,  # '>'
-     63: 255,  # '?'
-     64: 255,  # '@'
-     65: 23,  # 'A'
-     66: 37,  # 'B'
-     67: 47,  # 'C'
-     68: 39,  # 'D'
-     69: 29,  # 'E'
-     70: 52,  # 'F'
-     71: 36,  # 'G'
-     72: 45,  # 'H'
-     73: 53,  # 'I'
-     74: 60,  # 'J'
-     75: 16,  # 'K'
-     76: 49,  # 'L'
-     77: 20,  # 'M'
-     78: 46,  # 'N'
-     79: 42,  # 'O'
-     80: 48,  # 'P'
-     81: 69,  # 'Q'
-     82: 44,  # 'R'
-     83: 35,  # 'S'
-     84: 31,  # 'T'
-     85: 51,  # 'U'
-     86: 38,  # 'V'
-     87: 62,  # 'W'
-     88: 65,  # 'X'
-     89: 43,  # 'Y'
-     90: 56,  # 'Z'
-     91: 255,  # '['
-     92: 255,  # '\\'
-     93: 255,  # ']'
-     94: 255,  # '^'
-     95: 255,  # '_'
-     96: 255,  # '`'
-     97: 1,  # 'a'
-     98: 21,  # 'b'
-     99: 28,  # 'c'
-     100: 12,  # 'd'
-     101: 2,  # 'e'
-     102: 18,  # 'f'
-     103: 27,  # 'g'
-     104: 25,  # 'h'
-     105: 3,  # 'i'
-     106: 24,  # 'j'
-     107: 10,  # 'k'
-     108: 5,  # 'l'
-     109: 13,  # 'm'
-     110: 4,  # 'n'
-     111: 15,  # 'o'
-     112: 26,  # 'p'
-     113: 64,  # 'q'
-     114: 7,  # 'r'
-     115: 8,  # 's'
-     116: 9,  # 't'
-     117: 14,  # 'u'
-     118: 32,  # 'v'
-     119: 57,  # 'w'
-     120: 58,  # 'x'
-     121: 11,  # 'y'
-     122: 22,  # 'z'
-     123: 255,  # '{'
-     124: 255,  # '|'
-     125: 255,  # '}'
-     126: 255,  # '~'
-     127: 255,  # '\x7f'
-     128: 180,  # '\x80'
-     129: 179,  # '\x81'
-     130: 178,  # '\x82'
-     131: 177,  # '\x83'
-     132: 176,  # '\x84'
-     133: 175,  # '\x85'
-     134: 174,  # '\x86'
-     135: 173,  # '\x87'
-     136: 172,  # '\x88'
-     137: 171,  # '\x89'
-     138: 170,  # '\x8a'
-     139: 169,  # '\x8b'
-     140: 168,  # '\x8c'
-     141: 167,  # '\x8d'
-     142: 166,  # '\x8e'
-     143: 165,  # '\x8f'
-     144: 164,  # '\x90'
-     145: 163,  # '\x91'
-     146: 162,  # '\x92'
-     147: 161,  # '\x93'
-     148: 160,  # '\x94'
-     149: 159,  # '\x95'
-     150: 101,  # '\x96'
-     151: 158,  # '\x97'
-     152: 157,  # '\x98'
-     153: 156,  # '\x99'
-     154: 155,  # '\x9a'
-     155: 154,  # '\x9b'
-     156: 153,  # '\x9c'
-     157: 152,  # '\x9d'
-     158: 151,  # '\x9e'
-     159: 106,  # '\x9f'
-     160: 150,  # '\xa0'
-     161: 149,  # '¡'
-     162: 148,  # '¢'
-     163: 147,  # '£'
-     164: 146,  # '¤'
-     165: 145,  # '¥'
-     166: 144,  # '¦'
-     167: 100,  # '§'
-     168: 143,  # '¨'
-     169: 142,  # '©'
-     170: 141,  # 'ª'
-     171: 140,  # '«'
-     172: 139,  # '¬'
-     173: 138,  # '\xad'
-     174: 137,  # '®'
-     175: 136,  # '¯'
-     176: 94,  # '°'
-     177: 80,  # '±'
-     178: 93,  # '²'
-     179: 135,  # '³'
-     180: 105,  # '´'
-     181: 134,  # 'µ'
-     182: 133,  # '¶'
-     183: 63,  # '·'
-     184: 132,  # '¸'
-     185: 131,  # '¹'
-     186: 130,  # 'º'
-     187: 129,  # '»'
-     188: 128,  # '¼'
-     189: 127,  # '½'
-     190: 126,  # '¾'
-     191: 125,  # '¿'
-     192: 124,  # 'À'
-     193: 104,  # 'Á'
-     194: 73,  # 'Â'
-     195: 99,  # 'Ã'
-     196: 79,  # 'Ä'
-     197: 85,  # 'Å'
-     198: 123,  # 'Æ'
-     199: 54,  # 'Ç'
-     200: 122,  # 'È'
-     201: 98,  # 'É'
-     202: 92,  # 'Ê'
-     203: 121,  # 'Ë'
-     204: 120,  # 'Ì'
-     205: 91,  # 'Í'
-     206: 103,  # 'Î'
-     207: 119,  # 'Ï'
-     208: 68,  # 'Ğ'
-     209: 118,  # 'Ñ'
-     210: 117,  # 'Ò'
-     211: 97,  # 'Ó'
-     212: 116,  # 'Ô'
-     213: 115,  # 'Õ'
-     214: 50,  # 'Ö'
-     215: 90,  # '×'
-     216: 114,  # 'Ø'
-     217: 113,  # 'Ù'
-     218: 112,  # 'Ú'
-     219: 111,  # 'Û'
-     220: 55,  # 'Ü'
-     221: 41,  # 'İ'
-     222: 40,  # 'Ş'
-     223: 86,  # 'ß'
-     224: 89,  # 'à'
-     225: 70,  # 'á'
-     226: 59,  # 'â'
-     227: 78,  # 'ã'
-     228: 71,  # 'ä'
-     229: 82,  # 'å'
-     230: 88,  # 'æ'
-     231: 33,  # 'ç'
-     232: 77,  # 'è'
-     233: 66,  # 'é'
-     234: 84,  # 'ê'
-     235: 83,  # 'ë'
-     236: 110,  # 'ì'
-     237: 75,  # 'í'
-     238: 61,  # 'î'
-     239: 96,  # 'ï'
-     240: 30,  # 'ğ'
-     241: 67,  # 'ñ'
-     242: 109,  # 'ò'
-     243: 74,  # 'ó'
-     244: 87,  # 'ô'
-     245: 102,  # 'õ'
-     246: 34,  # 'ö'
-     247: 95,  # '÷'
-     248: 81,  # 'ø'
-     249: 108,  # 'ù'
-     250: 76,  # 'ú'
-     251: 72,  # 'û'
-     252: 17,  # 'ü'
-     253: 6,  # 'ı'
-     254: 19,  # 'ş'
-     255: 107,  # 'ÿ'
+    0: 255,  # '\x00'
+    1: 255,  # '\x01'
+    2: 255,  # '\x02'
+    3: 255,  # '\x03'
+    4: 255,  # '\x04'
+    5: 255,  # '\x05'
+    6: 255,  # '\x06'
+    7: 255,  # '\x07'
+    8: 255,  # '\x08'
+    9: 255,  # '\t'
+    10: 255,  # '\n'
+    11: 255,  # '\x0b'
+    12: 255,  # '\x0c'
+    13: 255,  # '\r'
+    14: 255,  # '\x0e'
+    15: 255,  # '\x0f'
+    16: 255,  # '\x10'
+    17: 255,  # '\x11'
+    18: 255,  # '\x12'
+    19: 255,  # '\x13'
+    20: 255,  # '\x14'
+    21: 255,  # '\x15'
+    22: 255,  # '\x16'
+    23: 255,  # '\x17'
+    24: 255,  # '\x18'
+    25: 255,  # '\x19'
+    26: 255,  # '\x1a'
+    27: 255,  # '\x1b'
+    28: 255,  # '\x1c'
+    29: 255,  # '\x1d'
+    30: 255,  # '\x1e'
+    31: 255,  # '\x1f'
+    32: 255,  # ' '
+    33: 255,  # '!'
+    34: 255,  # '"'
+    35: 255,  # '#'
+    36: 255,  # '$'
+    37: 255,  # '%'
+    38: 255,  # '&'
+    39: 255,  # "'"
+    40: 255,  # '('
+    41: 255,  # ')'
+    42: 255,  # '*'
+    43: 255,  # '+'
+    44: 255,  # ','
+    45: 255,  # '-'
+    46: 255,  # '.'
+    47: 255,  # '/'
+    48: 255,  # '0'
+    49: 255,  # '1'
+    50: 255,  # '2'
+    51: 255,  # '3'
+    52: 255,  # '4'
+    53: 255,  # '5'
+    54: 255,  # '6'
+    55: 255,  # '7'
+    56: 255,  # '8'
+    57: 255,  # '9'
+    58: 255,  # ':'
+    59: 255,  # ';'
+    60: 255,  # '<'
+    61: 255,  # '='
+    62: 255,  # '>'
+    63: 255,  # '?'
+    64: 255,  # '@'
+    65: 23,  # 'A'
+    66: 37,  # 'B'
+    67: 47,  # 'C'
+    68: 39,  # 'D'
+    69: 29,  # 'E'
+    70: 52,  # 'F'
+    71: 36,  # 'G'
+    72: 45,  # 'H'
+    73: 53,  # 'I'
+    74: 60,  # 'J'
+    75: 16,  # 'K'
+    76: 49,  # 'L'
+    77: 20,  # 'M'
+    78: 46,  # 'N'
+    79: 42,  # 'O'
+    80: 48,  # 'P'
+    81: 69,  # 'Q'
+    82: 44,  # 'R'
+    83: 35,  # 'S'
+    84: 31,  # 'T'
+    85: 51,  # 'U'
+    86: 38,  # 'V'
+    87: 62,  # 'W'
+    88: 65,  # 'X'
+    89: 43,  # 'Y'
+    90: 56,  # 'Z'
+    91: 255,  # '['
+    92: 255,  # '\\'
+    93: 255,  # ']'
+    94: 255,  # '^'
+    95: 255,  # '_'
+    96: 255,  # '`'
+    97: 1,  # 'a'
+    98: 21,  # 'b'
+    99: 28,  # 'c'
+    100: 12,  # 'd'
+    101: 2,  # 'e'
+    102: 18,  # 'f'
+    103: 27,  # 'g'
+    104: 25,  # 'h'
+    105: 3,  # 'i'
+    106: 24,  # 'j'
+    107: 10,  # 'k'
+    108: 5,  # 'l'
+    109: 13,  # 'm'
+    110: 4,  # 'n'
+    111: 15,  # 'o'
+    112: 26,  # 'p'
+    113: 64,  # 'q'
+    114: 7,  # 'r'
+    115: 8,  # 's'
+    116: 9,  # 't'
+    117: 14,  # 'u'
+    118: 32,  # 'v'
+    119: 57,  # 'w'
+    120: 58,  # 'x'
+    121: 11,  # 'y'
+    122: 22,  # 'z'
+    123: 255,  # '{'
+    124: 255,  # '|'
+    125: 255,  # '}'
+    126: 255,  # '~'
+    127: 255,  # '\x7f'
+    128: 180,  # '\x80'
+    129: 179,  # '\x81'
+    130: 178,  # '\x82'
+    131: 177,  # '\x83'
+    132: 176,  # '\x84'
+    133: 175,  # '\x85'
+    134: 174,  # '\x86'
+    135: 173,  # '\x87'
+    136: 172,  # '\x88'
+    137: 171,  # '\x89'
+    138: 170,  # '\x8a'
+    139: 169,  # '\x8b'
+    140: 168,  # '\x8c'
+    141: 167,  # '\x8d'
+    142: 166,  # '\x8e'
+    143: 165,  # '\x8f'
+    144: 164,  # '\x90'
+    145: 163,  # '\x91'
+    146: 162,  # '\x92'
+    147: 161,  # '\x93'
+    148: 160,  # '\x94'
+    149: 159,  # '\x95'
+    150: 101,  # '\x96'
+    151: 158,  # '\x97'
+    152: 157,  # '\x98'
+    153: 156,  # '\x99'
+    154: 155,  # '\x9a'
+    155: 154,  # '\x9b'
+    156: 153,  # '\x9c'
+    157: 152,  # '\x9d'
+    158: 151,  # '\x9e'
+    159: 106,  # '\x9f'
+    160: 150,  # '\xa0'
+    161: 149,  # '¡'
+    162: 148,  # '¢'
+    163: 147,  # '£'
+    164: 146,  # '¤'
+    165: 145,  # '¥'
+    166: 144,  # '¦'
+    167: 100,  # '§'
+    168: 143,  # '¨'
+    169: 142,  # '©'
+    170: 141,  # 'ª'
+    171: 140,  # '«'
+    172: 139,  # '¬'
+    173: 138,  # '\xad'
+    174: 137,  # '®'
+    175: 136,  # '¯'
+    176: 94,  # '°'
+    177: 80,  # '±'
+    178: 93,  # '²'
+    179: 135,  # '³'
+    180: 105,  # '´'
+    181: 134,  # 'µ'
+    182: 133,  # '¶'
+    183: 63,  # '·'
+    184: 132,  # '¸'
+    185: 131,  # '¹'
+    186: 130,  # 'º'
+    187: 129,  # '»'
+    188: 128,  # '¼'
+    189: 127,  # '½'
+    190: 126,  # '¾'
+    191: 125,  # '¿'
+    192: 124,  # 'À'
+    193: 104,  # 'Á'
+    194: 73,  # 'Â'
+    195: 99,  # 'Ã'
+    196: 79,  # 'Ä'
+    197: 85,  # 'Å'
+    198: 123,  # 'Æ'
+    199: 54,  # 'Ç'
+    200: 122,  # 'È'
+    201: 98,  # 'É'
+    202: 92,  # 'Ê'
+    203: 121,  # 'Ë'
+    204: 120,  # 'Ì'
+    205: 91,  # 'Í'
+    206: 103,  # 'Î'
+    207: 119,  # 'Ï'
+    208: 68,  # 'Ğ'
+    209: 118,  # 'Ñ'
+    210: 117,  # 'Ò'
+    211: 97,  # 'Ó'
+    212: 116,  # 'Ô'
+    213: 115,  # 'Õ'
+    214: 50,  # 'Ö'
+    215: 90,  # '×'
+    216: 114,  # 'Ø'
+    217: 113,  # 'Ù'
+    218: 112,  # 'Ú'
+    219: 111,  # 'Û'
+    220: 55,  # 'Ü'
+    221: 41,  # 'İ'
+    222: 40,  # 'Ş'
+    223: 86,  # 'ß'
+    224: 89,  # 'à'
+    225: 70,  # 'á'
+    226: 59,  # 'â'
+    227: 78,  # 'ã'
+    228: 71,  # 'ä'
+    229: 82,  # 'å'
+    230: 88,  # 'æ'
+    231: 33,  # 'ç'
+    232: 77,  # 'è'
+    233: 66,  # 'é'
+    234: 84,  # 'ê'
+    235: 83,  # 'ë'
+    236: 110,  # 'ì'
+    237: 75,  # 'í'
+    238: 61,  # 'î'
+    239: 96,  # 'ï'
+    240: 30,  # 'ğ'
+    241: 67,  # 'ñ'
+    242: 109,  # 'ò'
+    243: 74,  # 'ó'
+    244: 87,  # 'ô'
+    245: 102,  # 'õ'
+    246: 34,  # 'ö'
+    247: 95,  # '÷'
+    248: 81,  # 'ø'
+    249: 108,  # 'ù'
+    250: 76,  # 'ú'
+    251: 72,  # 'û'
+    252: 17,  # 'ü'
+    253: 6,  # 'ı'
+    254: 19,  # 'ş'
+    255: 107,  # 'ÿ'
 }
 
-ISO_8859_9_TURKISH_MODEL = SingleByteCharSetModel(charset_name='ISO-8859-9',
-                                                  language='Turkish',
-                                                  char_to_order_map=ISO_8859_9_TURKISH_CHAR_TO_ORDER,
-                                                  language_model=TURKISH_LANG_MODEL,
-                                                  typical_positive_ratio=0.97029,
-                                                  keep_ascii_letters=True,
-                                                  alphabet='ABCDEFGHIJKLMNOPRSTUVYZabcdefghijklmnoprstuvyzÂÇÎÖÛÜâçîöûüĞğİıŞş')
-
+ISO_8859_9_TURKISH_MODEL = SingleByteCharSetModel(
+    charset_name="ISO-8859-9",
+    language="Turkish",
+    char_to_order_map=ISO_8859_9_TURKISH_CHAR_TO_ORDER,
+    language_model=TURKISH_LANG_MODEL,
+    typical_positive_ratio=0.97029,
+    keep_ascii_letters=True,
+    alphabet="ABCDEFGHIJKLMNOPRSTUVYZabcdefghijklmnoprstuvyzÂÇÎÖÛÜâçîöûüĞğİıŞş",
+)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py b/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py
index 7d1e8c20..59a01d91 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/latin1prober.py
@@ -26,6 +26,8 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import List, Union
+
 from .charsetprober import CharSetProber
 from .enums import ProbingState
 
@@ -41,6 +43,7 @@ ASV = 6  # accent small vowel
 ASO = 7  # accent small other
 CLASS_NUM = 8  # total classes
 
+# fmt: off
 Latin1_CharToClass = (
     OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 00 - 07
     OTH, OTH, OTH, OTH, OTH, OTH, OTH, OTH,   # 08 - 0F
@@ -91,34 +94,34 @@ Latin1ClassModel = (
     0,  3,  1,  3,  1,  1,  1,  3,  # ASV
     0,  3,  1,  3,  1,  1,  3,  3,  # ASO
 )
+# fmt: on
 
 
 class Latin1Prober(CharSetProber):
-    def __init__(self):
-        super(Latin1Prober, self).__init__()
-        self._last_char_class = None
-        self._freq_counter = None
+    def __init__(self) -> None:
+        super().__init__()
+        self._last_char_class = OTH
+        self._freq_counter: List[int] = []
         self.reset()
 
-    def reset(self):
+    def reset(self) -> None:
         self._last_char_class = OTH
         self._freq_counter = [0] * FREQ_CAT_NUM
-        CharSetProber.reset(self)
+        super().reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "ISO-8859-1"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return ""
 
-    def feed(self, byte_str):
-        byte_str = self.filter_with_english_letters(byte_str)
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
+        byte_str = self.remove_xml_tags(byte_str)
         for c in byte_str:
             char_class = Latin1_CharToClass[c]
-            freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM)
-                                    + char_class]
+            freq = Latin1ClassModel[(self._last_char_class * CLASS_NUM) + char_class]
             if freq == 0:
                 self._state = ProbingState.NOT_ME
                 break
@@ -127,19 +130,18 @@ class Latin1Prober(CharSetProber):
 
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         if self.state == ProbingState.NOT_ME:
             return 0.01
 
         total = sum(self._freq_counter)
-        if total < 0.01:
-            confidence = 0.0
-        else:
-            confidence = ((self._freq_counter[3] - self._freq_counter[1] * 20.0)
-                          / total)
-        if confidence < 0.0:
-            confidence = 0.0
+        confidence = (
+            0.0
+            if total < 0.01
+            else (self._freq_counter[3] - self._freq_counter[1] * 20.0) / total
+        )
+        confidence = max(confidence, 0.0)
         # lower the confidence of latin1 so that other more accurate
         # detector can take priority.
-        confidence = confidence * 0.73
+        confidence *= 0.73
         return confidence
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py b/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py
index 6256ecfd..666307e8 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/mbcharsetprober.py
@@ -27,8 +27,12 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import Optional, Union
+
+from .chardistribution import CharDistributionAnalysis
 from .charsetprober import CharSetProber
-from .enums import ProbingState, MachineState
+from .codingstatemachine import CodingStateMachine
+from .enums import LanguageFilter, MachineState, ProbingState
 
 
 class MultiByteCharSetProber(CharSetProber):
@@ -36,56 +40,56 @@ class MultiByteCharSetProber(CharSetProber):
     MultiByteCharSetProber
     """
 
-    def __init__(self, lang_filter=None):
-        super(MultiByteCharSetProber, self).__init__(lang_filter=lang_filter)
-        self.distribution_analyzer = None
-        self.coding_sm = None
-        self._last_char = [0, 0]
+    def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None:
+        super().__init__(lang_filter=lang_filter)
+        self.distribution_analyzer: Optional[CharDistributionAnalysis] = None
+        self.coding_sm: Optional[CodingStateMachine] = None
+        self._last_char = bytearray(b"\0\0")
 
-    def reset(self):
-        super(MultiByteCharSetProber, self).reset()
+    def reset(self) -> None:
+        super().reset()
         if self.coding_sm:
             self.coding_sm.reset()
         if self.distribution_analyzer:
             self.distribution_analyzer.reset()
-        self._last_char = [0, 0]
-
-    @property
-    def charset_name(self):
-        raise NotImplementedError
+        self._last_char = bytearray(b"\0\0")
 
-    @property
-    def language(self):
-        raise NotImplementedError
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
+        assert self.coding_sm is not None
+        assert self.distribution_analyzer is not None
 
-    def feed(self, byte_str):
-        for i in range(len(byte_str)):
-            coding_state = self.coding_sm.next_state(byte_str[i])
+        for i, byte in enumerate(byte_str):
+            coding_state = self.coding_sm.next_state(byte)
             if coding_state == MachineState.ERROR:
-                self.logger.debug('%s %s prober hit error at byte %s',
-                                  self.charset_name, self.language, i)
+                self.logger.debug(
+                    "%s %s prober hit error at byte %s",
+                    self.charset_name,
+                    self.language,
+                    i,
+                )
                 self._state = ProbingState.NOT_ME
                 break
-            elif coding_state == MachineState.ITS_ME:
+            if coding_state == MachineState.ITS_ME:
                 self._state = ProbingState.FOUND_IT
                 break
-            elif coding_state == MachineState.START:
+            if coding_state == MachineState.START:
                 char_len = self.coding_sm.get_current_charlen()
                 if i == 0:
-                    self._last_char[1] = byte_str[0]
+                    self._last_char[1] = byte
                     self.distribution_analyzer.feed(self._last_char, char_len)
                 else:
-                    self.distribution_analyzer.feed(byte_str[i - 1:i + 1],
-                                                    char_len)
+                    self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len)
 
         self._last_char[0] = byte_str[-1]
 
         if self.state == ProbingState.DETECTING:
-            if (self.distribution_analyzer.got_enough_data() and
-                    (self.get_confidence() > self.SHORTCUT_THRESHOLD)):
+            if self.distribution_analyzer.got_enough_data() and (
+                self.get_confidence() > self.SHORTCUT_THRESHOLD
+            ):
                 self._state = ProbingState.FOUND_IT
 
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
+        assert self.distribution_analyzer is not None
         return self.distribution_analyzer.get_confidence()
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py b/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py
index 530abe75..6cb9cc7b 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/mbcsgroupprober.py
@@ -27,20 +27,22 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from .big5prober import Big5Prober
 from .charsetgroupprober import CharSetGroupProber
-from .utf8prober import UTF8Prober
-from .sjisprober import SJISProber
+from .cp949prober import CP949Prober
+from .enums import LanguageFilter
 from .eucjpprober import EUCJPProber
-from .gb2312prober import GB2312Prober
 from .euckrprober import EUCKRProber
-from .cp949prober import CP949Prober
-from .big5prober import Big5Prober
 from .euctwprober import EUCTWProber
+from .gb2312prober import GB2312Prober
+from .johabprober import JOHABProber
+from .sjisprober import SJISProber
+from .utf8prober import UTF8Prober
 
 
 class MBCSGroupProber(CharSetGroupProber):
-    def __init__(self, lang_filter=None):
-        super(MBCSGroupProber, self).__init__(lang_filter=lang_filter)
+    def __init__(self, lang_filter: LanguageFilter = LanguageFilter.NONE) -> None:
+        super().__init__(lang_filter=lang_filter)
         self.probers = [
             UTF8Prober(),
             SJISProber(),
@@ -49,6 +51,7 @@ class MBCSGroupProber(CharSetGroupProber):
             EUCKRProber(),
             CP949Prober(),
             Big5Prober(),
-            EUCTWProber()
+            EUCTWProber(),
+            JOHABProber(),
         ]
         self.reset()
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py b/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py
index 8360d0f2..7bbe97e6 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/mbcssm.py
@@ -25,43 +25,45 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from .codingstatemachinedict import CodingStateMachineDict
 from .enums import MachineState
 
 # BIG5
 
+# fmt: off
 BIG5_CLS = (
-    1,1,1,1,1,1,1,1,  # 00 - 07    #allow 0x00 as legal value
-    1,1,1,1,1,1,0,0,  # 08 - 0f
-    1,1,1,1,1,1,1,1,  # 10 - 17
-    1,1,1,0,1,1,1,1,  # 18 - 1f
-    1,1,1,1,1,1,1,1,  # 20 - 27
-    1,1,1,1,1,1,1,1,  # 28 - 2f
-    1,1,1,1,1,1,1,1,  # 30 - 37
-    1,1,1,1,1,1,1,1,  # 38 - 3f
-    2,2,2,2,2,2,2,2,  # 40 - 47
-    2,2,2,2,2,2,2,2,  # 48 - 4f
-    2,2,2,2,2,2,2,2,  # 50 - 57
-    2,2,2,2,2,2,2,2,  # 58 - 5f
-    2,2,2,2,2,2,2,2,  # 60 - 67
-    2,2,2,2,2,2,2,2,  # 68 - 6f
-    2,2,2,2,2,2,2,2,  # 70 - 77
-    2,2,2,2,2,2,2,1,  # 78 - 7f
-    4,4,4,4,4,4,4,4,  # 80 - 87
-    4,4,4,4,4,4,4,4,  # 88 - 8f
-    4,4,4,4,4,4,4,4,  # 90 - 97
-    4,4,4,4,4,4,4,4,  # 98 - 9f
-    4,3,3,3,3,3,3,3,  # a0 - a7
-    3,3,3,3,3,3,3,3,  # a8 - af
-    3,3,3,3,3,3,3,3,  # b0 - b7
-    3,3,3,3,3,3,3,3,  # b8 - bf
-    3,3,3,3,3,3,3,3,  # c0 - c7
-    3,3,3,3,3,3,3,3,  # c8 - cf
-    3,3,3,3,3,3,3,3,  # d0 - d7
-    3,3,3,3,3,3,3,3,  # d8 - df
-    3,3,3,3,3,3,3,3,  # e0 - e7
-    3,3,3,3,3,3,3,3,  # e8 - ef
-    3,3,3,3,3,3,3,3,  # f0 - f7
-    3,3,3,3,3,3,3,0  # f8 - ff
+    1, 1, 1, 1, 1, 1, 1, 1,  # 00 - 07    #allow 0x00 as legal value
+    1, 1, 1, 1, 1, 1, 0, 0,  # 08 - 0f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 10 - 17
+    1, 1, 1, 0, 1, 1, 1, 1,  # 18 - 1f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 20 - 27
+    1, 1, 1, 1, 1, 1, 1, 1,  # 28 - 2f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 30 - 37
+    1, 1, 1, 1, 1, 1, 1, 1,  # 38 - 3f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 40 - 47
+    2, 2, 2, 2, 2, 2, 2, 2,  # 48 - 4f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 50 - 57
+    2, 2, 2, 2, 2, 2, 2, 2,  # 58 - 5f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 60 - 67
+    2, 2, 2, 2, 2, 2, 2, 2,  # 68 - 6f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 70 - 77
+    2, 2, 2, 2, 2, 2, 2, 1,  # 78 - 7f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 80 - 87
+    4, 4, 4, 4, 4, 4, 4, 4,  # 88 - 8f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 90 - 97
+    4, 4, 4, 4, 4, 4, 4, 4,  # 98 - 9f
+    4, 3, 3, 3, 3, 3, 3, 3,  # a0 - a7
+    3, 3, 3, 3, 3, 3, 3, 3,  # a8 - af
+    3, 3, 3, 3, 3, 3, 3, 3,  # b0 - b7
+    3, 3, 3, 3, 3, 3, 3, 3,  # b8 - bf
+    3, 3, 3, 3, 3, 3, 3, 3,  # c0 - c7
+    3, 3, 3, 3, 3, 3, 3, 3,  # c8 - cf
+    3, 3, 3, 3, 3, 3, 3, 3,  # d0 - d7
+    3, 3, 3, 3, 3, 3, 3, 3,  # d8 - df
+    3, 3, 3, 3, 3, 3, 3, 3,  # e0 - e7
+    3, 3, 3, 3, 3, 3, 3, 3,  # e8 - ef
+    3, 3, 3, 3, 3, 3, 3, 3,  # f0 - f7
+    3, 3, 3, 3, 3, 3, 3, 0  # f8 - ff
 )
 
 BIG5_ST = (
@@ -69,34 +71,37 @@ BIG5_ST = (
     MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,#08-0f
     MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START#10-17
 )
+# fmt: on
 
 BIG5_CHAR_LEN_TABLE = (0, 1, 1, 2, 0)
 
-BIG5_SM_MODEL = {'class_table': BIG5_CLS,
-                 'class_factor': 5,
-                 'state_table': BIG5_ST,
-                 'char_len_table': BIG5_CHAR_LEN_TABLE,
-                 'name': 'Big5'}
+BIG5_SM_MODEL: CodingStateMachineDict = {
+    "class_table": BIG5_CLS,
+    "class_factor": 5,
+    "state_table": BIG5_ST,
+    "char_len_table": BIG5_CHAR_LEN_TABLE,
+    "name": "Big5",
+}
 
 # CP949
-
+# fmt: off
 CP949_CLS  = (
-    1,1,1,1,1,1,1,1, 1,1,1,1,1,1,0,0,  # 00 - 0f
-    1,1,1,1,1,1,1,1, 1,1,1,0,1,1,1,1,  # 10 - 1f
-    1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1,  # 20 - 2f
-    1,1,1,1,1,1,1,1, 1,1,1,1,1,1,1,1,  # 30 - 3f
-    1,4,4,4,4,4,4,4, 4,4,4,4,4,4,4,4,  # 40 - 4f
-    4,4,5,5,5,5,5,5, 5,5,5,1,1,1,1,1,  # 50 - 5f
-    1,5,5,5,5,5,5,5, 5,5,5,5,5,5,5,5,  # 60 - 6f
-    5,5,5,5,5,5,5,5, 5,5,5,1,1,1,1,1,  # 70 - 7f
-    0,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6,  # 80 - 8f
-    6,6,6,6,6,6,6,6, 6,6,6,6,6,6,6,6,  # 90 - 9f
-    6,7,7,7,7,7,7,7, 7,7,7,7,7,8,8,8,  # a0 - af
-    7,7,7,7,7,7,7,7, 7,7,7,7,7,7,7,7,  # b0 - bf
-    7,7,7,7,7,7,9,2, 2,3,2,2,2,2,2,2,  # c0 - cf
-    2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2,  # d0 - df
-    2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,2,  # e0 - ef
-    2,2,2,2,2,2,2,2, 2,2,2,2,2,2,2,0,  # f0 - ff
+    1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0,  # 00 - 0f
+    1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1,  # 10 - 1f
+    1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,  # 20 - 2f
+    1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,  # 30 - 3f
+    1, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4, 4,  # 40 - 4f
+    4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 1, 1, 1, 1, 1,  # 50 - 5f
+    1, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,  # 60 - 6f
+    5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 1, 1, 1, 1, 1,  # 70 - 7f
+    0, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,  # 80 - 8f
+    6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,  # 90 - 9f
+    6, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8,  # a0 - af
+    7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,  # b0 - bf
+    7, 7, 7, 7, 7, 7, 9, 2, 2, 3, 2, 2, 2, 2, 2, 2,  # c0 - cf
+    2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,  # d0 - df
+    2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,  # e0 - ef
+    2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 0,  # f0 - ff
 )
 
 CP949_ST = (
@@ -109,50 +114,53 @@ CP949_ST = (
     MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START, # 5
     MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START, # 6
 )
+# fmt: on
 
 CP949_CHAR_LEN_TABLE = (0, 1, 2, 0, 1, 1, 2, 2, 0, 2)
 
-CP949_SM_MODEL = {'class_table': CP949_CLS,
-                  'class_factor': 10,
-                  'state_table': CP949_ST,
-                  'char_len_table': CP949_CHAR_LEN_TABLE,
-                  'name': 'CP949'}
+CP949_SM_MODEL: CodingStateMachineDict = {
+    "class_table": CP949_CLS,
+    "class_factor": 10,
+    "state_table": CP949_ST,
+    "char_len_table": CP949_CHAR_LEN_TABLE,
+    "name": "CP949",
+}
 
 # EUC-JP
-
+# fmt: off
 EUCJP_CLS = (
-    4,4,4,4,4,4,4,4,  # 00 - 07
-    4,4,4,4,4,4,5,5,  # 08 - 0f
-    4,4,4,4,4,4,4,4,  # 10 - 17
-    4,4,4,5,4,4,4,4,  # 18 - 1f
-    4,4,4,4,4,4,4,4,  # 20 - 27
-    4,4,4,4,4,4,4,4,  # 28 - 2f
-    4,4,4,4,4,4,4,4,  # 30 - 37
-    4,4,4,4,4,4,4,4,  # 38 - 3f
-    4,4,4,4,4,4,4,4,  # 40 - 47
-    4,4,4,4,4,4,4,4,  # 48 - 4f
-    4,4,4,4,4,4,4,4,  # 50 - 57
-    4,4,4,4,4,4,4,4,  # 58 - 5f
-    4,4,4,4,4,4,4,4,  # 60 - 67
-    4,4,4,4,4,4,4,4,  # 68 - 6f
-    4,4,4,4,4,4,4,4,  # 70 - 77
-    4,4,4,4,4,4,4,4,  # 78 - 7f
-    5,5,5,5,5,5,5,5,  # 80 - 87
-    5,5,5,5,5,5,1,3,  # 88 - 8f
-    5,5,5,5,5,5,5,5,  # 90 - 97
-    5,5,5,5,5,5,5,5,  # 98 - 9f
-    5,2,2,2,2,2,2,2,  # a0 - a7
-    2,2,2,2,2,2,2,2,  # a8 - af
-    2,2,2,2,2,2,2,2,  # b0 - b7
-    2,2,2,2,2,2,2,2,  # b8 - bf
-    2,2,2,2,2,2,2,2,  # c0 - c7
-    2,2,2,2,2,2,2,2,  # c8 - cf
-    2,2,2,2,2,2,2,2,  # d0 - d7
-    2,2,2,2,2,2,2,2,  # d8 - df
-    0,0,0,0,0,0,0,0,  # e0 - e7
-    0,0,0,0,0,0,0,0,  # e8 - ef
-    0,0,0,0,0,0,0,0,  # f0 - f7
-    0,0,0,0,0,0,0,5  # f8 - ff
+    4, 4, 4, 4, 4, 4, 4, 4,  # 00 - 07
+    4, 4, 4, 4, 4, 4, 5, 5,  # 08 - 0f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 10 - 17
+    4, 4, 4, 5, 4, 4, 4, 4,  # 18 - 1f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 20 - 27
+    4, 4, 4, 4, 4, 4, 4, 4,  # 28 - 2f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 30 - 37
+    4, 4, 4, 4, 4, 4, 4, 4,  # 38 - 3f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 40 - 47
+    4, 4, 4, 4, 4, 4, 4, 4,  # 48 - 4f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 50 - 57
+    4, 4, 4, 4, 4, 4, 4, 4,  # 58 - 5f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 60 - 67
+    4, 4, 4, 4, 4, 4, 4, 4,  # 68 - 6f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 70 - 77
+    4, 4, 4, 4, 4, 4, 4, 4,  # 78 - 7f
+    5, 5, 5, 5, 5, 5, 5, 5,  # 80 - 87
+    5, 5, 5, 5, 5, 5, 1, 3,  # 88 - 8f
+    5, 5, 5, 5, 5, 5, 5, 5,  # 90 - 97
+    5, 5, 5, 5, 5, 5, 5, 5,  # 98 - 9f
+    5, 2, 2, 2, 2, 2, 2, 2,  # a0 - a7
+    2, 2, 2, 2, 2, 2, 2, 2,  # a8 - af
+    2, 2, 2, 2, 2, 2, 2, 2,  # b0 - b7
+    2, 2, 2, 2, 2, 2, 2, 2,  # b8 - bf
+    2, 2, 2, 2, 2, 2, 2, 2,  # c0 - c7
+    2, 2, 2, 2, 2, 2, 2, 2,  # c8 - cf
+    2, 2, 2, 2, 2, 2, 2, 2,  # d0 - d7
+    2, 2, 2, 2, 2, 2, 2, 2,  # d8 - df
+    0, 0, 0, 0, 0, 0, 0, 0,  # e0 - e7
+    0, 0, 0, 0, 0, 0, 0, 0,  # e8 - ef
+    0, 0, 0, 0, 0, 0, 0, 0,  # f0 - f7
+    0, 0, 0, 0, 0, 0, 0, 5  # f8 - ff
 )
 
 EUCJP_ST = (
@@ -162,100 +170,163 @@ EUCJP_ST = (
      MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     3,MachineState.ERROR,#18-1f
           3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START#20-27
 )
+# fmt: on
 
 EUCJP_CHAR_LEN_TABLE = (2, 2, 2, 3, 1, 0)
 
-EUCJP_SM_MODEL = {'class_table': EUCJP_CLS,
-                  'class_factor': 6,
-                  'state_table': EUCJP_ST,
-                  'char_len_table': EUCJP_CHAR_LEN_TABLE,
-                  'name': 'EUC-JP'}
+EUCJP_SM_MODEL: CodingStateMachineDict = {
+    "class_table": EUCJP_CLS,
+    "class_factor": 6,
+    "state_table": EUCJP_ST,
+    "char_len_table": EUCJP_CHAR_LEN_TABLE,
+    "name": "EUC-JP",
+}
 
 # EUC-KR
-
+# fmt: off
 EUCKR_CLS  = (
-    1,1,1,1,1,1,1,1,  # 00 - 07
-    1,1,1,1,1,1,0,0,  # 08 - 0f
-    1,1,1,1,1,1,1,1,  # 10 - 17
-    1,1,1,0,1,1,1,1,  # 18 - 1f
-    1,1,1,1,1,1,1,1,  # 20 - 27
-    1,1,1,1,1,1,1,1,  # 28 - 2f
-    1,1,1,1,1,1,1,1,  # 30 - 37
-    1,1,1,1,1,1,1,1,  # 38 - 3f
-    1,1,1,1,1,1,1,1,  # 40 - 47
+    1, 1, 1, 1, 1, 1, 1, 1,  # 00 - 07
+    1, 1, 1, 1, 1, 1, 0, 0,  # 08 - 0f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 10 - 17
+    1, 1, 1, 0, 1, 1, 1, 1,  # 18 - 1f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 20 - 27
+    1, 1, 1, 1, 1, 1, 1, 1,  # 28 - 2f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 30 - 37
+    1, 1, 1, 1, 1, 1, 1, 1,  # 38 - 3f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 40 - 47
+    1, 1, 1, 1, 1, 1, 1, 1,  # 48 - 4f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 50 - 57
+    1, 1, 1, 1, 1, 1, 1, 1,  # 58 - 5f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 60 - 67
+    1, 1, 1, 1, 1, 1, 1, 1,  # 68 - 6f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 70 - 77
+    1, 1, 1, 1, 1, 1, 1, 1,  # 78 - 7f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 80 - 87
+    0, 0, 0, 0, 0, 0, 0, 0,  # 88 - 8f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 90 - 97
+    0, 0, 0, 0, 0, 0, 0, 0,  # 98 - 9f
+    0, 2, 2, 2, 2, 2, 2, 2,  # a0 - a7
+    2, 2, 2, 2, 2, 3, 3, 3,  # a8 - af
+    2, 2, 2, 2, 2, 2, 2, 2,  # b0 - b7
+    2, 2, 2, 2, 2, 2, 2, 2,  # b8 - bf
+    2, 2, 2, 2, 2, 2, 2, 2,  # c0 - c7
+    2, 3, 2, 2, 2, 2, 2, 2,  # c8 - cf
+    2, 2, 2, 2, 2, 2, 2, 2,  # d0 - d7
+    2, 2, 2, 2, 2, 2, 2, 2,  # d8 - df
+    2, 2, 2, 2, 2, 2, 2, 2,  # e0 - e7
+    2, 2, 2, 2, 2, 2, 2, 2,  # e8 - ef
+    2, 2, 2, 2, 2, 2, 2, 2,  # f0 - f7
+    2, 2, 2, 2, 2, 2, 2, 0   # f8 - ff
+)
+
+EUCKR_ST = (
+    MachineState.ERROR,MachineState.START,     3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f
+)
+# fmt: on
+
+EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0)
+
+EUCKR_SM_MODEL: CodingStateMachineDict = {
+    "class_table": EUCKR_CLS,
+    "class_factor": 4,
+    "state_table": EUCKR_ST,
+    "char_len_table": EUCKR_CHAR_LEN_TABLE,
+    "name": "EUC-KR",
+}
+
+# JOHAB
+# fmt: off
+JOHAB_CLS = (
+    4,4,4,4,4,4,4,4,  # 00 - 07
+    4,4,4,4,4,4,0,0,  # 08 - 0f
+    4,4,4,4,4,4,4,4,  # 10 - 17
+    4,4,4,0,4,4,4,4,  # 18 - 1f
+    4,4,4,4,4,4,4,4,  # 20 - 27
+    4,4,4,4,4,4,4,4,  # 28 - 2f
+    4,3,3,3,3,3,3,3,  # 30 - 37
+    3,3,3,3,3,3,3,3,  # 38 - 3f
+    3,1,1,1,1,1,1,1,  # 40 - 47
     1,1,1,1,1,1,1,1,  # 48 - 4f
     1,1,1,1,1,1,1,1,  # 50 - 57
     1,1,1,1,1,1,1,1,  # 58 - 5f
     1,1,1,1,1,1,1,1,  # 60 - 67
     1,1,1,1,1,1,1,1,  # 68 - 6f
     1,1,1,1,1,1,1,1,  # 70 - 77
-    1,1,1,1,1,1,1,1,  # 78 - 7f
-    0,0,0,0,0,0,0,0,  # 80 - 87
-    0,0,0,0,0,0,0,0,  # 88 - 8f
-    0,0,0,0,0,0,0,0,  # 90 - 97
-    0,0,0,0,0,0,0,0,  # 98 - 9f
-    0,2,2,2,2,2,2,2,  # a0 - a7
-    2,2,2,2,2,3,3,3,  # a8 - af
-    2,2,2,2,2,2,2,2,  # b0 - b7
-    2,2,2,2,2,2,2,2,  # b8 - bf
-    2,2,2,2,2,2,2,2,  # c0 - c7
-    2,3,2,2,2,2,2,2,  # c8 - cf
-    2,2,2,2,2,2,2,2,  # d0 - d7
-    2,2,2,2,2,2,2,2,  # d8 - df
-    2,2,2,2,2,2,2,2,  # e0 - e7
-    2,2,2,2,2,2,2,2,  # e8 - ef
-    2,2,2,2,2,2,2,2,  # f0 - f7
-    2,2,2,2,2,2,2,0   # f8 - ff
+    1,1,1,1,1,1,1,2,  # 78 - 7f
+    6,6,6,6,8,8,8,8,  # 80 - 87
+    8,8,8,8,8,8,8,8,  # 88 - 8f
+    8,7,7,7,7,7,7,7,  # 90 - 97
+    7,7,7,7,7,7,7,7,  # 98 - 9f
+    7,7,7,7,7,7,7,7,  # a0 - a7
+    7,7,7,7,7,7,7,7,  # a8 - af
+    7,7,7,7,7,7,7,7,  # b0 - b7
+    7,7,7,7,7,7,7,7,  # b8 - bf
+    7,7,7,7,7,7,7,7,  # c0 - c7
+    7,7,7,7,7,7,7,7,  # c8 - cf
+    7,7,7,7,5,5,5,5,  # d0 - d7
+    5,9,9,9,9,9,9,5,  # d8 - df
+    9,9,9,9,9,9,9,9,  # e0 - e7
+    9,9,9,9,9,9,9,9,  # e8 - ef
+    9,9,9,9,9,9,9,9,  # f0 - f7
+    9,9,5,5,5,5,5,0   # f8 - ff
 )
 
-EUCKR_ST = (
-    MachineState.ERROR,MachineState.START,     3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
-    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #08-0f
+JOHAB_ST = (
+# cls = 0                   1                   2                   3                   4                   5                   6                   7                   8                   9
+    MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.ERROR ,MachineState.ERROR ,3                  ,3                  ,4                  ,  # MachineState.START
+    MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,  # MachineState.ITS_ME
+    MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,MachineState.ERROR ,  # MachineState.ERROR
+    MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.ERROR ,MachineState.ERROR ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,MachineState.START ,  # 3
+    MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,MachineState.ERROR ,MachineState.START ,  # 4
 )
+# fmt: on
 
-EUCKR_CHAR_LEN_TABLE = (0, 1, 2, 0)
+JOHAB_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 0, 0, 2, 2, 2)
 
-EUCKR_SM_MODEL = {'class_table': EUCKR_CLS,
-                'class_factor': 4,
-                'state_table': EUCKR_ST,
-                'char_len_table': EUCKR_CHAR_LEN_TABLE,
-                'name': 'EUC-KR'}
+JOHAB_SM_MODEL: CodingStateMachineDict = {
+    "class_table": JOHAB_CLS,
+    "class_factor": 10,
+    "state_table": JOHAB_ST,
+    "char_len_table": JOHAB_CHAR_LEN_TABLE,
+    "name": "Johab",
+}
 
 # EUC-TW
-
+# fmt: off
 EUCTW_CLS = (
-    2,2,2,2,2,2,2,2,  # 00 - 07
-    2,2,2,2,2,2,0,0,  # 08 - 0f
-    2,2,2,2,2,2,2,2,  # 10 - 17
-    2,2,2,0,2,2,2,2,  # 18 - 1f
-    2,2,2,2,2,2,2,2,  # 20 - 27
-    2,2,2,2,2,2,2,2,  # 28 - 2f
-    2,2,2,2,2,2,2,2,  # 30 - 37
-    2,2,2,2,2,2,2,2,  # 38 - 3f
-    2,2,2,2,2,2,2,2,  # 40 - 47
-    2,2,2,2,2,2,2,2,  # 48 - 4f
-    2,2,2,2,2,2,2,2,  # 50 - 57
-    2,2,2,2,2,2,2,2,  # 58 - 5f
-    2,2,2,2,2,2,2,2,  # 60 - 67
-    2,2,2,2,2,2,2,2,  # 68 - 6f
-    2,2,2,2,2,2,2,2,  # 70 - 77
-    2,2,2,2,2,2,2,2,  # 78 - 7f
-    0,0,0,0,0,0,0,0,  # 80 - 87
-    0,0,0,0,0,0,6,0,  # 88 - 8f
-    0,0,0,0,0,0,0,0,  # 90 - 97
-    0,0,0,0,0,0,0,0,  # 98 - 9f
-    0,3,4,4,4,4,4,4,  # a0 - a7
-    5,5,1,1,1,1,1,1,  # a8 - af
-    1,1,1,1,1,1,1,1,  # b0 - b7
-    1,1,1,1,1,1,1,1,  # b8 - bf
-    1,1,3,1,3,3,3,3,  # c0 - c7
-    3,3,3,3,3,3,3,3,  # c8 - cf
-    3,3,3,3,3,3,3,3,  # d0 - d7
-    3,3,3,3,3,3,3,3,  # d8 - df
-    3,3,3,3,3,3,3,3,  # e0 - e7
-    3,3,3,3,3,3,3,3,  # e8 - ef
-    3,3,3,3,3,3,3,3,  # f0 - f7
-    3,3,3,3,3,3,3,0   # f8 - ff
+    2, 2, 2, 2, 2, 2, 2, 2,  # 00 - 07
+    2, 2, 2, 2, 2, 2, 0, 0,  # 08 - 0f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 10 - 17
+    2, 2, 2, 0, 2, 2, 2, 2,  # 18 - 1f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 20 - 27
+    2, 2, 2, 2, 2, 2, 2, 2,  # 28 - 2f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 30 - 37
+    2, 2, 2, 2, 2, 2, 2, 2,  # 38 - 3f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 40 - 47
+    2, 2, 2, 2, 2, 2, 2, 2,  # 48 - 4f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 50 - 57
+    2, 2, 2, 2, 2, 2, 2, 2,  # 58 - 5f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 60 - 67
+    2, 2, 2, 2, 2, 2, 2, 2,  # 68 - 6f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 70 - 77
+    2, 2, 2, 2, 2, 2, 2, 2,  # 78 - 7f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 80 - 87
+    0, 0, 0, 0, 0, 0, 6, 0,  # 88 - 8f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 90 - 97
+    0, 0, 0, 0, 0, 0, 0, 0,  # 98 - 9f
+    0, 3, 4, 4, 4, 4, 4, 4,  # a0 - a7
+    5, 5, 1, 1, 1, 1, 1, 1,  # a8 - af
+    1, 1, 1, 1, 1, 1, 1, 1,  # b0 - b7
+    1, 1, 1, 1, 1, 1, 1, 1,  # b8 - bf
+    1, 1, 3, 1, 3, 3, 3, 3,  # c0 - c7
+    3, 3, 3, 3, 3, 3, 3, 3,  # c8 - cf
+    3, 3, 3, 3, 3, 3, 3, 3,  # d0 - d7
+    3, 3, 3, 3, 3, 3, 3, 3,  # d8 - df
+    3, 3, 3, 3, 3, 3, 3, 3,  # e0 - e7
+    3, 3, 3, 3, 3, 3, 3, 3,  # e8 - ef
+    3, 3, 3, 3, 3, 3, 3, 3,  # f0 - f7
+    3, 3, 3, 3, 3, 3, 3, 0   # f8 - ff
 )
 
 EUCTW_ST = (
@@ -266,50 +337,53 @@ EUCTW_ST = (
          5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,#20-27
     MachineState.START,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f
 )
+# fmt: on
 
 EUCTW_CHAR_LEN_TABLE = (0, 0, 1, 2, 2, 2, 3)
 
-EUCTW_SM_MODEL = {'class_table': EUCTW_CLS,
-                'class_factor': 7,
-                'state_table': EUCTW_ST,
-                'char_len_table': EUCTW_CHAR_LEN_TABLE,
-                'name': 'x-euc-tw'}
+EUCTW_SM_MODEL: CodingStateMachineDict = {
+    "class_table": EUCTW_CLS,
+    "class_factor": 7,
+    "state_table": EUCTW_ST,
+    "char_len_table": EUCTW_CHAR_LEN_TABLE,
+    "name": "x-euc-tw",
+}
 
 # GB2312
-
+# fmt: off
 GB2312_CLS = (
-    1,1,1,1,1,1,1,1,  # 00 - 07
-    1,1,1,1,1,1,0,0,  # 08 - 0f
-    1,1,1,1,1,1,1,1,  # 10 - 17
-    1,1,1,0,1,1,1,1,  # 18 - 1f
-    1,1,1,1,1,1,1,1,  # 20 - 27
-    1,1,1,1,1,1,1,1,  # 28 - 2f
-    3,3,3,3,3,3,3,3,  # 30 - 37
-    3,3,1,1,1,1,1,1,  # 38 - 3f
-    2,2,2,2,2,2,2,2,  # 40 - 47
-    2,2,2,2,2,2,2,2,  # 48 - 4f
-    2,2,2,2,2,2,2,2,  # 50 - 57
-    2,2,2,2,2,2,2,2,  # 58 - 5f
-    2,2,2,2,2,2,2,2,  # 60 - 67
-    2,2,2,2,2,2,2,2,  # 68 - 6f
-    2,2,2,2,2,2,2,2,  # 70 - 77
-    2,2,2,2,2,2,2,4,  # 78 - 7f
-    5,6,6,6,6,6,6,6,  # 80 - 87
-    6,6,6,6,6,6,6,6,  # 88 - 8f
-    6,6,6,6,6,6,6,6,  # 90 - 97
-    6,6,6,6,6,6,6,6,  # 98 - 9f
-    6,6,6,6,6,6,6,6,  # a0 - a7
-    6,6,6,6,6,6,6,6,  # a8 - af
-    6,6,6,6,6,6,6,6,  # b0 - b7
-    6,6,6,6,6,6,6,6,  # b8 - bf
-    6,6,6,6,6,6,6,6,  # c0 - c7
-    6,6,6,6,6,6,6,6,  # c8 - cf
-    6,6,6,6,6,6,6,6,  # d0 - d7
-    6,6,6,6,6,6,6,6,  # d8 - df
-    6,6,6,6,6,6,6,6,  # e0 - e7
-    6,6,6,6,6,6,6,6,  # e8 - ef
-    6,6,6,6,6,6,6,6,  # f0 - f7
-    6,6,6,6,6,6,6,0   # f8 - ff
+    1, 1, 1, 1, 1, 1, 1, 1,  # 00 - 07
+    1, 1, 1, 1, 1, 1, 0, 0,  # 08 - 0f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 10 - 17
+    1, 1, 1, 0, 1, 1, 1, 1,  # 18 - 1f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 20 - 27
+    1, 1, 1, 1, 1, 1, 1, 1,  # 28 - 2f
+    3, 3, 3, 3, 3, 3, 3, 3,  # 30 - 37
+    3, 3, 1, 1, 1, 1, 1, 1,  # 38 - 3f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 40 - 47
+    2, 2, 2, 2, 2, 2, 2, 2,  # 48 - 4f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 50 - 57
+    2, 2, 2, 2, 2, 2, 2, 2,  # 58 - 5f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 60 - 67
+    2, 2, 2, 2, 2, 2, 2, 2,  # 68 - 6f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 70 - 77
+    2, 2, 2, 2, 2, 2, 2, 4,  # 78 - 7f
+    5, 6, 6, 6, 6, 6, 6, 6,  # 80 - 87
+    6, 6, 6, 6, 6, 6, 6, 6,  # 88 - 8f
+    6, 6, 6, 6, 6, 6, 6, 6,  # 90 - 97
+    6, 6, 6, 6, 6, 6, 6, 6,  # 98 - 9f
+    6, 6, 6, 6, 6, 6, 6, 6,  # a0 - a7
+    6, 6, 6, 6, 6, 6, 6, 6,  # a8 - af
+    6, 6, 6, 6, 6, 6, 6, 6,  # b0 - b7
+    6, 6, 6, 6, 6, 6, 6, 6,  # b8 - bf
+    6, 6, 6, 6, 6, 6, 6, 6,  # c0 - c7
+    6, 6, 6, 6, 6, 6, 6, 6,  # c8 - cf
+    6, 6, 6, 6, 6, 6, 6, 6,  # d0 - d7
+    6, 6, 6, 6, 6, 6, 6, 6,  # d8 - df
+    6, 6, 6, 6, 6, 6, 6, 6,  # e0 - e7
+    6, 6, 6, 6, 6, 6, 6, 6,  # e8 - ef
+    6, 6, 6, 6, 6, 6, 6, 6,  # f0 - f7
+    6, 6, 6, 6, 6, 6, 6, 0   # f8 - ff
 )
 
 GB2312_ST = (
@@ -320,6 +394,7 @@ GB2312_ST = (
     MachineState.ERROR,MachineState.ERROR,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ERROR,#20-27
     MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.START #28-2f
 )
+# fmt: on
 
 # To be accurate, the length of class 6 can be either 2 or 4.
 # But it is not necessary to discriminate between the two since
@@ -328,100 +403,105 @@ GB2312_ST = (
 # 2 here.
 GB2312_CHAR_LEN_TABLE = (0, 1, 1, 1, 1, 1, 2)
 
-GB2312_SM_MODEL = {'class_table': GB2312_CLS,
-                   'class_factor': 7,
-                   'state_table': GB2312_ST,
-                   'char_len_table': GB2312_CHAR_LEN_TABLE,
-                   'name': 'GB2312'}
+GB2312_SM_MODEL: CodingStateMachineDict = {
+    "class_table": GB2312_CLS,
+    "class_factor": 7,
+    "state_table": GB2312_ST,
+    "char_len_table": GB2312_CHAR_LEN_TABLE,
+    "name": "GB2312",
+}
 
 # Shift_JIS
-
+# fmt: off
 SJIS_CLS = (
-    1,1,1,1,1,1,1,1,  # 00 - 07
-    1,1,1,1,1,1,0,0,  # 08 - 0f
-    1,1,1,1,1,1,1,1,  # 10 - 17
-    1,1,1,0,1,1,1,1,  # 18 - 1f
-    1,1,1,1,1,1,1,1,  # 20 - 27
-    1,1,1,1,1,1,1,1,  # 28 - 2f
-    1,1,1,1,1,1,1,1,  # 30 - 37
-    1,1,1,1,1,1,1,1,  # 38 - 3f
-    2,2,2,2,2,2,2,2,  # 40 - 47
-    2,2,2,2,2,2,2,2,  # 48 - 4f
-    2,2,2,2,2,2,2,2,  # 50 - 57
-    2,2,2,2,2,2,2,2,  # 58 - 5f
-    2,2,2,2,2,2,2,2,  # 60 - 67
-    2,2,2,2,2,2,2,2,  # 68 - 6f
-    2,2,2,2,2,2,2,2,  # 70 - 77
-    2,2,2,2,2,2,2,1,  # 78 - 7f
-    3,3,3,3,3,2,2,3,  # 80 - 87
-    3,3,3,3,3,3,3,3,  # 88 - 8f
-    3,3,3,3,3,3,3,3,  # 90 - 97
-    3,3,3,3,3,3,3,3,  # 98 - 9f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 00 - 07
+    1, 1, 1, 1, 1, 1, 0, 0,  # 08 - 0f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 10 - 17
+    1, 1, 1, 0, 1, 1, 1, 1,  # 18 - 1f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 20 - 27
+    1, 1, 1, 1, 1, 1, 1, 1,  # 28 - 2f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 30 - 37
+    1, 1, 1, 1, 1, 1, 1, 1,  # 38 - 3f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 40 - 47
+    2, 2, 2, 2, 2, 2, 2, 2,  # 48 - 4f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 50 - 57
+    2, 2, 2, 2, 2, 2, 2, 2,  # 58 - 5f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 60 - 67
+    2, 2, 2, 2, 2, 2, 2, 2,  # 68 - 6f
+    2, 2, 2, 2, 2, 2, 2, 2,  # 70 - 77
+    2, 2, 2, 2, 2, 2, 2, 1,  # 78 - 7f
+    3, 3, 3, 3, 3, 2, 2, 3,  # 80 - 87
+    3, 3, 3, 3, 3, 3, 3, 3,  # 88 - 8f
+    3, 3, 3, 3, 3, 3, 3, 3,  # 90 - 97
+    3, 3, 3, 3, 3, 3, 3, 3,  # 98 - 9f
     #0xa0 is illegal in sjis encoding, but some pages does
     #contain such byte. We need to be more error forgiven.
-    2,2,2,2,2,2,2,2,  # a0 - a7
-    2,2,2,2,2,2,2,2,  # a8 - af
-    2,2,2,2,2,2,2,2,  # b0 - b7
-    2,2,2,2,2,2,2,2,  # b8 - bf
-    2,2,2,2,2,2,2,2,  # c0 - c7
-    2,2,2,2,2,2,2,2,  # c8 - cf
-    2,2,2,2,2,2,2,2,  # d0 - d7
-    2,2,2,2,2,2,2,2,  # d8 - df
-    3,3,3,3,3,3,3,3,  # e0 - e7
-    3,3,3,3,3,4,4,4,  # e8 - ef
-    3,3,3,3,3,3,3,3,  # f0 - f7
-    3,3,3,3,3,0,0,0)  # f8 - ff
-
+    2, 2, 2, 2, 2, 2, 2, 2,  # a0 - a7
+    2, 2, 2, 2, 2, 2, 2, 2,  # a8 - af
+    2, 2, 2, 2, 2, 2, 2, 2,  # b0 - b7
+    2, 2, 2, 2, 2, 2, 2, 2,  # b8 - bf
+    2, 2, 2, 2, 2, 2, 2, 2,  # c0 - c7
+    2, 2, 2, 2, 2, 2, 2, 2,  # c8 - cf
+    2, 2, 2, 2, 2, 2, 2, 2,  # d0 - d7
+    2, 2, 2, 2, 2, 2, 2, 2,  # d8 - df
+    3, 3, 3, 3, 3, 3, 3, 3,  # e0 - e7
+    3, 3, 3, 3, 3, 4, 4, 4,  # e8 - ef
+    3, 3, 3, 3, 3, 3, 3, 3,  # f0 - f7
+    3, 3, 3, 3, 3, 0, 0, 0,  # f8 - ff
+)
 
 SJIS_ST = (
     MachineState.ERROR,MachineState.START,MachineState.START,     3,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,#00-07
     MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ITS_ME,#08-0f
     MachineState.ITS_ME,MachineState.ITS_ME,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START #10-17
 )
+# fmt: on
 
 SJIS_CHAR_LEN_TABLE = (0, 1, 1, 2, 0, 0)
 
-SJIS_SM_MODEL = {'class_table': SJIS_CLS,
-               'class_factor': 6,
-               'state_table': SJIS_ST,
-               'char_len_table': SJIS_CHAR_LEN_TABLE,
-               'name': 'Shift_JIS'}
+SJIS_SM_MODEL: CodingStateMachineDict = {
+    "class_table": SJIS_CLS,
+    "class_factor": 6,
+    "state_table": SJIS_ST,
+    "char_len_table": SJIS_CHAR_LEN_TABLE,
+    "name": "Shift_JIS",
+}
 
 # UCS2-BE
-
+# fmt: off
 UCS2BE_CLS = (
-    0,0,0,0,0,0,0,0,  # 00 - 07
-    0,0,1,0,0,2,0,0,  # 08 - 0f
-    0,0,0,0,0,0,0,0,  # 10 - 17
-    0,0,0,3,0,0,0,0,  # 18 - 1f
-    0,0,0,0,0,0,0,0,  # 20 - 27
-    0,3,3,3,3,3,0,0,  # 28 - 2f
-    0,0,0,0,0,0,0,0,  # 30 - 37
-    0,0,0,0,0,0,0,0,  # 38 - 3f
-    0,0,0,0,0,0,0,0,  # 40 - 47
-    0,0,0,0,0,0,0,0,  # 48 - 4f
-    0,0,0,0,0,0,0,0,  # 50 - 57
-    0,0,0,0,0,0,0,0,  # 58 - 5f
-    0,0,0,0,0,0,0,0,  # 60 - 67
-    0,0,0,0,0,0,0,0,  # 68 - 6f
-    0,0,0,0,0,0,0,0,  # 70 - 77
-    0,0,0,0,0,0,0,0,  # 78 - 7f
-    0,0,0,0,0,0,0,0,  # 80 - 87
-    0,0,0,0,0,0,0,0,  # 88 - 8f
-    0,0,0,0,0,0,0,0,  # 90 - 97
-    0,0,0,0,0,0,0,0,  # 98 - 9f
-    0,0,0,0,0,0,0,0,  # a0 - a7
-    0,0,0,0,0,0,0,0,  # a8 - af
-    0,0,0,0,0,0,0,0,  # b0 - b7
-    0,0,0,0,0,0,0,0,  # b8 - bf
-    0,0,0,0,0,0,0,0,  # c0 - c7
-    0,0,0,0,0,0,0,0,  # c8 - cf
-    0,0,0,0,0,0,0,0,  # d0 - d7
-    0,0,0,0,0,0,0,0,  # d8 - df
-    0,0,0,0,0,0,0,0,  # e0 - e7
-    0,0,0,0,0,0,0,0,  # e8 - ef
-    0,0,0,0,0,0,0,0,  # f0 - f7
-    0,0,0,0,0,0,4,5   # f8 - ff
+    0, 0, 0, 0, 0, 0, 0, 0,  # 00 - 07
+    0, 0, 1, 0, 0, 2, 0, 0,  # 08 - 0f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 10 - 17
+    0, 0, 0, 3, 0, 0, 0, 0,  # 18 - 1f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 20 - 27
+    0, 3, 3, 3, 3, 3, 0, 0,  # 28 - 2f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 30 - 37
+    0, 0, 0, 0, 0, 0, 0, 0,  # 38 - 3f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 40 - 47
+    0, 0, 0, 0, 0, 0, 0, 0,  # 48 - 4f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 50 - 57
+    0, 0, 0, 0, 0, 0, 0, 0,  # 58 - 5f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 60 - 67
+    0, 0, 0, 0, 0, 0, 0, 0,  # 68 - 6f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 70 - 77
+    0, 0, 0, 0, 0, 0, 0, 0,  # 78 - 7f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 80 - 87
+    0, 0, 0, 0, 0, 0, 0, 0,  # 88 - 8f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 90 - 97
+    0, 0, 0, 0, 0, 0, 0, 0,  # 98 - 9f
+    0, 0, 0, 0, 0, 0, 0, 0,  # a0 - a7
+    0, 0, 0, 0, 0, 0, 0, 0,  # a8 - af
+    0, 0, 0, 0, 0, 0, 0, 0,  # b0 - b7
+    0, 0, 0, 0, 0, 0, 0, 0,  # b8 - bf
+    0, 0, 0, 0, 0, 0, 0, 0,  # c0 - c7
+    0, 0, 0, 0, 0, 0, 0, 0,  # c8 - cf
+    0, 0, 0, 0, 0, 0, 0, 0,  # d0 - d7
+    0, 0, 0, 0, 0, 0, 0, 0,  # d8 - df
+    0, 0, 0, 0, 0, 0, 0, 0,  # e0 - e7
+    0, 0, 0, 0, 0, 0, 0, 0,  # e8 - ef
+    0, 0, 0, 0, 0, 0, 0, 0,  # f0 - f7
+    0, 0, 0, 0, 0, 0, 4, 5   # f8 - ff
 )
 
 UCS2BE_ST  = (
@@ -433,50 +513,53 @@ UCS2BE_ST  = (
           5,     8,     6,     6,MachineState.ERROR,     6,     6,     6,#28-2f
           6,     6,     6,     6,MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START #30-37
 )
+# fmt: on
 
 UCS2BE_CHAR_LEN_TABLE = (2, 2, 2, 0, 2, 2)
 
-UCS2BE_SM_MODEL = {'class_table': UCS2BE_CLS,
-                   'class_factor': 6,
-                   'state_table': UCS2BE_ST,
-                   'char_len_table': UCS2BE_CHAR_LEN_TABLE,
-                   'name': 'UTF-16BE'}
+UCS2BE_SM_MODEL: CodingStateMachineDict = {
+    "class_table": UCS2BE_CLS,
+    "class_factor": 6,
+    "state_table": UCS2BE_ST,
+    "char_len_table": UCS2BE_CHAR_LEN_TABLE,
+    "name": "UTF-16BE",
+}
 
 # UCS2-LE
-
+# fmt: off
 UCS2LE_CLS = (
-    0,0,0,0,0,0,0,0,  # 00 - 07
-    0,0,1,0,0,2,0,0,  # 08 - 0f
-    0,0,0,0,0,0,0,0,  # 10 - 17
-    0,0,0,3,0,0,0,0,  # 18 - 1f
-    0,0,0,0,0,0,0,0,  # 20 - 27
-    0,3,3,3,3,3,0,0,  # 28 - 2f
-    0,0,0,0,0,0,0,0,  # 30 - 37
-    0,0,0,0,0,0,0,0,  # 38 - 3f
-    0,0,0,0,0,0,0,0,  # 40 - 47
-    0,0,0,0,0,0,0,0,  # 48 - 4f
-    0,0,0,0,0,0,0,0,  # 50 - 57
-    0,0,0,0,0,0,0,0,  # 58 - 5f
-    0,0,0,0,0,0,0,0,  # 60 - 67
-    0,0,0,0,0,0,0,0,  # 68 - 6f
-    0,0,0,0,0,0,0,0,  # 70 - 77
-    0,0,0,0,0,0,0,0,  # 78 - 7f
-    0,0,0,0,0,0,0,0,  # 80 - 87
-    0,0,0,0,0,0,0,0,  # 88 - 8f
-    0,0,0,0,0,0,0,0,  # 90 - 97
-    0,0,0,0,0,0,0,0,  # 98 - 9f
-    0,0,0,0,0,0,0,0,  # a0 - a7
-    0,0,0,0,0,0,0,0,  # a8 - af
-    0,0,0,0,0,0,0,0,  # b0 - b7
-    0,0,0,0,0,0,0,0,  # b8 - bf
-    0,0,0,0,0,0,0,0,  # c0 - c7
-    0,0,0,0,0,0,0,0,  # c8 - cf
-    0,0,0,0,0,0,0,0,  # d0 - d7
-    0,0,0,0,0,0,0,0,  # d8 - df
-    0,0,0,0,0,0,0,0,  # e0 - e7
-    0,0,0,0,0,0,0,0,  # e8 - ef
-    0,0,0,0,0,0,0,0,  # f0 - f7
-    0,0,0,0,0,0,4,5   # f8 - ff
+    0, 0, 0, 0, 0, 0, 0, 0,  # 00 - 07
+    0, 0, 1, 0, 0, 2, 0, 0,  # 08 - 0f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 10 - 17
+    0, 0, 0, 3, 0, 0, 0, 0,  # 18 - 1f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 20 - 27
+    0, 3, 3, 3, 3, 3, 0, 0,  # 28 - 2f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 30 - 37
+    0, 0, 0, 0, 0, 0, 0, 0,  # 38 - 3f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 40 - 47
+    0, 0, 0, 0, 0, 0, 0, 0,  # 48 - 4f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 50 - 57
+    0, 0, 0, 0, 0, 0, 0, 0,  # 58 - 5f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 60 - 67
+    0, 0, 0, 0, 0, 0, 0, 0,  # 68 - 6f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 70 - 77
+    0, 0, 0, 0, 0, 0, 0, 0,  # 78 - 7f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 80 - 87
+    0, 0, 0, 0, 0, 0, 0, 0,  # 88 - 8f
+    0, 0, 0, 0, 0, 0, 0, 0,  # 90 - 97
+    0, 0, 0, 0, 0, 0, 0, 0,  # 98 - 9f
+    0, 0, 0, 0, 0, 0, 0, 0,  # a0 - a7
+    0, 0, 0, 0, 0, 0, 0, 0,  # a8 - af
+    0, 0, 0, 0, 0, 0, 0, 0,  # b0 - b7
+    0, 0, 0, 0, 0, 0, 0, 0,  # b8 - bf
+    0, 0, 0, 0, 0, 0, 0, 0,  # c0 - c7
+    0, 0, 0, 0, 0, 0, 0, 0,  # c8 - cf
+    0, 0, 0, 0, 0, 0, 0, 0,  # d0 - d7
+    0, 0, 0, 0, 0, 0, 0, 0,  # d8 - df
+    0, 0, 0, 0, 0, 0, 0, 0,  # e0 - e7
+    0, 0, 0, 0, 0, 0, 0, 0,  # e8 - ef
+    0, 0, 0, 0, 0, 0, 0, 0,  # f0 - f7
+    0, 0, 0, 0, 0, 0, 4, 5   # f8 - ff
 )
 
 UCS2LE_ST = (
@@ -488,50 +571,53 @@ UCS2LE_ST = (
           5,     5,     5,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,     5,     5,#28-2f
           5,     5,     5,MachineState.ERROR,     5,MachineState.ERROR,MachineState.START,MachineState.START #30-37
 )
+# fmt: on
 
 UCS2LE_CHAR_LEN_TABLE = (2, 2, 2, 2, 2, 2)
 
-UCS2LE_SM_MODEL = {'class_table': UCS2LE_CLS,
-                 'class_factor': 6,
-                 'state_table': UCS2LE_ST,
-                 'char_len_table': UCS2LE_CHAR_LEN_TABLE,
-                 'name': 'UTF-16LE'}
+UCS2LE_SM_MODEL: CodingStateMachineDict = {
+    "class_table": UCS2LE_CLS,
+    "class_factor": 6,
+    "state_table": UCS2LE_ST,
+    "char_len_table": UCS2LE_CHAR_LEN_TABLE,
+    "name": "UTF-16LE",
+}
 
 # UTF-8
-
+# fmt: off
 UTF8_CLS = (
-    1,1,1,1,1,1,1,1,  # 00 - 07  #allow 0x00 as a legal value
-    1,1,1,1,1,1,0,0,  # 08 - 0f
-    1,1,1,1,1,1,1,1,  # 10 - 17
-    1,1,1,0,1,1,1,1,  # 18 - 1f
-    1,1,1,1,1,1,1,1,  # 20 - 27
-    1,1,1,1,1,1,1,1,  # 28 - 2f
-    1,1,1,1,1,1,1,1,  # 30 - 37
-    1,1,1,1,1,1,1,1,  # 38 - 3f
-    1,1,1,1,1,1,1,1,  # 40 - 47
-    1,1,1,1,1,1,1,1,  # 48 - 4f
-    1,1,1,1,1,1,1,1,  # 50 - 57
-    1,1,1,1,1,1,1,1,  # 58 - 5f
-    1,1,1,1,1,1,1,1,  # 60 - 67
-    1,1,1,1,1,1,1,1,  # 68 - 6f
-    1,1,1,1,1,1,1,1,  # 70 - 77
-    1,1,1,1,1,1,1,1,  # 78 - 7f
-    2,2,2,2,3,3,3,3,  # 80 - 87
-    4,4,4,4,4,4,4,4,  # 88 - 8f
-    4,4,4,4,4,4,4,4,  # 90 - 97
-    4,4,4,4,4,4,4,4,  # 98 - 9f
-    5,5,5,5,5,5,5,5,  # a0 - a7
-    5,5,5,5,5,5,5,5,  # a8 - af
-    5,5,5,5,5,5,5,5,  # b0 - b7
-    5,5,5,5,5,5,5,5,  # b8 - bf
-    0,0,6,6,6,6,6,6,  # c0 - c7
-    6,6,6,6,6,6,6,6,  # c8 - cf
-    6,6,6,6,6,6,6,6,  # d0 - d7
-    6,6,6,6,6,6,6,6,  # d8 - df
-    7,8,8,8,8,8,8,8,  # e0 - e7
-    8,8,8,8,8,9,8,8,  # e8 - ef
-    10,11,11,11,11,11,11,11,  # f0 - f7
-    12,13,13,13,14,15,0,0    # f8 - ff
+    1, 1, 1, 1, 1, 1, 1, 1,  # 00 - 07  #allow 0x00 as a legal value
+    1, 1, 1, 1, 1, 1, 0, 0,  # 08 - 0f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 10 - 17
+    1, 1, 1, 0, 1, 1, 1, 1,  # 18 - 1f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 20 - 27
+    1, 1, 1, 1, 1, 1, 1, 1,  # 28 - 2f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 30 - 37
+    1, 1, 1, 1, 1, 1, 1, 1,  # 38 - 3f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 40 - 47
+    1, 1, 1, 1, 1, 1, 1, 1,  # 48 - 4f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 50 - 57
+    1, 1, 1, 1, 1, 1, 1, 1,  # 58 - 5f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 60 - 67
+    1, 1, 1, 1, 1, 1, 1, 1,  # 68 - 6f
+    1, 1, 1, 1, 1, 1, 1, 1,  # 70 - 77
+    1, 1, 1, 1, 1, 1, 1, 1,  # 78 - 7f
+    2, 2, 2, 2, 3, 3, 3, 3,  # 80 - 87
+    4, 4, 4, 4, 4, 4, 4, 4,  # 88 - 8f
+    4, 4, 4, 4, 4, 4, 4, 4,  # 90 - 97
+    4, 4, 4, 4, 4, 4, 4, 4,  # 98 - 9f
+    5, 5, 5, 5, 5, 5, 5, 5,  # a0 - a7
+    5, 5, 5, 5, 5, 5, 5, 5,  # a8 - af
+    5, 5, 5, 5, 5, 5, 5, 5,  # b0 - b7
+    5, 5, 5, 5, 5, 5, 5, 5,  # b8 - bf
+    0, 0, 6, 6, 6, 6, 6, 6,  # c0 - c7
+    6, 6, 6, 6, 6, 6, 6, 6,  # c8 - cf
+    6, 6, 6, 6, 6, 6, 6, 6,  # d0 - d7
+    6, 6, 6, 6, 6, 6, 6, 6,  # d8 - df
+    7, 8, 8, 8, 8, 8, 8, 8,  # e0 - e7
+    8, 8, 8, 8, 8, 9, 8, 8,  # e8 - ef
+    10, 11, 11, 11, 11, 11, 11, 11,  # f0 - f7
+    12, 13, 13, 13, 14, 15, 0, 0    # f8 - ff
 )
 
 UTF8_ST = (
@@ -562,11 +648,14 @@ UTF8_ST = (
     MachineState.ERROR,MachineState.ERROR,MachineState.START,MachineState.START,MachineState.START,MachineState.START,MachineState.ERROR,MachineState.ERROR,#c0-c7
     MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR,MachineState.ERROR #c8-cf
 )
+# fmt: on
 
 UTF8_CHAR_LEN_TABLE = (0, 1, 0, 0, 0, 0, 2, 3, 3, 3, 4, 4, 5, 5, 6, 6)
 
-UTF8_SM_MODEL = {'class_table': UTF8_CLS,
-                 'class_factor': 16,
-                 'state_table': UTF8_ST,
-                 'char_len_table': UTF8_CHAR_LEN_TABLE,
-                 'name': 'UTF-8'}
+UTF8_SM_MODEL: CodingStateMachineDict = {
+    "class_table": UTF8_CLS,
+    "class_factor": 16,
+    "state_table": UTF8_ST,
+    "char_len_table": UTF8_CHAR_LEN_TABLE,
+    "name": "UTF-8",
+}
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index f20fa90dfbfd044f2ed07632e8c63551c1f68955..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 228
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>U6e>
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk
yFVauWNGwW8Ez!?SElEsCEJ@UlkI&4@EQycTE2zB1VUwGmQks)$2Xf+PkXHcP<~{@f

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/chardet/metadata/__pycache__/languages.cpython-39.pyc
deleted file mode 100644
index 89a848bfcfb9b4e13f7f563f9c97ae182615ec54..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7959
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
VwjgyNcfi~z2nsotS1b(-a{=`75ElRd

diff --git a/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py b/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py
index 3237d5ab..eb40c5f0 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/metadata/languages.py
@@ -1,19 +1,17 @@
-#!/usr/bin/env python
-# -*- coding: utf-8 -*-
 """
 Metadata about languages used by our model training code for our
 SingleByteCharSetProbers.  Could be used for other things in the future.
 
 This code is based on the language metadata from the uchardet project.
 """
-from __future__ import absolute_import, print_function
 
 from string import ascii_letters
+from typing import List, Optional
 
+# TODO: Add Ukrainian (KOI8-U)
 
-# TODO: Add Ukranian (KOI8-U)
 
-class Language(object):
+class Language:
     """Metadata about a language useful for training models
 
     :ivar name: The human name for the language, in English.
@@ -33,9 +31,17 @@ class Language(object):
                             Wikipedia for training data.
     :type wiki_start_pages: list of str
     """
-    def __init__(self, name=None, iso_code=None, use_ascii=True, charsets=None,
-                 alphabet=None, wiki_start_pages=None):
-        super(Language, self).__init__()
+
+    def __init__(
+        self,
+        name: Optional[str] = None,
+        iso_code: Optional[str] = None,
+        use_ascii: bool = True,
+        charsets: Optional[List[str]] = None,
+        alphabet: Optional[str] = None,
+        wiki_start_pages: Optional[List[str]] = None,
+    ) -> None:
+        super().__init__()
         self.name = name
         self.iso_code = iso_code
         self.use_ascii = use_ascii
@@ -46,265 +52,301 @@ class Language(object):
             else:
                 alphabet = ascii_letters
         elif not alphabet:
-            raise ValueError('Must supply alphabet if use_ascii is False')
-        self.alphabet = ''.join(sorted(set(alphabet))) if alphabet else None
+            raise ValueError("Must supply alphabet if use_ascii is False")
+        self.alphabet = "".join(sorted(set(alphabet))) if alphabet else None
         self.wiki_start_pages = wiki_start_pages
 
-    def __repr__(self):
-        return '{}({})'.format(self.__class__.__name__,
-                               ', '.join('{}={!r}'.format(k, v)
-                                         for k, v in self.__dict__.items()
-                                         if not k.startswith('_')))
+    def __repr__(self) -> str:
+        param_str = ", ".join(
+            f"{k}={v!r}" for k, v in self.__dict__.items() if not k.startswith("_")
+        )
+        return f"{self.__class__.__name__}({param_str})"
 
 
-LANGUAGES = {'Arabic': Language(name='Arabic',
-                                iso_code='ar',
-                                use_ascii=False,
-                                # We only support encodings that use isolated
-                                # forms, because the current recommendation is
-                                # that the rendering system handles presentation
-                                # forms. This means we purposefully skip IBM864.
-                                charsets=['ISO-8859-6', 'WINDOWS-1256',
-                                          'CP720', 'CP864'],
-                                alphabet=u'ءآأؤإئابةتثجحخدذرزسشصضطظعغػؼؽؾؿـفقكلمنهوىيًٌٍَُِّ',
-                                wiki_start_pages=[u'الصفحة_الرئيسية']),
-             'Belarusian': Language(name='Belarusian',
-                                    iso_code='be',
-                                    use_ascii=False,
-                                    charsets=['ISO-8859-5', 'WINDOWS-1251',
-                                              'IBM866', 'MacCyrillic'],
-                                    alphabet=(u'АБВГДЕЁЖЗІЙКЛМНОПРСТУЎФХЦЧШЫЬЭЮЯ'
-                                              u'абвгдеёжзійклмнопрстуўфхцчшыьэюяʼ'),
-                                    wiki_start_pages=[u'Галоўная_старонка']),
-             'Bulgarian': Language(name='Bulgarian',
-                                   iso_code='bg',
-                                   use_ascii=False,
-                                   charsets=['ISO-8859-5', 'WINDOWS-1251',
-                                             'IBM855'],
-                                   alphabet=(u'АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯ'
-                                             u'абвгдежзийклмнопрстуфхцчшщъьюя'),
-                                   wiki_start_pages=[u'Начална_страница']),
-             'Czech': Language(name='Czech',
-                               iso_code='cz',
-                               use_ascii=True,
-                               charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                               alphabet=u'áčďéěíňóřšťúůýžÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ',
-                               wiki_start_pages=[u'Hlavní_strana']),
-             'Danish': Language(name='Danish',
-                                iso_code='da',
-                                use_ascii=True,
-                                charsets=['ISO-8859-1', 'ISO-8859-15',
-                                          'WINDOWS-1252'],
-                                alphabet=u'æøåÆØÅ',
-                                wiki_start_pages=[u'Forside']),
-             'German': Language(name='German',
-                                iso_code='de',
-                                use_ascii=True,
-                                charsets=['ISO-8859-1', 'WINDOWS-1252'],
-                                alphabet=u'äöüßÄÖÜ',
-                                wiki_start_pages=[u'Wikipedia:Hauptseite']),
-             'Greek': Language(name='Greek',
-                               iso_code='el',
-                               use_ascii=False,
-                               charsets=['ISO-8859-7', 'WINDOWS-1253'],
-                               alphabet=(u'αβγδεζηθικλμνξοπρσςτυφχψωάέήίόύώ'
-                                         u'ΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΣΤΥΦΧΨΩΆΈΉΊΌΎΏ'),
-                               wiki_start_pages=[u'Πύλη:Κύρια']),
-             'English': Language(name='English',
-                                 iso_code='en',
-                                 use_ascii=True,
-                                 charsets=['ISO-8859-1', 'WINDOWS-1252'],
-                                 wiki_start_pages=[u'Main_Page']),
-             'Esperanto': Language(name='Esperanto',
-                                   iso_code='eo',
-                                   # Q, W, X, and Y not used at all
-                                   use_ascii=False,
-                                   charsets=['ISO-8859-3'],
-                                   alphabet=(u'abcĉdefgĝhĥijĵklmnoprsŝtuŭvz'
-                                             u'ABCĈDEFGĜHĤIJĴKLMNOPRSŜTUŬVZ'),
-                                   wiki_start_pages=[u'Vikipedio:Ĉefpaĝo']),
-             'Spanish': Language(name='Spanish',
-                                 iso_code='es',
-                                 use_ascii=True,
-                                 charsets=['ISO-8859-1', 'ISO-8859-15',
-                                           'WINDOWS-1252'],
-                                 alphabet=u'ñáéíóúüÑÁÉÍÓÚÜ',
-                                 wiki_start_pages=[u'Wikipedia:Portada']),
-             'Estonian': Language(name='Estonian',
-                                  iso_code='et',
-                                  use_ascii=False,
-                                  charsets=['ISO-8859-4', 'ISO-8859-13',
-                                            'WINDOWS-1257'],
-                                  # C, F, Š, Q, W, X, Y, Z, Ž are only for
-                                  # loanwords
-                                  alphabet=(u'ABDEGHIJKLMNOPRSTUVÕÄÖÜ'
-                                            u'abdeghijklmnoprstuvõäöü'),
-                                  wiki_start_pages=[u'Esileht']),
-             'Finnish': Language(name='Finnish',
-                                 iso_code='fi',
-                                 use_ascii=True,
-                                 charsets=['ISO-8859-1', 'ISO-8859-15',
-                                           'WINDOWS-1252'],
-                                 alphabet=u'ÅÄÖŠŽåäöšž',
-                                 wiki_start_pages=[u'Wikipedia:Etusivu']),
-             'French': Language(name='French',
-                                iso_code='fr',
-                                use_ascii=True,
-                                charsets=['ISO-8859-1', 'ISO-8859-15',
-                                          'WINDOWS-1252'],
-                                alphabet=u'œàâçèéîïùûêŒÀÂÇÈÉÎÏÙÛÊ',
-                                wiki_start_pages=[u'Wikipédia:Accueil_principal',
-                                                  u'Bœuf (animal)']),
-             'Hebrew': Language(name='Hebrew',
-                                iso_code='he',
-                                use_ascii=False,
-                                charsets=['ISO-8859-8', 'WINDOWS-1255'],
-                                alphabet=u'אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ',
-                                wiki_start_pages=[u'עמוד_ראשי']),
-             'Croatian': Language(name='Croatian',
-                                  iso_code='hr',
-                                  # Q, W, X, Y are only used for foreign words.
-                                  use_ascii=False,
-                                  charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                                  alphabet=(u'abcčćdđefghijklmnoprsštuvzž'
-                                            u'ABCČĆDĐEFGHIJKLMNOPRSŠTUVZŽ'),
-                                  wiki_start_pages=[u'Glavna_stranica']),
-             'Hungarian': Language(name='Hungarian',
-                                   iso_code='hu',
-                                   # Q, W, X, Y are only used for foreign words.
-                                   use_ascii=False,
-                                   charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                                   alphabet=(u'abcdefghijklmnoprstuvzáéíóöőúüű'
-                                             u'ABCDEFGHIJKLMNOPRSTUVZÁÉÍÓÖŐÚÜŰ'),
-                                   wiki_start_pages=[u'Kezdőlap']),
-             'Italian': Language(name='Italian',
-                                 iso_code='it',
-                                 use_ascii=True,
-                                 charsets=['ISO-8859-1', 'ISO-8859-15',
-                                           'WINDOWS-1252'],
-                                 alphabet=u'ÀÈÉÌÒÓÙàèéìòóù',
-                                 wiki_start_pages=[u'Pagina_principale']),
-             'Lithuanian': Language(name='Lithuanian',
-                                    iso_code='lt',
-                                    use_ascii=False,
-                                    charsets=['ISO-8859-13', 'WINDOWS-1257',
-                                              'ISO-8859-4'],
-                                    # Q, W, and X not used at all
-                                    alphabet=(u'AĄBCČDEĘĖFGHIĮYJKLMNOPRSŠTUŲŪVZŽ'
-                                              u'aąbcčdeęėfghiįyjklmnoprsštuųūvzž'),
-                                    wiki_start_pages=[u'Pagrindinis_puslapis']),
-             'Latvian': Language(name='Latvian',
-                                 iso_code='lv',
-                                 use_ascii=False,
-                                 charsets=['ISO-8859-13', 'WINDOWS-1257',
-                                           'ISO-8859-4'],
-                                 # Q, W, X, Y are only for loanwords
-                                 alphabet=(u'AĀBCČDEĒFGĢHIĪJKĶLĻMNŅOPRSŠTUŪVZŽ'
-                                           u'aābcčdeēfgģhiījkķlļmnņoprsštuūvzž'),
-                                 wiki_start_pages=[u'Sākumlapa']),
-             'Macedonian': Language(name='Macedonian',
-                                    iso_code='mk',
-                                    use_ascii=False,
-                                    charsets=['ISO-8859-5', 'WINDOWS-1251',
-                                              'MacCyrillic', 'IBM855'],
-                                    alphabet=(u'АБВГДЃЕЖЗЅИЈКЛЉМНЊОПРСТЌУФХЦЧЏШ'
-                                              u'абвгдѓежзѕијклљмнњопрстќуфхцчџш'),
-                                    wiki_start_pages=[u'Главна_страница']),
-             'Dutch': Language(name='Dutch',
-                               iso_code='nl',
-                               use_ascii=True,
-                               charsets=['ISO-8859-1', 'WINDOWS-1252'],
-                               wiki_start_pages=[u'Hoofdpagina']),
-             'Polish': Language(name='Polish',
-                                iso_code='pl',
-                                # Q and X are only used for foreign words.
-                                use_ascii=False,
-                                charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                                alphabet=(u'AĄBCĆDEĘFGHIJKLŁMNŃOÓPRSŚTUWYZŹŻ'
-                                          u'aąbcćdeęfghijklłmnńoóprsśtuwyzźż'),
-                                wiki_start_pages=[u'Wikipedia:Strona_główna']),
-             'Portuguese': Language(name='Portuguese',
-                                 iso_code='pt',
-                                 use_ascii=True,
-                                 charsets=['ISO-8859-1', 'ISO-8859-15',
-                                           'WINDOWS-1252'],
-                                 alphabet=u'ÁÂÃÀÇÉÊÍÓÔÕÚáâãàçéêíóôõú',
-                                 wiki_start_pages=[u'Wikipédia:Página_principal']),
-             'Romanian': Language(name='Romanian',
-                                  iso_code='ro',
-                                  use_ascii=True,
-                                  charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                                  alphabet=u'ăâîșțĂÂÎȘȚ',
-                                  wiki_start_pages=[u'Pagina_principală']),
-             'Russian': Language(name='Russian',
-                                 iso_code='ru',
-                                 use_ascii=False,
-                                 charsets=['ISO-8859-5', 'WINDOWS-1251',
-                                           'KOI8-R', 'MacCyrillic', 'IBM866',
-                                           'IBM855'],
-                                 alphabet=(u'абвгдеёжзийклмнопрстуфхцчшщъыьэюя'
-                                           u'АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ'),
-                                 wiki_start_pages=[u'Заглавная_страница']),
-             'Slovak': Language(name='Slovak',
-                                iso_code='sk',
-                                use_ascii=True,
-                                charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                                alphabet=u'áäčďéíĺľňóôŕšťúýžÁÄČĎÉÍĹĽŇÓÔŔŠŤÚÝŽ',
-                                wiki_start_pages=[u'Hlavná_stránka']),
-             'Slovene': Language(name='Slovene',
-                                 iso_code='sl',
-                                 # Q, W, X, Y are only used for foreign words.
-                                 use_ascii=False,
-                                 charsets=['ISO-8859-2', 'WINDOWS-1250'],
-                                 alphabet=(u'abcčdefghijklmnoprsštuvzž'
-                                           u'ABCČDEFGHIJKLMNOPRSŠTUVZŽ'),
-                                 wiki_start_pages=[u'Glavna_stran']),
-             # Serbian can be written in both Latin and Cyrillic, but there's no
-             # simple way to get the Latin alphabet pages from Wikipedia through
-             # the API, so for now we just support Cyrillic.
-             'Serbian': Language(name='Serbian',
-                                 iso_code='sr',
-                                 alphabet=(u'АБВГДЂЕЖЗИЈКЛЉМНЊОПРСТЋУФХЦЧЏШ'
-                                           u'абвгдђежзијклљмнњопрстћуфхцчџш'),
-                                 charsets=['ISO-8859-5', 'WINDOWS-1251',
-                                           'MacCyrillic', 'IBM855'],
-                                 wiki_start_pages=[u'Главна_страна']),
-             'Thai': Language(name='Thai',
-                              iso_code='th',
-                              use_ascii=False,
-                              charsets=['ISO-8859-11', 'TIS-620', 'CP874'],
-                              alphabet=u'กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛',
-                              wiki_start_pages=[u'หน้าหลัก']),
-             'Turkish': Language(name='Turkish',
-                                 iso_code='tr',
-                                 # Q, W, and X are not used by Turkish
-                                 use_ascii=False,
-                                 charsets=['ISO-8859-3', 'ISO-8859-9',
-                                           'WINDOWS-1254'],
-                                 alphabet=(u'abcçdefgğhıijklmnoöprsştuüvyzâîû'
-                                           u'ABCÇDEFGĞHIİJKLMNOÖPRSŞTUÜVYZÂÎÛ'),
-                                 wiki_start_pages=[u'Ana_Sayfa']),
-             'Vietnamese': Language(name='Vietnamese',
-                                    iso_code='vi',
-                                    use_ascii=False,
-                                    # Windows-1258 is the only common 8-bit
-                                    # Vietnamese encoding supported by Python.
-                                    # From Wikipedia:
-                                    # For systems that lack support for Unicode,
-                                    # dozens of 8-bit Vietnamese code pages are
-                                    # available.[1] The most common are VISCII
-                                    # (TCVN 5712:1993), VPS, and Windows-1258.[3]
-                                    # Where ASCII is required, such as when
-                                    # ensuring readability in plain text e-mail,
-                                    # Vietnamese letters are often encoded
-                                    # according to Vietnamese Quoted-Readable
-                                    # (VIQR) or VSCII Mnemonic (VSCII-MNEM),[4]
-                                    # though usage of either variable-width
-                                    # scheme has declined dramatically following
-                                    # the adoption of Unicode on the World Wide
-                                    # Web.
-                                    charsets=['WINDOWS-1258'],
-                                    alphabet=(u'aăâbcdđeêghiklmnoôơpqrstuưvxy'
-                                              u'AĂÂBCDĐEÊGHIKLMNOÔƠPQRSTUƯVXY'),
-                                    wiki_start_pages=[u'Chữ_Quốc_ngữ']),
-            }
+LANGUAGES = {
+    "Arabic": Language(
+        name="Arabic",
+        iso_code="ar",
+        use_ascii=False,
+        # We only support encodings that use isolated
+        # forms, because the current recommendation is
+        # that the rendering system handles presentation
+        # forms. This means we purposefully skip IBM864.
+        charsets=["ISO-8859-6", "WINDOWS-1256", "CP720", "CP864"],
+        alphabet="ءآأؤإئابةتثجحخدذرزسشصضطظعغػؼؽؾؿـفقكلمنهوىيًٌٍَُِّ",
+        wiki_start_pages=["الصفحة_الرئيسية"],
+    ),
+    "Belarusian": Language(
+        name="Belarusian",
+        iso_code="be",
+        use_ascii=False,
+        charsets=["ISO-8859-5", "WINDOWS-1251", "IBM866", "MacCyrillic"],
+        alphabet="АБВГДЕЁЖЗІЙКЛМНОПРСТУЎФХЦЧШЫЬЭЮЯабвгдеёжзійклмнопрстуўфхцчшыьэюяʼ",
+        wiki_start_pages=["Галоўная_старонка"],
+    ),
+    "Bulgarian": Language(
+        name="Bulgarian",
+        iso_code="bg",
+        use_ascii=False,
+        charsets=["ISO-8859-5", "WINDOWS-1251", "IBM855"],
+        alphabet="АБВГДЕЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЬЮЯабвгдежзийклмнопрстуфхцчшщъьюя",
+        wiki_start_pages=["Начална_страница"],
+    ),
+    "Czech": Language(
+        name="Czech",
+        iso_code="cz",
+        use_ascii=True,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="áčďéěíňóřšťúůýžÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ",
+        wiki_start_pages=["Hlavní_strana"],
+    ),
+    "Danish": Language(
+        name="Danish",
+        iso_code="da",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="æøåÆØÅ",
+        wiki_start_pages=["Forside"],
+    ),
+    "German": Language(
+        name="German",
+        iso_code="de",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="äöüßẞÄÖÜ",
+        wiki_start_pages=["Wikipedia:Hauptseite"],
+    ),
+    "Greek": Language(
+        name="Greek",
+        iso_code="el",
+        use_ascii=False,
+        charsets=["ISO-8859-7", "WINDOWS-1253"],
+        alphabet="αβγδεζηθικλμνξοπρσςτυφχψωάέήίόύώΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΣΤΥΦΧΨΩΆΈΉΊΌΎΏ",
+        wiki_start_pages=["Πύλη:Κύρια"],
+    ),
+    "English": Language(
+        name="English",
+        iso_code="en",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "WINDOWS-1252", "MacRoman"],
+        wiki_start_pages=["Main_Page"],
+    ),
+    "Esperanto": Language(
+        name="Esperanto",
+        iso_code="eo",
+        # Q, W, X, and Y not used at all
+        use_ascii=False,
+        charsets=["ISO-8859-3"],
+        alphabet="abcĉdefgĝhĥijĵklmnoprsŝtuŭvzABCĈDEFGĜHĤIJĴKLMNOPRSŜTUŬVZ",
+        wiki_start_pages=["Vikipedio:Ĉefpaĝo"],
+    ),
+    "Spanish": Language(
+        name="Spanish",
+        iso_code="es",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="ñáéíóúüÑÁÉÍÓÚÜ",
+        wiki_start_pages=["Wikipedia:Portada"],
+    ),
+    "Estonian": Language(
+        name="Estonian",
+        iso_code="et",
+        use_ascii=False,
+        charsets=["ISO-8859-4", "ISO-8859-13", "WINDOWS-1257"],
+        # C, F, Š, Q, W, X, Y, Z, Ž are only for
+        # loanwords
+        alphabet="ABDEGHIJKLMNOPRSTUVÕÄÖÜabdeghijklmnoprstuvõäöü",
+        wiki_start_pages=["Esileht"],
+    ),
+    "Finnish": Language(
+        name="Finnish",
+        iso_code="fi",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="ÅÄÖŠŽåäöšž",
+        wiki_start_pages=["Wikipedia:Etusivu"],
+    ),
+    "French": Language(
+        name="French",
+        iso_code="fr",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="œàâçèéîïùûêŒÀÂÇÈÉÎÏÙÛÊ",
+        wiki_start_pages=["Wikipédia:Accueil_principal", "Bœuf (animal)"],
+    ),
+    "Hebrew": Language(
+        name="Hebrew",
+        iso_code="he",
+        use_ascii=False,
+        charsets=["ISO-8859-8", "WINDOWS-1255"],
+        alphabet="אבגדהוזחטיךכלםמןנסעףפץצקרשתװױײ",
+        wiki_start_pages=["עמוד_ראשי"],
+    ),
+    "Croatian": Language(
+        name="Croatian",
+        iso_code="hr",
+        # Q, W, X, Y are only used for foreign words.
+        use_ascii=False,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="abcčćdđefghijklmnoprsštuvzžABCČĆDĐEFGHIJKLMNOPRSŠTUVZŽ",
+        wiki_start_pages=["Glavna_stranica"],
+    ),
+    "Hungarian": Language(
+        name="Hungarian",
+        iso_code="hu",
+        # Q, W, X, Y are only used for foreign words.
+        use_ascii=False,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="abcdefghijklmnoprstuvzáéíóöőúüűABCDEFGHIJKLMNOPRSTUVZÁÉÍÓÖŐÚÜŰ",
+        wiki_start_pages=["Kezdőlap"],
+    ),
+    "Italian": Language(
+        name="Italian",
+        iso_code="it",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="ÀÈÉÌÒÓÙàèéìòóù",
+        wiki_start_pages=["Pagina_principale"],
+    ),
+    "Lithuanian": Language(
+        name="Lithuanian",
+        iso_code="lt",
+        use_ascii=False,
+        charsets=["ISO-8859-13", "WINDOWS-1257", "ISO-8859-4"],
+        # Q, W, and X not used at all
+        alphabet="AĄBCČDEĘĖFGHIĮYJKLMNOPRSŠTUŲŪVZŽaąbcčdeęėfghiįyjklmnoprsštuųūvzž",
+        wiki_start_pages=["Pagrindinis_puslapis"],
+    ),
+    "Latvian": Language(
+        name="Latvian",
+        iso_code="lv",
+        use_ascii=False,
+        charsets=["ISO-8859-13", "WINDOWS-1257", "ISO-8859-4"],
+        # Q, W, X, Y are only for loanwords
+        alphabet="AĀBCČDEĒFGĢHIĪJKĶLĻMNŅOPRSŠTUŪVZŽaābcčdeēfgģhiījkķlļmnņoprsštuūvzž",
+        wiki_start_pages=["Sākumlapa"],
+    ),
+    "Macedonian": Language(
+        name="Macedonian",
+        iso_code="mk",
+        use_ascii=False,
+        charsets=["ISO-8859-5", "WINDOWS-1251", "MacCyrillic", "IBM855"],
+        alphabet="АБВГДЃЕЖЗЅИЈКЛЉМНЊОПРСТЌУФХЦЧЏШабвгдѓежзѕијклљмнњопрстќуфхцчџш",
+        wiki_start_pages=["Главна_страница"],
+    ),
+    "Dutch": Language(
+        name="Dutch",
+        iso_code="nl",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "WINDOWS-1252", "MacRoman"],
+        wiki_start_pages=["Hoofdpagina"],
+    ),
+    "Polish": Language(
+        name="Polish",
+        iso_code="pl",
+        # Q and X are only used for foreign words.
+        use_ascii=False,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="AĄBCĆDEĘFGHIJKLŁMNŃOÓPRSŚTUWYZŹŻaąbcćdeęfghijklłmnńoóprsśtuwyzźż",
+        wiki_start_pages=["Wikipedia:Strona_główna"],
+    ),
+    "Portuguese": Language(
+        name="Portuguese",
+        iso_code="pt",
+        use_ascii=True,
+        charsets=["ISO-8859-1", "ISO-8859-15", "WINDOWS-1252", "MacRoman"],
+        alphabet="ÁÂÃÀÇÉÊÍÓÔÕÚáâãàçéêíóôõú",
+        wiki_start_pages=["Wikipédia:Página_principal"],
+    ),
+    "Romanian": Language(
+        name="Romanian",
+        iso_code="ro",
+        use_ascii=True,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="ăâîșțĂÂÎȘȚ",
+        wiki_start_pages=["Pagina_principală"],
+    ),
+    "Russian": Language(
+        name="Russian",
+        iso_code="ru",
+        use_ascii=False,
+        charsets=[
+            "ISO-8859-5",
+            "WINDOWS-1251",
+            "KOI8-R",
+            "MacCyrillic",
+            "IBM866",
+            "IBM855",
+        ],
+        alphabet="абвгдеёжзийклмнопрстуфхцчшщъыьэюяАБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ",
+        wiki_start_pages=["Заглавная_страница"],
+    ),
+    "Slovak": Language(
+        name="Slovak",
+        iso_code="sk",
+        use_ascii=True,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="áäčďéíĺľňóôŕšťúýžÁÄČĎÉÍĹĽŇÓÔŔŠŤÚÝŽ",
+        wiki_start_pages=["Hlavná_stránka"],
+    ),
+    "Slovene": Language(
+        name="Slovene",
+        iso_code="sl",
+        # Q, W, X, Y are only used for foreign words.
+        use_ascii=False,
+        charsets=["ISO-8859-2", "WINDOWS-1250"],
+        alphabet="abcčdefghijklmnoprsštuvzžABCČDEFGHIJKLMNOPRSŠTUVZŽ",
+        wiki_start_pages=["Glavna_stran"],
+    ),
+    # Serbian can be written in both Latin and Cyrillic, but there's no
+    # simple way to get the Latin alphabet pages from Wikipedia through
+    # the API, so for now we just support Cyrillic.
+    "Serbian": Language(
+        name="Serbian",
+        iso_code="sr",
+        alphabet="АБВГДЂЕЖЗИЈКЛЉМНЊОПРСТЋУФХЦЧЏШабвгдђежзијклљмнњопрстћуфхцчџш",
+        charsets=["ISO-8859-5", "WINDOWS-1251", "MacCyrillic", "IBM855"],
+        wiki_start_pages=["Главна_страна"],
+    ),
+    "Thai": Language(
+        name="Thai",
+        iso_code="th",
+        use_ascii=False,
+        charsets=["ISO-8859-11", "TIS-620", "CP874"],
+        alphabet="กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛",
+        wiki_start_pages=["หน้าหลัก"],
+    ),
+    "Turkish": Language(
+        name="Turkish",
+        iso_code="tr",
+        # Q, W, and X are not used by Turkish
+        use_ascii=False,
+        charsets=["ISO-8859-3", "ISO-8859-9", "WINDOWS-1254"],
+        alphabet="abcçdefgğhıijklmnoöprsştuüvyzâîûABCÇDEFGĞHIİJKLMNOÖPRSŞTUÜVYZÂÎÛ",
+        wiki_start_pages=["Ana_Sayfa"],
+    ),
+    "Vietnamese": Language(
+        name="Vietnamese",
+        iso_code="vi",
+        use_ascii=False,
+        # Windows-1258 is the only common 8-bit
+        # Vietnamese encoding supported by Python.
+        # From Wikipedia:
+        # For systems that lack support for Unicode,
+        # dozens of 8-bit Vietnamese code pages are
+        # available.[1] The most common are VISCII
+        # (TCVN 5712:1993), VPS, and Windows-1258.[3]
+        # Where ASCII is required, such as when
+        # ensuring readability in plain text e-mail,
+        # Vietnamese letters are often encoded
+        # according to Vietnamese Quoted-Readable
+        # (VIQR) or VSCII Mnemonic (VSCII-MNEM),[4]
+        # though usage of either variable-width
+        # scheme has declined dramatically following
+        # the adoption of Unicode on the World Wide
+        # Web.
+        charsets=["WINDOWS-1258"],
+        alphabet="aăâbcdđeêghiklmnoôơpqrstuưvxyAĂÂBCDĐEÊGHIKLMNOÔƠPQRSTUƯVXY",
+        wiki_start_pages=["Chữ_Quốc_ngữ"],
+    ),
+}
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py b/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py
index 46ba835c..0ffbcdd2 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/sbcharsetprober.py
@@ -26,70 +26,77 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from collections import namedtuple
+from typing import Dict, List, NamedTuple, Optional, Union
 
 from .charsetprober import CharSetProber
 from .enums import CharacterCategory, ProbingState, SequenceLikelihood
 
 
-SingleByteCharSetModel = namedtuple('SingleByteCharSetModel',
-                                    ['charset_name',
-                                     'language',
-                                     'char_to_order_map',
-                                     'language_model',
-                                     'typical_positive_ratio',
-                                     'keep_ascii_letters',
-                                     'alphabet'])
+class SingleByteCharSetModel(NamedTuple):
+    charset_name: str
+    language: str
+    char_to_order_map: Dict[int, int]
+    language_model: Dict[int, Dict[int, int]]
+    typical_positive_ratio: float
+    keep_ascii_letters: bool
+    alphabet: str
 
 
 class SingleByteCharSetProber(CharSetProber):
     SAMPLE_SIZE = 64
-    SB_ENOUGH_REL_THRESHOLD = 1024  #  0.25 * SAMPLE_SIZE^2
+    SB_ENOUGH_REL_THRESHOLD = 1024  # 0.25 * SAMPLE_SIZE^2
     POSITIVE_SHORTCUT_THRESHOLD = 0.95
     NEGATIVE_SHORTCUT_THRESHOLD = 0.05
 
-    def __init__(self, model, reversed=False, name_prober=None):
-        super(SingleByteCharSetProber, self).__init__()
+    def __init__(
+        self,
+        model: SingleByteCharSetModel,
+        is_reversed: bool = False,
+        name_prober: Optional[CharSetProber] = None,
+    ) -> None:
+        super().__init__()
         self._model = model
         # TRUE if we need to reverse every pair in the model lookup
-        self._reversed = reversed
+        self._reversed = is_reversed
         # Optional auxiliary prober for name decision
         self._name_prober = name_prober
-        self._last_order = None
-        self._seq_counters = None
-        self._total_seqs = None
-        self._total_char = None
-        self._freq_char = None
+        self._last_order = 255
+        self._seq_counters: List[int] = []
+        self._total_seqs = 0
+        self._total_char = 0
+        self._control_char = 0
+        self._freq_char = 0
         self.reset()
 
-    def reset(self):
-        super(SingleByteCharSetProber, self).reset()
+    def reset(self) -> None:
+        super().reset()
         # char order of last character
         self._last_order = 255
         self._seq_counters = [0] * SequenceLikelihood.get_num_categories()
         self._total_seqs = 0
         self._total_char = 0
+        self._control_char = 0
         # characters that fall in our sampling range
         self._freq_char = 0
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> Optional[str]:
         if self._name_prober:
             return self._name_prober.charset_name
-        else:
-            return self._model.charset_name
+        return self._model.charset_name
 
     @property
-    def language(self):
+    def language(self) -> Optional[str]:
         if self._name_prober:
             return self._name_prober.language
-        else:
-            return self._model.language
+        return self._model.language
 
-    def feed(self, byte_str):
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
         # TODO: Make filter_international_words keep things in self.alphabet
         if not self._model.keep_ascii_letters:
             byte_str = self.filter_international_words(byte_str)
+        else:
+            byte_str = self.remove_xml_tags(byte_str)
         if not byte_str:
             return self.state
         char_to_order_map = self._model.char_to_order_map
@@ -103,9 +110,6 @@ class SingleByteCharSetProber(CharSetProber):
             #      _total_char purposes.
             if order < CharacterCategory.CONTROL:
                 self._total_char += 1
-            # TODO: Follow uchardet's lead and discount confidence for frequent
-            #       control characters.
-            #       See https://github.com/BYVoid/uchardet/commit/55b4f23971db61
             if order < self.SAMPLE_SIZE:
                 self._freq_char += 1
                 if self._last_order < self.SAMPLE_SIZE:
@@ -122,23 +126,36 @@ class SingleByteCharSetProber(CharSetProber):
             if self._total_seqs > self.SB_ENOUGH_REL_THRESHOLD:
                 confidence = self.get_confidence()
                 if confidence > self.POSITIVE_SHORTCUT_THRESHOLD:
-                    self.logger.debug('%s confidence = %s, we have a winner',
-                                      charset_name, confidence)
+                    self.logger.debug(
+                        "%s confidence = %s, we have a winner", charset_name, confidence
+                    )
                     self._state = ProbingState.FOUND_IT
                 elif confidence < self.NEGATIVE_SHORTCUT_THRESHOLD:
-                    self.logger.debug('%s confidence = %s, below negative '
-                                      'shortcut threshhold %s', charset_name,
-                                      confidence,
-                                      self.NEGATIVE_SHORTCUT_THRESHOLD)
+                    self.logger.debug(
+                        "%s confidence = %s, below negative shortcut threshold %s",
+                        charset_name,
+                        confidence,
+                        self.NEGATIVE_SHORTCUT_THRESHOLD,
+                    )
                     self._state = ProbingState.NOT_ME
 
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         r = 0.01
         if self._total_seqs > 0:
-            r = ((1.0 * self._seq_counters[SequenceLikelihood.POSITIVE]) /
-                 self._total_seqs / self._model.typical_positive_ratio)
+            r = (
+                (
+                    self._seq_counters[SequenceLikelihood.POSITIVE]
+                    + 0.25 * self._seq_counters[SequenceLikelihood.LIKELY]
+                )
+                / self._total_seqs
+                / self._model.typical_positive_ratio
+            )
+            # The more control characters (proportionnaly to the size
+            # of the text), the less confident we become in the current
+            # charset.
+            r = r * (self._total_char - self._control_char) / self._total_char
             r = r * self._freq_char / self._total_char
             if r >= 1.0:
                 r = 0.99
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py b/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py
index bdeef4e1..890ae846 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/sbcsgroupprober.py
@@ -28,33 +28,38 @@
 
 from .charsetgroupprober import CharSetGroupProber
 from .hebrewprober import HebrewProber
-from .langbulgarianmodel import (ISO_8859_5_BULGARIAN_MODEL,
-                                 WINDOWS_1251_BULGARIAN_MODEL)
+from .langbulgarianmodel import ISO_8859_5_BULGARIAN_MODEL, WINDOWS_1251_BULGARIAN_MODEL
 from .langgreekmodel import ISO_8859_7_GREEK_MODEL, WINDOWS_1253_GREEK_MODEL
 from .langhebrewmodel import WINDOWS_1255_HEBREW_MODEL
+
 # from .langhungarianmodel import (ISO_8859_2_HUNGARIAN_MODEL,
 #                                  WINDOWS_1250_HUNGARIAN_MODEL)
-from .langrussianmodel import (IBM855_RUSSIAN_MODEL, IBM866_RUSSIAN_MODEL,
-                               ISO_8859_5_RUSSIAN_MODEL, KOI8_R_RUSSIAN_MODEL,
-                               MACCYRILLIC_RUSSIAN_MODEL,
-                               WINDOWS_1251_RUSSIAN_MODEL)
+from .langrussianmodel import (
+    IBM855_RUSSIAN_MODEL,
+    IBM866_RUSSIAN_MODEL,
+    ISO_8859_5_RUSSIAN_MODEL,
+    KOI8_R_RUSSIAN_MODEL,
+    MACCYRILLIC_RUSSIAN_MODEL,
+    WINDOWS_1251_RUSSIAN_MODEL,
+)
 from .langthaimodel import TIS_620_THAI_MODEL
 from .langturkishmodel import ISO_8859_9_TURKISH_MODEL
 from .sbcharsetprober import SingleByteCharSetProber
 
 
 class SBCSGroupProber(CharSetGroupProber):
-    def __init__(self):
-        super(SBCSGroupProber, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         hebrew_prober = HebrewProber()
-        logical_hebrew_prober = SingleByteCharSetProber(WINDOWS_1255_HEBREW_MODEL,
-                                                        False, hebrew_prober)
+        logical_hebrew_prober = SingleByteCharSetProber(
+            WINDOWS_1255_HEBREW_MODEL, is_reversed=False, name_prober=hebrew_prober
+        )
         # TODO: See if using ISO-8859-8 Hebrew model works better here, since
         #       it's actually the visual one
-        visual_hebrew_prober = SingleByteCharSetProber(WINDOWS_1255_HEBREW_MODEL,
-                                                       True, hebrew_prober)
-        hebrew_prober.set_model_probers(logical_hebrew_prober,
-                                        visual_hebrew_prober)
+        visual_hebrew_prober = SingleByteCharSetProber(
+            WINDOWS_1255_HEBREW_MODEL, is_reversed=True, name_prober=hebrew_prober
+        )
+        hebrew_prober.set_model_probers(logical_hebrew_prober, visual_hebrew_prober)
         # TODO: ORDER MATTERS HERE. I changed the order vs what was in master
         #       and several tests failed that did not before. Some thought
         #       should be put into the ordering, and we should consider making
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py b/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py
index 9e29623b..91df0779 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/sjisprober.py
@@ -25,68 +25,81 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
-from .mbcharsetprober import MultiByteCharSetProber
-from .codingstatemachine import CodingStateMachine
+from typing import Union
+
 from .chardistribution import SJISDistributionAnalysis
+from .codingstatemachine import CodingStateMachine
+from .enums import MachineState, ProbingState
 from .jpcntx import SJISContextAnalysis
+from .mbcharsetprober import MultiByteCharSetProber
 from .mbcssm import SJIS_SM_MODEL
-from .enums import ProbingState, MachineState
 
 
 class SJISProber(MultiByteCharSetProber):
-    def __init__(self):
-        super(SJISProber, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(SJIS_SM_MODEL)
         self.distribution_analyzer = SJISDistributionAnalysis()
         self.context_analyzer = SJISContextAnalysis()
         self.reset()
 
-    def reset(self):
-        super(SJISProber, self).reset()
+    def reset(self) -> None:
+        super().reset()
         self.context_analyzer.reset()
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return self.context_analyzer.charset_name
 
     @property
-    def language(self):
+    def language(self) -> str:
         return "Japanese"
 
-    def feed(self, byte_str):
-        for i in range(len(byte_str)):
-            coding_state = self.coding_sm.next_state(byte_str[i])
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
+        assert self.coding_sm is not None
+        assert self.distribution_analyzer is not None
+
+        for i, byte in enumerate(byte_str):
+            coding_state = self.coding_sm.next_state(byte)
             if coding_state == MachineState.ERROR:
-                self.logger.debug('%s %s prober hit error at byte %s',
-                                  self.charset_name, self.language, i)
+                self.logger.debug(
+                    "%s %s prober hit error at byte %s",
+                    self.charset_name,
+                    self.language,
+                    i,
+                )
                 self._state = ProbingState.NOT_ME
                 break
-            elif coding_state == MachineState.ITS_ME:
+            if coding_state == MachineState.ITS_ME:
                 self._state = ProbingState.FOUND_IT
                 break
-            elif coding_state == MachineState.START:
+            if coding_state == MachineState.START:
                 char_len = self.coding_sm.get_current_charlen()
                 if i == 0:
-                    self._last_char[1] = byte_str[0]
-                    self.context_analyzer.feed(self._last_char[2 - char_len:],
-                                               char_len)
+                    self._last_char[1] = byte
+                    self.context_analyzer.feed(
+                        self._last_char[2 - char_len :], char_len
+                    )
                     self.distribution_analyzer.feed(self._last_char, char_len)
                 else:
-                    self.context_analyzer.feed(byte_str[i + 1 - char_len:i + 3
-                                                        - char_len], char_len)
-                    self.distribution_analyzer.feed(byte_str[i - 1:i + 1],
-                                                    char_len)
+                    self.context_analyzer.feed(
+                        byte_str[i + 1 - char_len : i + 3 - char_len], char_len
+                    )
+                    self.distribution_analyzer.feed(byte_str[i - 1 : i + 1], char_len)
 
         self._last_char[0] = byte_str[-1]
 
         if self.state == ProbingState.DETECTING:
-            if (self.context_analyzer.got_enough_data() and
-               (self.get_confidence() > self.SHORTCUT_THRESHOLD)):
+            if self.context_analyzer.got_enough_data() and (
+                self.get_confidence() > self.SHORTCUT_THRESHOLD
+            ):
                 self._state = ProbingState.FOUND_IT
 
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
+        assert self.distribution_analyzer is not None
+
         context_conf = self.context_analyzer.get_confidence()
         distrib_conf = self.distribution_analyzer.get_confidence()
         return max(context_conf, distrib_conf)
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py b/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py
index 055a8ac1..30c441dc 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/universaldetector.py
@@ -39,16 +39,21 @@ class a user of ``chardet`` should use.
 import codecs
 import logging
 import re
+from typing import List, Optional, Union
 
 from .charsetgroupprober import CharSetGroupProber
+from .charsetprober import CharSetProber
 from .enums import InputState, LanguageFilter, ProbingState
 from .escprober import EscCharSetProber
 from .latin1prober import Latin1Prober
+from .macromanprober import MacRomanProber
 from .mbcsgroupprober import MBCSGroupProber
+from .resultdict import ResultDict
 from .sbcsgroupprober import SBCSGroupProber
+from .utf1632prober import UTF1632Prober
 
 
-class UniversalDetector(object):
+class UniversalDetector:
     """
     The ``UniversalDetector`` class underlies the ``chardet.detect`` function
     and coordinates all of the different charset probers.
@@ -66,49 +71,87 @@ class UniversalDetector(object):
     """
 
     MINIMUM_THRESHOLD = 0.20
-    HIGH_BYTE_DETECTOR = re.compile(b'[\x80-\xFF]')
-    ESC_DETECTOR = re.compile(b'(\033|~{)')
-    WIN_BYTE_DETECTOR = re.compile(b'[\x80-\x9F]')
-    ISO_WIN_MAP = {'iso-8859-1': 'Windows-1252',
-                   'iso-8859-2': 'Windows-1250',
-                   'iso-8859-5': 'Windows-1251',
-                   'iso-8859-6': 'Windows-1256',
-                   'iso-8859-7': 'Windows-1253',
-                   'iso-8859-8': 'Windows-1255',
-                   'iso-8859-9': 'Windows-1254',
-                   'iso-8859-13': 'Windows-1257'}
-
-    def __init__(self, lang_filter=LanguageFilter.ALL):
-        self._esc_charset_prober = None
-        self._charset_probers = []
-        self.result = None
-        self.done = None
-        self._got_data = None
-        self._input_state = None
-        self._last_char = None
+    HIGH_BYTE_DETECTOR = re.compile(b"[\x80-\xFF]")
+    ESC_DETECTOR = re.compile(b"(\033|~{)")
+    WIN_BYTE_DETECTOR = re.compile(b"[\x80-\x9F]")
+    ISO_WIN_MAP = {
+        "iso-8859-1": "Windows-1252",
+        "iso-8859-2": "Windows-1250",
+        "iso-8859-5": "Windows-1251",
+        "iso-8859-6": "Windows-1256",
+        "iso-8859-7": "Windows-1253",
+        "iso-8859-8": "Windows-1255",
+        "iso-8859-9": "Windows-1254",
+        "iso-8859-13": "Windows-1257",
+    }
+    # Based on https://encoding.spec.whatwg.org/#names-and-labels
+    # but altered to match Python names for encodings and remove mappings
+    # that break tests.
+    LEGACY_MAP = {
+        "ascii": "Windows-1252",
+        "iso-8859-1": "Windows-1252",
+        "tis-620": "ISO-8859-11",
+        "iso-8859-9": "Windows-1254",
+        "gb2312": "GB18030",
+        "euc-kr": "CP949",
+        "utf-16le": "UTF-16",
+    }
+
+    def __init__(
+        self,
+        lang_filter: LanguageFilter = LanguageFilter.ALL,
+        should_rename_legacy: bool = False,
+    ) -> None:
+        self._esc_charset_prober: Optional[EscCharSetProber] = None
+        self._utf1632_prober: Optional[UTF1632Prober] = None
+        self._charset_probers: List[CharSetProber] = []
+        self.result: ResultDict = {
+            "encoding": None,
+            "confidence": 0.0,
+            "language": None,
+        }
+        self.done = False
+        self._got_data = False
+        self._input_state = InputState.PURE_ASCII
+        self._last_char = b""
         self.lang_filter = lang_filter
         self.logger = logging.getLogger(__name__)
-        self._has_win_bytes = None
+        self._has_win_bytes = False
+        self.should_rename_legacy = should_rename_legacy
         self.reset()
 
-    def reset(self):
+    @property
+    def input_state(self) -> int:
+        return self._input_state
+
+    @property
+    def has_win_bytes(self) -> bool:
+        return self._has_win_bytes
+
+    @property
+    def charset_probers(self) -> List[CharSetProber]:
+        return self._charset_probers
+
+    def reset(self) -> None:
         """
         Reset the UniversalDetector and all of its probers back to their
         initial states.  This is called by ``__init__``, so you only need to
         call this directly in between analyses of different documents.
         """
-        self.result = {'encoding': None, 'confidence': 0.0, 'language': None}
+        self.result = {"encoding": None, "confidence": 0.0, "language": None}
         self.done = False
         self._got_data = False
         self._has_win_bytes = False
         self._input_state = InputState.PURE_ASCII
-        self._last_char = b''
+        self._last_char = b""
         if self._esc_charset_prober:
             self._esc_charset_prober.reset()
+        if self._utf1632_prober:
+            self._utf1632_prober.reset()
         for prober in self._charset_probers:
             prober.reset()
 
-    def feed(self, byte_str):
+    def feed(self, byte_str: Union[bytes, bytearray]) -> None:
         """
         Takes a chunk of a document and feeds it through all of the relevant
         charset probers.
@@ -125,7 +168,7 @@ class UniversalDetector(object):
         if self.done:
             return
 
-        if not len(byte_str):
+        if not byte_str:
             return
 
         if not isinstance(byte_str, bytearray):
@@ -136,35 +179,38 @@ class UniversalDetector(object):
             # If the data starts with BOM, we know it is UTF
             if byte_str.startswith(codecs.BOM_UTF8):
                 # EF BB BF  UTF-8 with BOM
-                self.result = {'encoding': "UTF-8-SIG",
-                               'confidence': 1.0,
-                               'language': ''}
-            elif byte_str.startswith((codecs.BOM_UTF32_LE,
-                                      codecs.BOM_UTF32_BE)):
+                self.result = {
+                    "encoding": "UTF-8-SIG",
+                    "confidence": 1.0,
+                    "language": "",
+                }
+            elif byte_str.startswith((codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE)):
                 # FF FE 00 00  UTF-32, little-endian BOM
                 # 00 00 FE FF  UTF-32, big-endian BOM
-                self.result = {'encoding': "UTF-32",
-                               'confidence': 1.0,
-                               'language': ''}
-            elif byte_str.startswith(b'\xFE\xFF\x00\x00'):
+                self.result = {"encoding": "UTF-32", "confidence": 1.0, "language": ""}
+            elif byte_str.startswith(b"\xFE\xFF\x00\x00"):
                 # FE FF 00 00  UCS-4, unusual octet order BOM (3412)
-                self.result = {'encoding': "X-ISO-10646-UCS-4-3412",
-                               'confidence': 1.0,
-                               'language': ''}
-            elif byte_str.startswith(b'\x00\x00\xFF\xFE'):
+                self.result = {
+                    # TODO: This encoding is not supported by Python. Should remove?
+                    "encoding": "X-ISO-10646-UCS-4-3412",
+                    "confidence": 1.0,
+                    "language": "",
+                }
+            elif byte_str.startswith(b"\x00\x00\xFF\xFE"):
                 # 00 00 FF FE  UCS-4, unusual octet order BOM (2143)
-                self.result = {'encoding': "X-ISO-10646-UCS-4-2143",
-                               'confidence': 1.0,
-                               'language': ''}
+                self.result = {
+                    # TODO: This encoding is not supported by Python. Should remove?
+                    "encoding": "X-ISO-10646-UCS-4-2143",
+                    "confidence": 1.0,
+                    "language": "",
+                }
             elif byte_str.startswith((codecs.BOM_LE, codecs.BOM_BE)):
                 # FF FE  UTF-16, little endian BOM
                 # FE FF  UTF-16, big endian BOM
-                self.result = {'encoding': "UTF-16",
-                               'confidence': 1.0,
-                               'language': ''}
+                self.result = {"encoding": "UTF-16", "confidence": 1.0, "language": ""}
 
             self._got_data = True
-            if self.result['encoding'] is not None:
+            if self.result["encoding"] is not None:
                 self.done = True
                 return
 
@@ -173,12 +219,29 @@ class UniversalDetector(object):
         if self._input_state == InputState.PURE_ASCII:
             if self.HIGH_BYTE_DETECTOR.search(byte_str):
                 self._input_state = InputState.HIGH_BYTE
-            elif self._input_state == InputState.PURE_ASCII and \
-                    self.ESC_DETECTOR.search(self._last_char + byte_str):
+            elif (
+                self._input_state == InputState.PURE_ASCII
+                and self.ESC_DETECTOR.search(self._last_char + byte_str)
+            ):
                 self._input_state = InputState.ESC_ASCII
 
         self._last_char = byte_str[-1:]
 
+        # next we will look to see if it is appears to be either a UTF-16 or
+        # UTF-32 encoding
+        if not self._utf1632_prober:
+            self._utf1632_prober = UTF1632Prober()
+
+        if self._utf1632_prober.state == ProbingState.DETECTING:
+            if self._utf1632_prober.feed(byte_str) == ProbingState.FOUND_IT:
+                self.result = {
+                    "encoding": self._utf1632_prober.charset_name,
+                    "confidence": self._utf1632_prober.get_confidence(),
+                    "language": "",
+                }
+                self.done = True
+                return
+
         # If we've seen escape sequences, use the EscCharSetProber, which
         # uses a simple state machine to check for known escape sequences in
         # HZ and ISO-2022 encodings, since those are the only encodings that
@@ -187,12 +250,11 @@ class UniversalDetector(object):
             if not self._esc_charset_prober:
                 self._esc_charset_prober = EscCharSetProber(self.lang_filter)
             if self._esc_charset_prober.feed(byte_str) == ProbingState.FOUND_IT:
-                self.result = {'encoding':
-                               self._esc_charset_prober.charset_name,
-                               'confidence':
-                               self._esc_charset_prober.get_confidence(),
-                               'language':
-                               self._esc_charset_prober.language}
+                self.result = {
+                    "encoding": self._esc_charset_prober.charset_name,
+                    "confidence": self._esc_charset_prober.get_confidence(),
+                    "language": self._esc_charset_prober.language,
+                }
                 self.done = True
         # If we've seen high bytes (i.e., those with values greater than 127),
         # we need to do more complicated checks using all our multi-byte and
@@ -207,17 +269,20 @@ class UniversalDetector(object):
                 if self.lang_filter & LanguageFilter.NON_CJK:
                     self._charset_probers.append(SBCSGroupProber())
                 self._charset_probers.append(Latin1Prober())
+                self._charset_probers.append(MacRomanProber())
             for prober in self._charset_probers:
                 if prober.feed(byte_str) == ProbingState.FOUND_IT:
-                    self.result = {'encoding': prober.charset_name,
-                                   'confidence': prober.get_confidence(),
-                                   'language': prober.language}
+                    self.result = {
+                        "encoding": prober.charset_name,
+                        "confidence": prober.get_confidence(),
+                        "language": prober.language,
+                    }
                     self.done = True
                     break
             if self.WIN_BYTE_DETECTOR.search(byte_str):
                 self._has_win_bytes = True
 
-    def close(self):
+    def close(self) -> ResultDict:
         """
         Stop analyzing the current document and come up with a final
         prediction.
@@ -231,13 +296,11 @@ class UniversalDetector(object):
         self.done = True
 
         if not self._got_data:
-            self.logger.debug('no data received!')
+            self.logger.debug("no data received!")
 
         # Default to ASCII if it is all we've seen so far
         elif self._input_state == InputState.PURE_ASCII:
-            self.result = {'encoding': 'ascii',
-                           'confidence': 1.0,
-                           'language': ''}
+            self.result = {"encoding": "ascii", "confidence": 1.0, "language": ""}
 
         # If we have seen non-ASCII, return the best that met MINIMUM_THRESHOLD
         elif self._input_state == InputState.HIGH_BYTE:
@@ -253,34 +316,47 @@ class UniversalDetector(object):
                     max_prober = prober
             if max_prober and (max_prober_confidence > self.MINIMUM_THRESHOLD):
                 charset_name = max_prober.charset_name
-                lower_charset_name = max_prober.charset_name.lower()
+                assert charset_name is not None
+                lower_charset_name = charset_name.lower()
                 confidence = max_prober.get_confidence()
                 # Use Windows encoding name instead of ISO-8859 if we saw any
                 # extra Windows-specific bytes
-                if lower_charset_name.startswith('iso-8859'):
+                if lower_charset_name.startswith("iso-8859"):
                     if self._has_win_bytes:
-                        charset_name = self.ISO_WIN_MAP.get(lower_charset_name,
-                                                            charset_name)
-                self.result = {'encoding': charset_name,
-                               'confidence': confidence,
-                               'language': max_prober.language}
+                        charset_name = self.ISO_WIN_MAP.get(
+                            lower_charset_name, charset_name
+                        )
+                # Rename legacy encodings with superset encodings if asked
+                if self.should_rename_legacy:
+                    charset_name = self.LEGACY_MAP.get(
+                        (charset_name or "").lower(), charset_name
+                    )
+                self.result = {
+                    "encoding": charset_name,
+                    "confidence": confidence,
+                    "language": max_prober.language,
+                }
 
         # Log all prober confidences if none met MINIMUM_THRESHOLD
         if self.logger.getEffectiveLevel() <= logging.DEBUG:
-            if self.result['encoding'] is None:
-                self.logger.debug('no probers hit minimum threshold')
+            if self.result["encoding"] is None:
+                self.logger.debug("no probers hit minimum threshold")
                 for group_prober in self._charset_probers:
                     if not group_prober:
                         continue
                     if isinstance(group_prober, CharSetGroupProber):
                         for prober in group_prober.probers:
-                            self.logger.debug('%s %s confidence = %s',
-                                              prober.charset_name,
-                                              prober.language,
-                                              prober.get_confidence())
+                            self.logger.debug(
+                                "%s %s confidence = %s",
+                                prober.charset_name,
+                                prober.language,
+                                prober.get_confidence(),
+                            )
                     else:
-                        self.logger.debug('%s %s confidence = %s',
-                                          group_prober.charset_name,
-                                          group_prober.language,
-                                          group_prober.get_confidence())
+                        self.logger.debug(
+                            "%s %s confidence = %s",
+                            group_prober.charset_name,
+                            group_prober.language,
+                            group_prober.get_confidence(),
+                        )
         return self.result
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py b/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py
index 6c3196cc..d96354d9 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/utf8prober.py
@@ -25,45 +25,46 @@
 # 02110-1301  USA
 ######################### END LICENSE BLOCK #########################
 
+from typing import Union
+
 from .charsetprober import CharSetProber
-from .enums import ProbingState, MachineState
 from .codingstatemachine import CodingStateMachine
+from .enums import MachineState, ProbingState
 from .mbcssm import UTF8_SM_MODEL
 
 
-
 class UTF8Prober(CharSetProber):
     ONE_CHAR_PROB = 0.5
 
-    def __init__(self):
-        super(UTF8Prober, self).__init__()
+    def __init__(self) -> None:
+        super().__init__()
         self.coding_sm = CodingStateMachine(UTF8_SM_MODEL)
-        self._num_mb_chars = None
+        self._num_mb_chars = 0
         self.reset()
 
-    def reset(self):
-        super(UTF8Prober, self).reset()
+    def reset(self) -> None:
+        super().reset()
         self.coding_sm.reset()
         self._num_mb_chars = 0
 
     @property
-    def charset_name(self):
+    def charset_name(self) -> str:
         return "utf-8"
 
     @property
-    def language(self):
+    def language(self) -> str:
         return ""
 
-    def feed(self, byte_str):
+    def feed(self, byte_str: Union[bytes, bytearray]) -> ProbingState:
         for c in byte_str:
             coding_state = self.coding_sm.next_state(c)
             if coding_state == MachineState.ERROR:
                 self._state = ProbingState.NOT_ME
                 break
-            elif coding_state == MachineState.ITS_ME:
+            if coding_state == MachineState.ITS_ME:
                 self._state = ProbingState.FOUND_IT
                 break
-            elif coding_state == MachineState.START:
+            if coding_state == MachineState.START:
                 if self.coding_sm.get_current_charlen() >= 2:
                     self._num_mb_chars += 1
 
@@ -73,10 +74,9 @@ class UTF8Prober(CharSetProber):
 
         return self.state
 
-    def get_confidence(self):
+    def get_confidence(self) -> float:
         unlike = 0.99
         if self._num_mb_chars < 6:
-            unlike *= self.ONE_CHAR_PROB ** self._num_mb_chars
+            unlike *= self.ONE_CHAR_PROB**self._num_mb_chars
             return 1.0 - unlike
-        else:
-            return unlike
+        return unlike
diff --git a/env/Lib/site-packages/pip/_vendor/chardet/version.py b/env/Lib/site-packages/pip/_vendor/chardet/version.py
index 70369b9d..c5e9d85c 100644
--- a/env/Lib/site-packages/pip/_vendor/chardet/version.py
+++ b/env/Lib/site-packages/pip/_vendor/chardet/version.py
@@ -1,9 +1,9 @@
 """
 This module exists only to simplify retrieving the version number of chardet
-from within setup.py and from chardet subpackages.
+from within setuptools and from chardet subpackages.
 
 :author: Dan Blanchard (dan.blanchard@gmail.com)
 """
 
-__version__ = "4.0.0"
-VERSION = __version__.split('.')
+__version__ = "5.1.0"
+VERSION = __version__.split(".")
diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__init__.py b/env/Lib/site-packages/pip/_vendor/colorama/__init__.py
index b149ed79..383101cd 100644
--- a/env/Lib/site-packages/pip/_vendor/colorama/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/colorama/__init__.py
@@ -1,6 +1,7 @@
 # Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
-from .initialise import init, deinit, reinit, colorama_text
+from .initialise import init, deinit, reinit, colorama_text, just_fix_windows_console
 from .ansi import Fore, Back, Style, Cursor
 from .ansitowin32 import AnsiToWin32
 
-__version__ = '0.4.4'
+__version__ = '0.4.6'
+
diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index bd8cbdaf1421633e7f2105a59c4780d29403dc3b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 471
zcmYe~<>g{vU|^UdaWM5g0|Ucj5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlt3xMKR?v
zM=|HJM6ob}#F=tfbJ?QUa@nKUb2*|oayg?o!Q#w0T)Es)+>8t<EKxiuticSLY%duZ
z7#K8JZn0$MWtQAxOG$;$MG%@dIX@@AC^0uNz9hAx1f<L@zbN$<i&J89_AS=nlFFRa
zTWrpyMaB6=nvA!&9rKDaL-NBj^NfwESPk?{^i2FTd2exnjLb~T$t+GS0{NhbnSp_!
zhy_HjGB7aQVoA&^&MaaB@!3HH2Z-PV$#8>YO7hD=1{Q&W<`#E+d|7Hyab|vAeEdp=
zB7Trk5b>+g*(xTqIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00
z*wZm4*wxoHIK(wb!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{lwATc>RF+H_7
zrXaIGKfWwAFD1W79~Lb7@$n$f#mDOvRNmsS$<0qG%}KQbd9oPf9|=YYMjj>rEZ=~H

diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansi.cpython-39.pyc
deleted file mode 100644
index 289921d1e1e4cdb0a890634e8f0fc739658ba064..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3256
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
PfLB0FKumy*jS&O^ne2R8

diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/ansitowin32.cpython-39.pyc
deleted file mode 100644
index 5a1d0f29b5e7600235db474f382655bfbeeea474..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7722
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
ZK|TN_Z4M?GMiE8<W)?;cMmA;v0|4|y2;2Yw

diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/initialise.cpython-39.pyc
deleted file mode 100644
index afa6b47b1ecd18f626bde53106251302c2f2b69d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1738
zcmYe~<>g{vU|^UdaWJ)-oq^#oh=Yt-7#J8F7#J9eOBfg!QW#Pga~Pr^G-DJan9mf&
zl){w4oWq>U62-#EkiwYAn!=dKmcp3Gp2C>Ok;0P5nZlaF*1{0Ql_HeFk;2)+7{#5!
zmBQV^5XF<qn8lmIlfv7=(99Ucm%^9A-@*{ZpCXVV*uoGckir<upeg(k<Q~75j0_A6
znvA!&9rKDaL-NBj^Nfw$l0j0)n2CXb!5QRS2?hp+5{49pQpO^Y5{44SX2u0f3mF(0
zQW%06Rx<i&G8Zv3FfiQW&M(SLk1sAs$uBLr#aWbEoLUl}n3J=Tp@^M<0Ydz0cD9NM
zElw>ej!Df)$t;TT&r5YF$}CG&&{YWa^9*wh3ib?f3|8>;bMg0c4fb@533l~$4GwV)
zQZS1N2=IwXG||n;PtPna$;^&P%`1!X$xMnV&MZmQEl5nxPE1cNjw#42(2p-m%}dEI
z(ofFM$uCOGP1MiK%Ph%E%*iZH)hnnhVq;)n5CVA&6d??Z9E@O*kYq3y8Ui3TNF6u;
zIv5xjYM6_qN*HPwY8Y#n(wUnXi=;{zQy7~Wn;1)&vX~QDN|>@(6WKuQ6oyiUBC`~R
zMD{$f5{?oUkd7LL8s=tJ7KRe0c;-ZQkXo>+m=uOYPOvIAG*zsLoF!bvEhXFwcuIH|
zGBPrxFeP$<0$h{XuS%!9D6zoSEitD!RUtV)FD)lCxujU3JhLQ2Au+E~A-^OewMZec
zDBU)ss5CW1lkXODVqWDfuCT<M(p1-?qWq#;%*B<(x7Z+YRm2L4JrF0gs0a~@APyhM
zqJq>ESgdk``0>RhMX8Cow~!@4in$X@QY$h`;#2bTQg5+AIJY>8QbEy`S_BSbO_p1n
ziKQj^;KXr@Jvl$GEVZcQ7He@yQD(s{7Le(P#8Sioau*9I?!-Z{B?pQcCLu-+RyIa9
zCN4%cX1@O%Fq(yhk&CfNl7WE%cRE%;q+>o%I*w;5VFssanG)s_#&{M`@D_n0UXv9Z
zCPmz!bjt%G_&@|Nh=8YMh(p0{WJ^f}xzZTqN{|33O|gN}l@z*rKzRyeLOw{T4%j_4
z44Diyj7u2%7#SI=1X38n7#JDCLAi{9ks*(xgt3`{k--3**C1|V0{gNEWV9yJEtbTh
z^x|7=+2tS_;v|sykg(&0Wq|mS)QS=-key)XG4U}nF>){!$)Y<C9Kx_{PfBp{gMtPT
zT!J7j?%*l{2NyVNf!)K%!3Yj6Pz)!7QX|M6APmZZAPiQj2FisjMM|(-Si_vc*vnGO
zTEn`4aUnyIQVnYsQ!PUcLokCT6R1!U133bea*9Mj#T~4aD$d9+%}I#|r8Q6v03~Hj
zwjz*ci%@kGfy%vG>>z~&sYPgETO`21z~BW6QBcxgU}RxrVPyNy#su;SSWc70&Cf4H
zQ?N)Fl#02M^YcJ)kdv7NPF1(K6Z48QOY+M>MK8Gcgrqo-VMXA;1P39glmcfQM4aE^
zgBq2an3tHIS_F>7B2dVItwnMsA{}tp<mRW8=A_zzl3y`MEe9h9BL@=?GYcaN6Bsjd
QuyV<8u(L37ad5B$09HP0)&Kwi

diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/win32.cpython-39.pyc
deleted file mode 100644
index 0c8709f0ac9c87dfdfa044124483cfb128d9b41e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3970
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
b<u@BUR1GR0VhS4v3lBR73zrZF7Y7#r{xppU

diff --git a/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/colorama/__pycache__/winterm.cpython-39.pyc
deleted file mode 100644
index 958e35ccec9b08bd312a543e7c196a74e518634f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py b/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py
index 6039a054..abf209e6 100644
--- a/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py
+++ b/env/Lib/site-packages/pip/_vendor/colorama/ansitowin32.py
@@ -4,7 +4,7 @@ import sys
 import os
 
 from .ansi import AnsiFore, AnsiBack, AnsiStyle, Style, BEL
-from .winterm import WinTerm, WinColor, WinStyle
+from .winterm import enable_vt_processing, WinTerm, WinColor, WinStyle
 from .win32 import windll, winapi_test
 
 
@@ -37,6 +37,12 @@ class StreamWrapper(object):
     def __exit__(self, *args, **kwargs):
         return self.__wrapped.__exit__(*args, **kwargs)
 
+    def __setstate__(self, state):
+        self.__dict__ = state
+
+    def __getstate__(self):
+        return self.__dict__
+
     def write(self, text):
         self.__convertor.write(text)
 
@@ -57,7 +63,9 @@ class StreamWrapper(object):
         stream = self.__wrapped
         try:
             return stream.closed
-        except AttributeError:
+        # AttributeError in the case that the stream doesn't support being closed
+        # ValueError for the case that the stream has already been detached when atexit runs
+        except (AttributeError, ValueError):
             return True
 
 
@@ -86,15 +94,22 @@ class AnsiToWin32(object):
         # (e.g. Cygwin Terminal). In this case it's up to the terminal
         # to support the ANSI codes.
         conversion_supported = on_windows and winapi_test()
+        try:
+            fd = wrapped.fileno()
+        except Exception:
+            fd = -1
+        system_has_native_ansi = not on_windows or enable_vt_processing(fd)
+        have_tty = not self.stream.closed and self.stream.isatty()
+        need_conversion = conversion_supported and not system_has_native_ansi
 
         # should we strip ANSI sequences from our output?
         if strip is None:
-            strip = conversion_supported or (not self.stream.closed and not self.stream.isatty())
+            strip = need_conversion or not have_tty
         self.strip = strip
 
         # should we should convert ANSI sequences into win32 calls?
         if convert is None:
-            convert = conversion_supported and not self.stream.closed and self.stream.isatty()
+            convert = need_conversion and have_tty
         self.convert = convert
 
         # dict of ansi codes to win32 functions and parameters
@@ -256,3 +271,7 @@ class AnsiToWin32(object):
                     if params[0] in '02':
                         winterm.set_title(params[1])
         return text
+
+
+    def flush(self):
+        self.wrapped.flush()
diff --git a/env/Lib/site-packages/pip/_vendor/colorama/initialise.py b/env/Lib/site-packages/pip/_vendor/colorama/initialise.py
index 430d0668..d5fd4b71 100644
--- a/env/Lib/site-packages/pip/_vendor/colorama/initialise.py
+++ b/env/Lib/site-packages/pip/_vendor/colorama/initialise.py
@@ -6,13 +6,27 @@ import sys
 from .ansitowin32 import AnsiToWin32
 
 
-orig_stdout = None
-orig_stderr = None
+def _wipe_internal_state_for_tests():
+    global orig_stdout, orig_stderr
+    orig_stdout = None
+    orig_stderr = None
+
+    global wrapped_stdout, wrapped_stderr
+    wrapped_stdout = None
+    wrapped_stderr = None
 
-wrapped_stdout = None
-wrapped_stderr = None
+    global atexit_done
+    atexit_done = False
+
+    global fixed_windows_console
+    fixed_windows_console = False
 
-atexit_done = False
+    try:
+        # no-op if it wasn't registered
+        atexit.unregister(reset_all)
+    except AttributeError:
+        # python 2: no atexit.unregister. Oh well, we did our best.
+        pass
 
 
 def reset_all():
@@ -55,6 +69,29 @@ def deinit():
         sys.stderr = orig_stderr
 
 
+def just_fix_windows_console():
+    global fixed_windows_console
+
+    if sys.platform != "win32":
+        return
+    if fixed_windows_console:
+        return
+    if wrapped_stdout is not None or wrapped_stderr is not None:
+        # Someone already ran init() and it did stuff, so we won't second-guess them
+        return
+
+    # On newer versions of Windows, AnsiToWin32.__init__ will implicitly enable the
+    # native ANSI support in the console as a side-effect. We only need to actually
+    # replace sys.stdout/stderr if we're in the old-style conversion mode.
+    new_stdout = AnsiToWin32(sys.stdout, convert=None, strip=None, autoreset=False)
+    if new_stdout.convert:
+        sys.stdout = new_stdout
+    new_stderr = AnsiToWin32(sys.stderr, convert=None, strip=None, autoreset=False)
+    if new_stderr.convert:
+        sys.stderr = new_stderr
+
+    fixed_windows_console = True
+
 @contextlib.contextmanager
 def colorama_text(*args, **kwargs):
     init(*args, **kwargs)
@@ -78,3 +115,7 @@ def wrap_stream(stream, convert, strip, autoreset, wrap):
         if wrapper.should_wrap():
             stream = wrapper.stream
     return stream
+
+
+# Use this for initial setup as well, to reduce code duplication
+_wipe_internal_state_for_tests()
diff --git a/env/Lib/site-packages/pip/_vendor/colorama/win32.py b/env/Lib/site-packages/pip/_vendor/colorama/win32.py
index c2d83603..841b0e27 100644
--- a/env/Lib/site-packages/pip/_vendor/colorama/win32.py
+++ b/env/Lib/site-packages/pip/_vendor/colorama/win32.py
@@ -4,6 +4,8 @@
 STDOUT = -11
 STDERR = -12
 
+ENABLE_VIRTUAL_TERMINAL_PROCESSING = 0x0004
+
 try:
     import ctypes
     from ctypes import LibraryLoader
@@ -89,6 +91,20 @@ else:
     ]
     _SetConsoleTitleW.restype = wintypes.BOOL
 
+    _GetConsoleMode = windll.kernel32.GetConsoleMode
+    _GetConsoleMode.argtypes = [
+        wintypes.HANDLE,
+        POINTER(wintypes.DWORD)
+    ]
+    _GetConsoleMode.restype = wintypes.BOOL
+
+    _SetConsoleMode = windll.kernel32.SetConsoleMode
+    _SetConsoleMode.argtypes = [
+        wintypes.HANDLE,
+        wintypes.DWORD
+    ]
+    _SetConsoleMode.restype = wintypes.BOOL
+
     def _winapi_test(handle):
         csbi = CONSOLE_SCREEN_BUFFER_INFO()
         success = _GetConsoleScreenBufferInfo(
@@ -150,3 +166,15 @@ else:
 
     def SetConsoleTitle(title):
         return _SetConsoleTitleW(title)
+
+    def GetConsoleMode(handle):
+        mode = wintypes.DWORD()
+        success = _GetConsoleMode(handle, byref(mode))
+        if not success:
+            raise ctypes.WinError()
+        return mode.value
+
+    def SetConsoleMode(handle, mode):
+        success = _SetConsoleMode(handle, mode)
+        if not success:
+            raise ctypes.WinError()
diff --git a/env/Lib/site-packages/pip/_vendor/colorama/winterm.py b/env/Lib/site-packages/pip/_vendor/colorama/winterm.py
index 0fdb4ec4..aad867e8 100644
--- a/env/Lib/site-packages/pip/_vendor/colorama/winterm.py
+++ b/env/Lib/site-packages/pip/_vendor/colorama/winterm.py
@@ -1,6 +1,12 @@
 # Copyright Jonathan Hartley 2013. BSD 3-Clause license, see LICENSE file.
-from . import win32
+try:
+    from msvcrt import get_osfhandle
+except ImportError:
+    def get_osfhandle(_):
+        raise OSError("This isn't windows!")
+
 
+from . import win32
 
 # from wincon.h
 class WinColor(object):
@@ -167,3 +173,23 @@ class WinTerm(object):
 
     def set_title(self, title):
         win32.SetConsoleTitle(title)
+
+
+def enable_vt_processing(fd):
+    if win32.windll is None or not win32.winapi_test():
+        return False
+
+    try:
+        handle = get_osfhandle(fd)
+        mode = win32.GetConsoleMode(handle)
+        win32.SetConsoleMode(
+            handle,
+            mode | win32.ENABLE_VIRTUAL_TERMINAL_PROCESSING,
+        )
+
+        mode = win32.GetConsoleMode(handle)
+        if mode & win32.ENABLE_VIRTUAL_TERMINAL_PROCESSING:
+            return True
+    # Can get TypeError in testsuite where 'fd' is a Mock()
+    except (OSError, TypeError):
+        return False
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__init__.py b/env/Lib/site-packages/pip/_vendor/distlib/__init__.py
index 63d916e3..962173c8 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/__init__.py
@@ -1,12 +1,12 @@
 # -*- coding: utf-8 -*-
 #
-# Copyright (C) 2012-2019 Vinay Sajip.
+# Copyright (C) 2012-2022 Vinay Sajip.
 # Licensed to the Python Software Foundation under a contributor agreement.
 # See LICENSE.txt and CONTRIBUTORS.txt.
 #
 import logging
 
-__version__ = '0.3.1'
+__version__ = '0.3.6'
 
 class DistlibException(Exception):
     pass
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 26fe7876846643be9ad59f28927ee4e43dc81a5d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1084
zcmYe~<>g{vU|^UdaWK`DiGkrUh=Ytd7#J8F7#J9ea~K#HQW#Pga~Pr+QkbF`-5FAt
zQ&?IUQdm-%nwg`Rs{~RQQdn~sa#^BS7#YGD@>EzDQduhl7#Tp&ogsxSg}sF#g*}xa
zi>;YCiY1aEkI8@`m0<yUD#t>`D9%*Q1zf2t%?t|}85vR-gBdhAUV_}=SH)_eXRK$K
z4B{YTMwr8R7#J8*8KM|d7^0ZK8kuehxMUWW<YXqfRwSnulw{`T`DrrW;)svWOUzA;
zkH5tgAD^3_Qknx|^Tfv&mL}#vWL7d1u`w_}h+hrPRxzQ)sYS&xsW~Z`MKS()sV+sC
zWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llWuD-6pA+A9RW-$Q)J~4?Vx;gpjnZ+fU
z*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<@nxxbDfvbEDG(Ry$H!;pWtPOp>lIWM
zF)=VOaD&1g#Nc2A^EDZ7ar>3#<ai|JrR1a*VFU|EDLB4VP=Y0esf8hm84_brEGeuh
zY%L5?tSRiEa4rJHaWY6FEPO$1Q2087EN1~nd@#dGMn7=qtYo^yQk<HTc8jejH95a1
z1uO_5*cliYZn0&6ohHP<!0;JlV3iP(d-Wiagl#M0ghfOVD1k!E2S*Or5|-55%o1Uc
z5<Uh7hAIJMD?n1oAm@W@2VoE!<R!3oK&GWI)G)*|q%Z_CfUVJFyv34}pPa49SOf}g
zbi25ci&7IyQhoB1vqj)GiXq#GP~fM@R>TZa1PZkxRuGF9MDT+MK@b7<1A+kg1{?t(
z$zqT=2O|iA#WcBZvFGHcr)TD+-{OvsFH0>d&dkq?kH5tUPubu^0akpA+cUQyzo^8u
zs3^ba7CSV7+~Q16E%C`uPfslZJM0!4$iUR1TU?1LDNr>?9tJs}2;`<)95#?VVh7?C
Z3otM+a4@kj2{1D;3NZ38O0aS<0sveu<>3GT

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index 41b0909f21b95625ab9c3a5a93e9b92145f3754d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/database.cpython-39.pyc
deleted file mode 100644
index 912b3ee2d9dd1e4bc7da4e21c551ce45c0546ec1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 42508
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
YcnQ=q#Ii85FbmW(2y&TmNO4F404`X_aR2}S

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/index.cpython-39.pyc
deleted file mode 100644
index 9665374b7abc14d7f9b2570423b6a7eb9e68ba16..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/locators.cpython-39.pyc
deleted file mode 100644
index 0becc23bf9eef5df250973155261d3ffbe49934a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 38517
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
S-c0{ln3(>sv9U36F#`a{ktFE=

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/manifest.cpython-39.pyc
deleted file mode 100644
index 2aa069a2d60f9d2bac22989becf8ef4642702fab..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/markers.cpython-39.pyc
deleted file mode 100644
index 97123f12612c5c75856379337b9c09c8e05957a0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4511
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
F0RUtF5S9P{

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/metadata.cpython-39.pyc
deleted file mode 100644
index 14140c9e7b7cdb11ccdd68e4dea3a443d048f5e3..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/resources.cpython-39.pyc
deleted file mode 100644
index 8d057ac273a36f696a6677b930d9ed15a3e5d43a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 11050
zcmYe~<>g{vU|^UdaWIuni-F-Wh=Ytd85kHG7#J9eTNoJ_QW#Pga~N_NqZk=MY^EHh
zD5eyK6s8>JC}uFt62$_hS)*9NG+PuKm}ZY+2h$u;9AKI=iW5w8MRBDtr?BL3=ki4H
zFfybtr?BSm=JG}H<?=`I=L$p#<O)U!GBTvHED%Z+UdR|FlERcI>duhDmcrh`kiwoS
z*vuRy=FX79k;2)+kiwZN-pm{&;m(l4mBQV^kiwlR(aanr>CTYClfv7=kirY*OSv<o
z@TKs#Fr@H<)l0iGqzI%4wlJg!rb;(6N6DnhrZ6=#rb?%BWyz(=WHLp`SGiR2fZeMQ
zr5MhTC&R*!sx*PIQi+iP1i>=OQHqfac}xZjsnV(Psft-DHZYc|4MQ|Ymjp;xs#+S;
z1jfn`kUmBRh>jGY6yX+zDD_N+D2)`66wwxjD9u#P1zM@vDPqlx3mKzyQp8gvS{R~q
zQ<#DoG$mhx;zyJ5mOyD<W^#T?YJ5&+NorAIPO;xhMg|53kc>-aaY;^Ql50hBYC%b6
zex4@FE&k-h<c!pm_=2MRg4Cjt%3FNtsU`7X!T6-a;?!G$1&JjY@g@0Cv6RfBTdd9?
zJ;@;ZkTDCCQ>@3pz>vxi#hAhn#gxL)&XC5K!j!_?!WqS!!ji(;!Vtv*iK!^ob_N!P
zD7Ih*P0m}qL8-<0rA5i9V8i{AnV_bDC=i>Kfq{V;l;R8+7#M08Qy5AaieyR{vKSXI
zl`uCml(3{QHZv|{s%0!;En%x+Xl7c#Uc<N$oFao6G@1OW_==zw=z@Kx$#IJ*zxWml
z$a}X~vhp+Yir5$!7;Z5amlWM%EiNrcEh++~@>?A7@tJv<CGqi^Ot)ByQ*+X8v48?*
zCF3p5`1s_U#Ny)k_>~O58lA0TLW@(2iepl9QZkET{PR*>iZaVm6?7Fs{XD~5gMvLn
z9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4Ud@_?_iZe@6
zbqf-cvlG)(i(?8h3-sg5Qu9*si}X_<F{uypQ?Xt_Wf4CE1A{Cmh(I1;VB}yDVXP8E
z306IrUy?yV2?|;e2C+d&#2KU)6pJa0pdhPy%%uPYp2Z3!8L0~3fKw<gNz6%ANXst*
zi=}6lrRFKX++oiJ*JD+XSd^Fxm$6a^$w*bO0tc8?0?btj3Q4J%dFc?7Q}oa^gCYl_
z5yVo+PXk*CvrHi~56lNU3rTNLYDsBPo|QsKQE93|CPWWdjY4KI#PtZpAw?n#3=Auo
ziv&QC&jB;Kh?{|d0W1X}M8UF|#qnUzD}w?GlqeZE(E}K!1SS1)FfcHHFgSp>fYWal
z!vaQ7`ix<!WvXSaVM<{vWhj!XVXkG#n^eM-#k_!}h9Qf!hG79)4bwu#8s>$}wJcz9
z_8OLjjJ2#_Hb)KXLdN2V5~c;5AQmG7Sd<H-qBtvssg^B|r-oqxcMV8CQ!QH!ThWFR
zo*I@E=4PgTnOgQ5_658(j9Gl3ToTTZ!pOqF!qCjj$dD&s$WXk@09=ZJN+U*w8kS%N
zO_r)9@c400Em25>$E`wUUP(S8Ds=E90!J)KATzJHBrz{J6%i{|@F>hkRRBeOUSe)4
zk<srLa*L@vNt6E;TUusbN@@{uiI$m{mR|&_*&y-D1BzrpP}K4k6s4wRR)ESmPzlGL
zl34_@@)m1mF^JERo0y%Nl37%Ii!HSxv$&+VNCKpbCBGmw?-px$QD#Z%E!L#UlGI{N
z4sc2;5(mk%K}-c(c8jejwYW5=qzIHlZ?S^Y(JjU_Nb&-u!6I-PV@^*k0hOP{GN7Ev
zF2Kma$i^hW$iv9P$i>LR$i~FO$il?KsKr<%2+Kp@0#h$NwM3KAPm>)~UV)q*AAgH0
zK0Y@;r8FlsKK>R@e0*VPVh%(GTvC9&P^1BJCoi-hOHR$niH}Eek`O3>K<)w;g&-#t
zgUS{TMm{zUZm<|eEda_E;FbZ%Pw-lRF@>pxA&NPL8I+E0@xYw!lvtdKQ51np0Ou4?
zmaJi{VTfm_VX9$>XG~!TW?0GSr^!?#1#&eD$TOOdoC_8y(g!&gWG}=EV26VWMNd$E
z1r=-zjBJcmqR6(xOGH0SmLg4%ek~B84I)5VAts@jsms8?-~lod<WvsEA`l-VAV8%m
zI3Pd-A|RreQ<$PyK+T&LhA7rlwiMPBwibqF#whkwwiNah4ltV|l`Vxcg$vB)OyLe@
z(B!$r0dscMad0+tQ~;Ny3Pq^}MXAN9c_pB7G%-&hGY?i}!1Je$LUCzwhC*VoLZU)S
zVo9PxT4qkFo<c}QX0bwMG1#=c{1Sz{{G!~%oSaGpNQNxQOe{%FQAny(C@oGcQUJ9n
zbQF?GOB9L{OEOZ6KoW^yz37Fy8#v!3D3oVpCTA$*Cgy>vFL3byD_$Wv-7OhZ>wwZZ
z2!q(5Fat+DC}-9%fD1{6g`nDqv1$_7E>ML8DttiI5zI7*$BIjeQWJCa5M>Y4dkP@0
zB`UxgI0_~C3ZUGqkXfRTpH!BaUka+*5=%gQNT~w~rM%Q~1&D!gTT>I0GZacPbCHTE
zSW4sqwV5EwS29BKKWd7(#hD1IIzSE#gQXh=_9`J*l<L8yaR&*g#3^9_w|n?X7@HXq
z8A=!yFx7yArwCMJXfoeo1y^(6j0w)!MMj`>jP4dt?8k#j)p(FwKpC2WnFEwF5bl91
z!R;ROD1x{Fnm0K?Ap$NCu{og#RDq^}EC*#E2Bs=LctC*lkZCCg$kO7>s#I)t-eLjC
zWFc7!Z*l5@Wc)O_(DMH+_W1ae{A5t!nOPj4oS#>cn3<PaRAdYaQ&4lX$P~l^`K8DL
z#6pBKm<29=K&@3jkforal!K9lm4%6elZlawjfs(qnTfFoB#*o30F}7NMMo+NxFroL
zE?84Qbu#NML^S|&U<jGP#|sKRSe`1z8it$*X^@|wu_q0SJ!hB`^x*3JG}+LCwa5w-
zR^afn1+l<kg&@G8X3fCBkPor}lsGvUS(um@i$G$yLuwLopMx=qIh7@gbpcxn(?Z4~
zxfJFo_B@spmMC^eVH?E(DQKfOA%$!dR|<CuPYXj7cM5L`UkgJNPYQpEKnp_@Z;D`w
zPzys8Uy5*wNDD(0e~M^|SPMgx0JP^Nm?D`X)xr=Zlq#Gmk|mlY*31|so+6zh)4~uX
zks=$+pec6?p0pvQVwDNFK!Jsr0;G)sZcT&ooI-JBaY-to)m#iIDQ~f4C6*;>GXG-H
zE2vBcllfI_df*B`lc@+)!xT9(FfgFBIzh1m3O{gx3MwEVb!iD>4Py#p3PUq<4MRLr
z33C?90#>jXQwno4^FmO4%Lb}xHCg;XEr^`_#FW&c_;^se0_4K@_*)E`?6=q;EsI<1
z>8T}&B_&0-*dPj#T34WkP7$berO5;-6J1fG8ywT1I<^rO)1c~^kFiP|7CMk1gICcQ
zzC)=lAbmkln>v^QQWh~I9CM4KC^az$ROYROItE(<pC>*sC9AZ!1Y9__fm{U&Lk7kw
zcnXKP2uU4^t3b&b)X)Hjxf25eLkU9-V+mt3Q;|RlV=Yr2OA1phQw`$+CQz%smbr#`
z0dop-4MP^oLMBFr64orXEcP1aK89MB8ioZNpmsc{z2x^9R5$AXV$?4JF*G@Eab*@m
z>geQDa9MhbwYVTBv*Z?AW?pe>Q3*KI5uPss71c#vpg{mua7^6dh2_t9P#fwNb8%|H
zE!Kj>qLShwRm@1b#T5^#F~OnI2?`ZHP<_qJ#mL6Q!pOzQ$H>E2C5awqa2+V&0}4;#
zW35O5<QP!v4XGIhN;bDx<3Sl`D#$S)BN-U0M9>`oQh;GMNHI8WK%IaTh8o5!hBPKv
zdSL`N)L{t()PhH|wn&<Rfnf%crLt(2f=W<u6&w%hX`t8+N)>RQyMX$D3=0@QskN4=
z2Gkd1TF6)|mBLWVoTpX;s@Fj!mq7`04MPoMGgB>d9#;tqj9tT2!yM0A!whpbTTw75
zoI*g2V&3@7;`o%zqSWM){Gv*5p$V>Iz+Tg20Y`sP07yAF17M477Es8|2Kf@y0B2z2
zVg$uB7b6c77pRdSjOJ&MY80P>!WiyTP|^eCfh@)p#%88qhLucyx0s5OG?|JN;f@Fe
zvCwJ&Lk0$h<sdhJOk==IU!ahNw75|02H6YmX@e?dgx&oTwM;ck3z!x%gflQPq%gpG
zyTJ^G48>Z=y<Jf0R}=xtF3bp5-eM_AO-zAxH^7NQ9gDlo7#J8<f!qy>Zw5v_#wrQ4
z@B+CU(#ipQ4V0A_7#KiokmJFL6O_MT#aR|3sQrsspn(eBVo+NLTj-fHFfgnGxdLP?
z17?W|asx;+O4xzag32$DGm1gIpmxSIP))(q!qLf4!T=t}V@_dd;V1!>UyNDI3mIJ)
zni-ox&2v^itc?y~kQ>Cni9Llen>k;khG79i2Ls4YJPe>QCcj(U@$m(fkURq#VdF^6
zODQhTEXlYfRGghzP>`AupIT9pnpd2epI5BOSOgApM5`8D7_cYi<m8v9rfdS)2CDHG
z7&#cZ{#WT@33*t-SFC4~lb@WJQ*5UP)s5l-CI$uuPz-`S0BU)sGt@A|3e+-ofbt__
z5lao@M5aQPV5Bi3O{QB+dIn$zYBCmqn%0og1MEaDo1DzzlH~l{0=umY3=E$^v0i0B
zocj=3HCaGKbqTm+zr_wRF(tDIoU@DIsX&tnVmB!7f`=4}Y#10AHiCi%<RJz|9_A_;
zd=_J*2~c_fCreOX21Q^EBPar4r4LgPs7r(93WV3e&Asg)>p@|Pr7lHoTcg+w%EzGe
z2x{~dw}2B7yu@TmVJKxRYN%mKX9U%vMGZB~3m8)v7czqKco+jCLk&|FQ;|dsQx<bA
zOAS*Niwi@nT`g-3OR-N4Yb{$IUkcL#)*6-?)^w(YjJ0fFU$HG@1dWMhF%^~7FfU-M
zVF!(i724IXgUl<mE0h403!2P+;7Yj22UI?=7lnfgUFL%P0<b?JBM{(bEhw;Vu_YE1
zq~@i-28F=oE~x0Z#Zr==l7EX8Jjevrbc-V|wH#6#vnFR`=A=ME5L_yPQxFGuG`}Rj
zXb&hXK@}sYWCnHHKy@%1BM5RavM{nS@qx-~Mjj@Nb`;D6KTS#WHn}C(8^x8yw>S!N
z5=+wZi*j#q6_<co1fa}V6bCBmKy5W}GXhcHfNMl>AQXX0>>^O{R|G13z^M)#CbxKs
zOA<>mlXFu`GV)WvX%~`M<UnSE(@r*s1@<a}0C~E|j)8%p9OPdm&<H9c3kzrjjD?AV
zm4lgshl3ePvT!hSuyHW+FoD&Bk_#w%!7(WPf;hzqXnh25i3XaP;D};@&P=dEXC~Mn
zb4O9^Dd0JyC=SS6Q4}X+jwp%?GB*^(4V|Uo0ncRc1~X`i+!Bn+EI`d*Rc1IF{qXV#
zG?=Ydm018Dn}Ig_QL+Qb8!%iP1#ViFFxG%3I+#Gs2u6k)hAieRmRhD1#uC;Vre;QQ
zh8l)=wi0%bcnVW9Q;{8rmBmrR5YLgvQ^J|WRl_6+Qo~WgUBi&Y(F|((^S}~0$f{dx
z@t`Juu_kX3s7fj-0L2qH6}W@a3wvTwaz<uZ>MiD+)Vy0<kipJ)5Su+Cu^7}VC@KW0
z<E+Xo$jmLsFDkhu5?_^BfM}mUCY5fn73UX~q^8_r1q~ck!0K3VccBPmC8+NV$q(RE
z0dm1rP^thqih&U{M#{&;!^p$L!&oJS5%{>f51__0xL^Ynj5UnV0u5pjmPRKy=|2G3
z3oXgyu-JvGV*s)ORG@+FTLdc17(wG(DGaSlk_@$spsraKV;Mt{9JrehR>N3iRl}IV
zBnckU&t?YkK!f|@47H3UEYQgT&~z7bl?ZsEfLRhWRRAsk!x{3#SQtv!D~ll0i7Cvr
zOpqzX8m8i&5{?C&DJ)?7xU#qxf`<Erz+$Y(Vl|*CMK-^Xm;e9&|L;~M3~p{Kq$OtN
zq^4LYs1_-x7QqC|^NX_Kf|@)<C7>7s#XBUc2ZB-nTT*6mYH~?YB}gt0B*NvHmy%lH
zT2zz|?mDKYrxx8}O-W5EO)mnats)gr@d|CO!dt4h7&9TU11=`OX#v#eeGG~d&`=4e
zy#;Ek3W0kiOpGGnQF9hX5hfwVDse2ah0%5eMH2{vqe%@EO$=EKS)f{lF$<Kjm?0Sp
z8g0y=mN=;YpvmM{1j;a)ED+a&Q!Uup#Yp}DmHc3jLCQa{C%^>QC!oH?SCCI&Ef_Jz
zDg{h8gPLxT<`PC11C%U5t^hk8ls7;r3^dJ@#f0331cmP{@K_mWEEwVzc=G`gzF-G|
z%JN?z2Z785RovJegS{;as<^@K0JTF(Kph-Vr-pGMa%=V$Q)d1xb|=uZiKjoL>cHj>
zP{r~W$sID--GQSw01psQbpz_})i7i+LgSCAh9QdyR0yUpN<x~WFG0#RnIVCKNXeik
zEF@$Q@dc{o7#JBCib3fGR0?4$dqA;;(a>gRU|;}6GB|t|fD##F7O3<_IE$%B2Q(!J
z&;2?zOrYFv&QQx#!U9Tywag`~%?!0HC2R}WY8bNEYnT=?)w0&Gf;x#=?9GhX3`KLm
z;;fROfdo+JGNTYKQo{@l0Ja*I1)Mc(3%E*{vY1nt7BZzUOEQ3(JvFQ;Oy&%=tc4zs
zsXxD>Dp1x1g$}s+qsfgFM4-NO5h$M*fl_-Br~)pk1}R5mcjm;Dlp@eLs3tq43kuE)
zpd50Gr64CY4>Igf4=NcLi_t?G)PQ9Hg*0f|2Ncqv{0(aP@G<f+3NSJ;3NcDBaxqrP
zV^0|HDi)<W1;rY?K+XV10w}vc1BS7Nu}BLvPA17v!kERB%?#p!SmvMtn0Wzs%%%oZ
z05gFLU=~m+TEGgbh-;al1u$D>60`tjs%3^2z@YgrW=LSVX|hAgN<{FX23k=KQrQ6t
zsv=PMKtc+f48a6AtAbil!k`cW)s&!85EMdujIa_ATgae{6KL{bYY;-F2|?pVMWA99
z($)i&3XrxQC<8#6c_8bHbU-l<b`qEXxdhVx0JRz}g7Pm&oP&{tnTMN$nL`NNh-2np
z;ot|iD^MZ_RN{al2%JMeB}ffp2?Myb!)U_*YN0^-!%VjXz!g(!QG8J<XzfH%<t>(y
z%7Ro)CU7}?iw9J|rxt;SuZqx;)h&LAp41|!83v#L1li2MSkwg?Oa-+MKn+I_2IW_{
zi+VuGg`tF@jG;)VgrSB3RD<W0)qs;q8Do(OXxOHikrB)X%Yt)l3S$aWGc%~WlEPHV
zP~=s@n!?=7*u)6R(J3roIZ%FPFX5<R0WI(W<!7+UiW1fo)*1#e29W9+aN7>lVgT7}
z!vJcxXtGt!hqf?5D<6<&<{<$99$!vWfG#D0j44CcXF$aut1LjHfv{<Is036oWNOSx
z0dxKyG9;P+oit2FtPDXh05p6I8h(wB_p7pq%r8|)PRs*M%%y`D5}>#eGP10rke`=R
ziR$no(1>c4TxecmQcfypA`jGsFG)onL{}{WttEoSD5QB=lmjYO*dfLigT}NWjnVk{
zA~#T)1x0I7JBS6E3@_>c<vO-o>`>=J@*B7<3eJO|+Or5W3W}DTz%$Thpd<vUXc*Wy
z7`d3ZK;saMJd7NS985fne2g3rHX~RqX!%e|X>M+1d_2m~11ogs0i5=O7#J8*7;70J
zH7KZL29?yH_8+LLTf(}4rGyPsA1s7)gZ)a_YgtM-vN#uT)i8j{^BR_T?i!{VmUx~T
zW>BgErJG;|P3EdK#HE*#3?1k+ZgEC_X-*1awpk%j0X`)Lopgn#sFDmwasov-CF!Rm
z1ESln2sB`-$$N{vAUnOZBs1q052#{=L}O|ZB!Y!Ow#CE5pivKwQE=RXqV*PUJS4;+
zX#vte1;;9=w_XGaac~mTWQEjj;L%ZVgoA3HB5)!A6=IO62bH|H_#sI*J}tipJU$)-
zN&z4>4D2jSpcNZ@j4X^Si~@{oj2w(bpaE-5Jx~%%D=jH4N{x>%0u?xr+7dJka*I7D
zKRrD&FCF5xiJ+9rR-6IyGsKsypyI8#s0@@`L4i^PO1-yOzzRSq2fT=_2-LzT0@ZG}
zKohY(`Jm=Cq=c^pX*2;5oM5x_ld?b!bI=L~$T%@*nho5K2A9g<+;EE<-hoRk0_T)l
zQt@d;`BkZT(D2U5Oac$n73C%7L@~#wW!~cU1b6r#4SYci)wcwK!HfOeGILUWz%xv@
zxIk=3VRDPlv81FZGpV#B6>I>wI4%N}x{#d1<qKZc5>i=^TEq+T%M=g+3S3CcfWjZb
z0>=@D4J5wpK*3TBs?T_sI6#>a88h)PN-%LTvoH(j2(Sq#3UCNS3HWg^vi)OWWnyAt
Z1Z7{)zzS#xT!@j4nS+^ynM0C~830ZknCSoj

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/scripts.cpython-39.pyc
deleted file mode 100644
index d2bafdbba247cdcd44b5b5c68612d281ca1d7436..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 10958
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
MT#PJS90Dv%04oJ9r2qf`

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/util.cpython-39.pyc
deleted file mode 100644
index 22a066ee2fa540b79e7054b5e3c8c25d3e684f7f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 48230
zcmYe~<>g{vU|^UdaWM7hO9qC=APzF-U|?WyU|?V<-onDbkiw9{n8OeSqM33SbD5%;
z7(r~t9OfuyupCPiOA12@a}H}RTNFD~jw6Z#EXNte38uNCxWF`b6gQaWiQ)m%yivSh
znlFm43L?TE#UIX)C&t2%Dp1+Q$N+*Vj8XiN40%ij5PJoq1i^ZQqJ+S-aFj5Z7Ksu8
z)1pzLP_x9M#KIZ!q`+p~0+|GLop_WOl6ewQ5-BVxtT~doQc+Tj3@I!rY&p`oGEp+Q
zvQe_Ra#3=*@=@}+3Q-EVicyNWN>NI=%2CR>Dp4xAs!^)BYEf#r>QU;s8c`a#no*j$
zT2WfL+ELoMI#D{gx>35hdQp10`ceA122lo#45?fT3{#C3GDaDv@-8q*VPD7?WeR3-
zEM$x_1G6|6GDew$SzHSlqb$HI?uCp|mS7goLdGa7FpGB~W0W<R#kY_#$|i+BMWBTt
z$~HwXMW}@#$}UAXMWlrx%05LjMXZG(${|HOMWTfv$}y!QMKVRIg)z!0MLI>Mg(1p0
zMK(pQg(1o%MLtELg(1o{l{w2TMKMLGg`t@-${oy8PEi5#Jixrp6txuf7RF}AC{K5W
z6pa+k7KRkfRIg^{DDM=l6zvv<C?9u*6rB{^7KRjEu()rEUW$GTLzJI8LyAF)VGBcw
zAz0iW?0%zE-mHLyOi_U;#wjK(3{gQTT`8t1W-W|S!71h`7A*`>At{zARxJ!sp()lW
zHZ2TMVJWsLb}bB1;VJeh4lN8(5nyv1Q+cx@7cxaffq6~~8Ka_8x>KA}Tv`~TV!&dq
z3mKzgQ`}PATNt9^Qan;TTNt9^Q@m2VTNt7eQhcHkQ+!kWS{R~|Qv6c_S{R~|-5F8>
zQ-WF;Qi8zlO>t*P2~G)VVMqx9^Hbd!QbJS0S{PEo!2Gn7@Tl~Zo|MRxs20YkjFjk<
zm==bp%#_%uEO&;KxRm%7hLm`)%51QE5*9K><$zg<3mKzw!K|c(j8S<h$tfu<3{h+;
zsVQkK3{m;1{1cdqE~T)fq~}QI7DN^17DW~17Dp8`GPpCOWTa%aFr;Lrs$`WkGe?!U
zGo)mtWVbM+WTzH3Ge;G;Go<9C<hC%R<fay+syDMlm8J@1m8CGI<h3$MGDMZ9mZ#)r
zGfiMA5^-lpDM%@7VMr-VRmrMoW{#>z<%fzFr4+X?q!g#BWK}jZM^(Brq?DwTwlJiW
zrmALDH8V$5fmPbMGo+NIl(#UXl&7j@RW~z7Rl75!RHRh4Fr-wbs%F(RGe^~=RHan6
zFhte5Go;j{)V46B)Ph5#&YdBpE~UPOA*DXGu9-Qi-kl+(A*Hc}A*B(_Z*XTwX-a8s
zVMu9C)o5mpYIJ8vX-R2qVMu8O>u*YFOKERmh-yw@3}(>meF-Yh{4^PFv8JRJmZpLj
zndv$CNiP{07#K7eZwa_$7MJ8?Cb?E5rxuiC=I3dO-r^}PDay=Ck1we#NG-m_S&~{&
z0%qT0E6yk_$;`RMS(I2FpP5%sT5^jc7_8RQ|CV5KVsb`md|FX{ZhUcmX;E_OE%wr)
zocw~+JTN0GKQr$Zdqzn~K~84UEzXMEoT7qcFtfNIC$j`(*)495kdOe6#JrT8)S_Dg
zPKm{-&iQ$1ndzlPi6!|(x46p^b23xnGgDIYN^WsF=jW9qX6B_9-Qr0Gt13t=Do!oB
z#St3h<62adUv!H-Dzm^XGbi;HM_O@8YI1%`>Mi!tyu#A_lGIxqrA0Yl4OM(`8qqQ3
zF?zbO+L|%NT2%s2zLqvjL@G|h#@4>Z&ep!hw%SO?xV9#`PBGRNtXeBh10<<gqhV)j
zuZbdGlbKhOmtPW7teu$$R?88WUlfxBvV$`&F)sze<j{x-hFGkj5gk(ua!GZqhNhOb
zvX!-tzP(~yf`f``oSJQoja^K1Of1Mv$)LysMJxz|*vt$J3?N)=#=yXk!kEI;!qCaw
z&d|=B#+1UG!qURg$<)r2#+bsI!q&pk$=J@A#+bsM!qLLf$<V=2!_W*$Dx8U_j0_B1
z3JMAe0ib|XNL0v8EXqzTQh+1}g~YrRg`(7w(xN<tM1_>hWKe2JEUHvUhQvc=UOGZc
zYDGa&YH@L9ex4o|*vOEKRAfEnnK?NyjSAVRmBk85`2|Wk3Q9Q{#Y$kCl!`#CwEQB4
zy!<@flGLKy%)G>$Vuj2+uz4jJsR{^76w-?lb8{1mbQJPo&MnqcaD=%W>cZ3%h0Ht!
zaP$`|WELxw<SQhlf=$cJD@iRXC`v6!O;JcJR!CIH$t+1NO3Z;8paXVMB9y0)mtO*N
zJGzmHVB^XXi!u|Fa#9sEic6C-KqlrF$LA&HrfTYe<x%2~oq>UYg@J(~7}U_vV`N|`
zVOYRe!?2LCma&GhNT-Hz0n<W;6h=vgTBaI?8pZ|83mH-vKt)z9L*B0%hGMG{mK3ID
z#wNzRH#HD-%r(p@%w>#4VI?dnEHw;b3?SJQ<^`-Z%qgr3nQB>T7*g0^X4EjJGuE=!
zFcd*`*Dz-@6?IKuEMzJyftXjrlFd}Ku7-61TMf%XMn(o?-GwD3><HHupD1BTVTaiW
z)&X}tL?^2I3rkX17jV?DE@Z4_D`83Ds9}S+6|9pPqysL`gs^o1=R$^Bh8m_ChBT&N
z22D=CB2X5n5--h5ttd!M2E}1&UW!6~ngY0ps$x=CsuIi0D+84sNNL7OLACf6LlG$G
ztE5vw<pn5pK+`%j{y}O$21An{$Y_WHkc1}JEiO+NSHBQXH&54~TdcW>CCM4L*wTyg
zOACr`F{kFG+~N+d%qvN(fR;u@sRcQS$*H&45(^4IvOK{dL7sl@@y;Hhe%`lOzy%~*
z4#<K6P4-)yMX9-onR%Ic>9-hjZ?P4n7MJFf++r-e#gt!oi?txJsHFH7WARFcB3%Xs
zhF>+#RxzQ)sYS&xsW~Z`MKS()sV+sCWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llW
zuD-6pA+A9RW-$Q)J~4?Vx;gpjnZ+fU*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<
z@nxxbDfvbEDUeD-A5<IY6;$5hf|L~TWr;<Opk!<XDwvqK7+Dy37=;*F7`d1@7&#bu
zz>tlRg^7oejgg0ui;)kmMu>?EEW*Voz*waKE|}vXhU(em<R>TQ6x-=R_#jJAG7uXy
z0||p{-on7ZP{U9Z1WCFnOxa9DL7*Zog&C6I7ceYjXl9IIs%5MNC1gfPh7^`;<|2m@
z#uQd~!eu~KUCWRc)xiiVBx9IrnLxUVR+KO;U<PMV<{IYWqQVt5%nMkcnUtl5p@w+@
zD<YG^^|ID7)Uebr)v%_p&0(%(DvYaP0%dV%GG>P)<6n##;3WBrQS+BfDX3Tim3yFs
zSCCkgnpcvMTAW!7N_{JtZ!zT;++xnjD89v9lu@k7R;0?nz)+;Xz`$^e)7LS`+chZO
zKcGk!Bq#?W<Uut)Tag-wtpOrTL4-PpFaZ&ux<ixc78@j(i}XQaptMz_2QrcyA{-Ac
zbU`5vvWS6EfKdV*t3pgXpm=6vVPs<DVH9BGVdP_EVXRWb8<QZjP@)o)89^8vl|c*)
z(Ao(WT}58-vXQBVsaT=VtA?S530yuxOGHpqgQJ(ZmLY|)hOve@g=r3REn^{14I?z5
znf-1tC+4LT8H0j@`4+RIp9>_AK;g5J1rk1ppaF*pW056lXuuMDVqQuGC@_RT37!!V
z1dsqAkdPDeQU=2JO!-AH&olW4A^cus0}2twB3l%%7FjSbFf`-wqYS<%1{Y46jJJ59
zsRvZJ<)uSJS-?g^tOExxIK_bz8xOLXAO{qKJL;SqDty8`+&tXiQU)dL_!$@&K;3m`
zkV_4iL4^P)tAjFFkys7m0>%`^g^Wc~DNMl(;LOXokg*n&hD=IWQkZKPq4f?EIODQN
zGSo8HFxD_FU|YzL!UV2s8B>^87;0Hq7;0Hr7;4#S*=ralFcw+WFs86bGNiC(GeLL@
z*i+b2*cUR@a@267uw*k7O##<yF!LEx*lRez=5f|A)^Mb-i$l#{z_E~_mNA{7mZgSs
z0%MT@*o~Y}H{K{=N#U&Fgu0Ps0cQ=|ouE3h2E<3WloMn^G0OzTLW3Gku<N+8nI|w7
z$(69AaKlaEOks!k3~V!J;f@-X35>;7DWKK?;{>Ln8Bm|`fPHqL2Gm{zhXhzXV+q#+
z<{D@iPGBsqDq%_C#S)6_CEPXa&5X5NHC$Od6Bvu;)o^9;PGBrvRl<_OSHlkV5lToy
z%+I?4>B!e|L){?=_QR7J?ixmL{${IX%-d4KxPU!H2sykbFcpDX62fq|5D4)Sz6H!R
zoC`rdcBtX5;e?valNV9K50L?-k_k-3F(oW1BJj|Ihkq?EYUqPq4~hY%qCR9DDWWyJ
zX-w&iwQMyYyRJZeC6>)RfvIRm2}_DNvWt;ohOtBd>SI<=TAsjE^aZMy5v=!12}_Cu
zTrb-M=3<5#=32fynH0$y<`k&~f{@{j8a5Y(X2yk#X-r}awR|N)HOw_EHEcDkHS9Hf
zDYCt6!3>&mRbAl5DXj5dlv-GtS(KWanpdJwkXT#{Y3hPo$B<mCrw|0|4Zyo%U=zwS
z@{3ay5=%;oGLuS6Qj1}YWd%^99n?0?FD(XD@g>Cy`DtK5B)cFj<X?=+epP~?CNrqT
z25!`WDm`#Z?-yhAFUDAKEm<XoQbnd#loTa`)Kv-RCg!B&7v-j=D8L1OG3r#wB<JVm
zCc@1GwfMmD;41YOqeB%xtf3eh<Ow#3-xJz$3=Q%D380iZtk9+hxb1#~0lDp-0xDk^
zi}s|0+U<~5FcY|3fwkco!Q}u$2@6vD*{6gxg&E!qLFi%ul|`U9OJf4(cr-I=7>c&k
zFr+X+8#5h+ARcQ9*oFn{pw=?H-ejy{EEX$aO<{xCQYco#RJ;f5T3Cyky{ZNrkD#s~
z48x;3C$qQ&6m9thso+kzjzU>#5vZf5P*PfulUl5hnWm7KSE-O#1nFAA3;@x^1*yrI
zX_=`hItr;d#i<H@`FW|3_y)<sFr*<=B@BxRsQIA4FLDLdO`sOSFL;YSIX|zsq$n{n
zuLPt*lj9bbv%hbEV~{Im>*tmbxFPKC7msMSgBwgmN+5GV?I%svTfAkdMe*>)cM+(8
zbc+M(h~gqpQ|T6C8Mq3A5Re)xJ+&krrsycB64C-S30OgGU>0zTSAY@32DO3t7zG#w
z7?~I$BA|8>3uBc!q{>6i3Gjw5ve`ujAg3CF2qO^T&cMJ>#Z+hei_yAD92R6qrho#a
zN(QNK1PZGhP-i_Qu>_o1ezB?+E2tL#V$xASN!(1xiCct$fgzoth9Q=xmNA6^RNzcx
zDr5;}&}1y~2RQ@OP}F3)#iVC&i#a(z4-zsUK}hS7%LbHglJj#5>{uBY7(Ro-rb-o$
zml5hU*>16b3W8f~keqsp8xiBh;3mW^=F*~^Tii&V))c<Q3M!-uZgCZtfO<;hnI#!T
zG9ZV7+ryx?YZ1Ire2XP5GcN_wd<G?iTbzFWe(}Kpj?S({QlPdkTXAwmYHsQ+w!GAm
zoc!b>50F8gAOh6eDN+HkKmnx5e~Y;&wGh&Tgrpl#PYLAuqA-v_oS<e9xCve44dOGG
z7G>UI%q-FYaTrUAe8F^lkq?MwDk??~MnQ}an+Qs3eW2iE<p4LiVTlZs#6%c*pxrJJ
zMixdkXaW>s6kudyWMSk3cg{d8Hby=sP+|mi%6J$#SV65<F=h@KK1Mz!P&W;fXhm3f
zz}+>78WBhbj)@IyiU1Q2lL#XZ6B{ENlMEvVBisL?3<d^<WKaqMISqvQ7#J8pLml7-
z+6wqERV`B{xUuEJ5IZS`xt67twU(`fA&YSVXt0B2AyX}T2{Wh(;ldDGP|E?80Sy^2
z)pC|FgDPwnhS-o=F3@m54OcT$Eq4uD3Uet#Q68vIR>PgbypV~Jq0p;_sfGhA&r`#;
zfE8p;7F!C-LZ$`mDJ%;aYk6yUQ&_|qYIwvMYM5)dZ5Rr@3JnScYM6r=G+C=u-7@o1
z6jD-)OEU8kLBn3f3ZQ|hqEyH@XR$(BW=?7`ig!U?2bELcn!yF!DP6!&!kERB#hk*p
z5Y&xiMBy{mFfL#Lbt#MWycn7oYZyydL0wL0r<D!VdJSe+$>jHoQD2k2ND-Vq@{4b=
z6eN~p++r?HEhvfxi81G-=7AHkCetmJqWt`lq8w1-1ZPArfheqsQgh-#x_KEH7>Yqn
zX9gxvn&D%t(gc+^aL>hq{9TObg+nAEdi{#BKz#;|qHK^YV5`8H0W=nQi@6}b0PNDD
zT#(b)ioiKilkXNE!fcQeZ?P7Y=A;%E6@XOnfNX<>@-3F6#NyOjY{jK%X_*zbSU_^O
z*b0hLK|GGcq~dt6JeUO<)V>8~fjo7K7iLF1C~j_Xz<di~feb>=Tfz{JL8BDnYc5dO
zfQk(UW)5~xjsfKv5awd!0OtlVMlr^s22ffDrEwSrjYol+2H>;~>S~uTlrW|+HZv6o
zq%hSo<cWY1LJ4yTV+u2f)y$mD3>sGmX3%8u1C?WmIq?urhTP%?`4Gy}WVywjkys3B
zSlwbSt}HI91cexTdTI$sXeDD2$SQPiv1jIiMs3PeKwbeyGb0xh8?y*wQ9CwggJKTs
zY*0LcvdIFb66P#W7GVIT$P%_@recK>c2L@cIC&+bpC(fL-{Q#2FUn0$EKV(I0lAJV
zwIVgSv;;I7dW$QwI5V%fBrz{JwFp!c6iI+mO&f>+r%f;cPN00CxIpLxjfz5&C>I|i
zDCmoNKyC-+FIbR+%meYkZubM{w_27Gh8mV;@aSeOOATwWObv69Obv4_YYl4=OARY%
zOmzX{LWWwl8nzn7GKL~EP%%-&lEPHO1}aX{n8g@sSqfQdK&@kDXsd)%H5pW+a;X+;
zG8J)xe8`%UU!Gc|$qq`G`MCupw|EnCKtd_;$r*`7#kY9CV~g<xMPNzxl+?6D@IYPx
zwA4?=h_QmA{N&Ws6gyCifr5yEk%ftak%bY2K_hA$j7*Fyi~@{BQ$V2rDrsP$015#R
z28RNu-(12_!&m}JctVhI<XXl|aC_8+Ay%T6xrVuhp^TwO3N&OT2^vvlwqYogs$mLd
zDCz*^Yv!VEP~?CH*lw|cXK6H9ZZW3ZVgZfVgHzir=Iqo;bPw=>E9&Hu_@v7C?9@s>
zkUv1hKLa@KK>h$#RYfyFt_NimnCnsc@MYkU@GM49ETu4IvlhvK`ot;B3&BHiptJ`X
za;pWElZ?%bwG34`C2R}WK_w`t#|G~AvPv?fuz}m$%%Fam3q!0^3=^n|sbPik4Pux;
zefbpj8nzmCaNmfdgtLaDnX#6$hBJksl(D!2TpDxMu-35IFcc;f2GlTzGXyiRFqCjr
zZi7sv*Dx&LP63TCFflSfr_(u7I9nKMxk`8z@GfMi<*wqZ;i}=TVQ6MzWC&--vtnT=
z;mP8gz*s2&H-Ud410zF;zyd*VuNv+vgg%JL;L4JFfzUz*7lzoNTAoY>7Ep!7W5ZC(
zTEo47qlRZ8qYFc<NeojhZ!KR6dkt?5A2xqYU@T68`;6CyVFF{J#RSGeIdFx?1xf2K
zL1n=&*3yzRU5i^>sTC!ud7yTFaTQ-dWl2VUo?dE2K|W{{njOlhVplCzuvJjStO-FT
zfonoYsRA0DZDuMGs{ze)FoJqCd0aIN3z$HD2Q5tqX3%8v0}X&DrhtoYP39ud2vpHL
zP<~@8N=-~jD*!b%lM8OK6_*sHCg!3iL2i(uc!*p!DE)!bFev@;FjXmn<)Cgx)N5c-
zhz?C*Na4i;ZP3SO=B4G|VgpSeCKuo0Oiu;bnUY#`iv^^q2sAczizTZ#KkpVxPJUv_
zE!NDE)ZF4*0+3P+6iD%@c_l@aw>aU`thZQ-Q&Y2xL_t2{flP9OJKjaNBz-fBi!<}m
zgHw}1O%0FK#FW$`$P5B&a!!76>Mah?jBI&PV!<uY#5ia!l%p7;xLA|FXd%c*7Et5<
z7HbxWf@D-y@Vvw=c926dQ;TmgW`kRqkV1$RBwAUt2$b6wfQT6&A{1m2YguAWX)1d7
z@_;-JYRG~TKsYFXL2VocMm{D!@K8S!BWNHW)SiH~Ktb(BAtnwsP~ipY0C9i|0|6#b
zfd-l+0I37DLW_2RiUs6C4OFy)Ft|_ywH!g!5|&~CR17eduz-f}KvQL)!8;d**qj)q
zTIO0%2b#SGJf&2_0?qsZpo$<1l+786Vrp2kxN6z*1X5T)tQyuVPH?tit6|OJE^13*
ztzk=HTfhV2K?hOTYM2)A)-czwX7SaqEo5e7D0C~-sbN~ckCcd^WBNt2K%qGs)KOzq
zEw)lE24|FL)#BKq08lY208VX1i$SWEfWjP<!pe(4Q;^^UQnVH%vl1l3otTmm4~^_w
zY~ZLVE-D8}gWCeEX*r4M#o!JJs8Lu_1c^ehS(@xcb3qD0>7xi7$=g9(P*<a92Z#mg
zgrLVWFIX!qqT4_b4eAkrBbt$eQ2;t?!@&gVQiw2$FcuvIMIWq02hpGs9#l~#gL*2U
z+8s0&0UDF25~*PbV*r(ippqR_ax*gI@gUfsWlpe~hy|4Ba|^(2IriM_l#<lkf+A3B
z<`!E~Zb?xpXki0WNea62*+J@3GK*${91c>>zywNv985*WK+Xg?4dg@+2BkQ-Ga*$c
zxN*Q(C07C}nixRER0_<&AQ4Ex#RHZFvymOl3~mzNVoOggNiI*h#hRRvl3Aq5R5T3~
zi_FR8=uRy<!N9<<5adiyX##O37b6D~So|fZX2j^5Q`5D#*oyO$vr|iM38tr(K$|Ef
znYpR?r6soni_wKNnQpNcrzYp;r4-*{PA<tu4|YC?VewECR%7wj1yJ~d!W|idstNFV
zJ5bj=l_82Tg&~RwvYa7`IfV_hI<18<iX{cqD`UUK4_<JR0%}<mq!yJ_V)Va2Q3@_J
zKtT$c|A}WvVSuG5##=0DrFqGqeo}F2PFm3=P!<5UK*0nkq2A(%kI&4@EQycb2J!*O
zI0nWl2{dc<V2b>bLGFk72h<FM_W?jztA;U!p_HMBr-mVzp@v}r1E`#+WiA2rbQx<H
zvKX?MYnVah2&f8%G{0EDj=IH`pOlrFTyl#$KE4>z)Q^t`ISn+d5Ff9}Qgj)drt*`r
zZZRk46c_Ep;uH4xcu-{&zZ>KcP;fASTa#RjLQGZSm>vSF)nxS3WG%W5GMp<uJ~uz5
zG$%Da{uWPsd|_!~4#f7ND<I2mfe3K0AqY?a7F}duVAu+>5)>L7j2x_B5sZ`!3O8^>
z)q#glL5;p_rXoH_NEM4gXz=hRV>VNfUI|kQVvv*p+|&b!yOl5@&*3frb+j348A}+l
zSisHuj2cF8&mX*qp)jC^vA75%7tBz?kj0k8Uc=bO5X_*-mUw}YfdM+)sSfH(f_$nD
zTEvm40AebXWF(d-fETco=NDxw<mZ8hu=5g2K-2A@5~{eexFj_fY2gdV6ot%U1#lA@
zq(NO@9lWHZptM9GDKR-)p(H;&wIn08NFgyjF*8r06x09!8=G8O1e*2*kH@BD7Nvr6
zTctvAYC$4+^i@wm!7nv6B{fAMDK$B<v^W(!6ajK3Xr&C;gyPha(gKCz<f6=i68NZW
zVorHtWwAnWX+c3wCS+tkG%vG4p}3?nCl#{XB_pvc6|zJIG=5)}T2zvn0^)-P@xe3l
zU^gY_=ar@Aff_0bNvUc1MX3tqsS3%7c?yZiC8dcuIh6_^N0nrx=7PrBL3)uwNI@Ye
zF|#<e7;I7)sGR|B=YT>8wCD%qBHhg53<XGlf`^uoVk9*a9Ac0GK85@uuqml|Da8t)
z(LRMlh2osV;ta_6GI*Q<JbO?j1C9-K)nav!J3(uCl2R2ClZx|mN=s5-{{R2~f0ZnT
z63~JYu&L_$>agxEcvOQ6;q0QRpsd1{Tw0WpSp-_Jk(*zZ3K@R^HG4IgZgGIj1w{^M
z{YFU!#_%3!9UCa1!Q(QALHPze_P_-i(_;ZIrT~q^@i1|LmQH|2^ol@hmO(Wutk?n5
zpxg#7M?oD#csZ()!j!_?!WhL2E=L)nSU^*iEeuhtDd6r(6kCdF3U>-m3u6>}idqU^
z3V#b@6i13cieL*v6laQ1if{`<6jzE!if9W%6nBbPig*h{6i<poiew8z6mN=pid2ep
z3u6>ticE@Z3qurtid>3(3qzDZib9HF3qzD(ic*Sl3qzDp3U4rjrp7HE(84@_=p=$0
z?y?)y+<=tbC5+7sH4O1gH4LCNP>_BCw4l7jo>Ej9UsRe`v>y})?5TOhrA4VJw|F4s
zcTs9`eo=}h6S$--dWu?FfeR{7F?Jsm;E;X-8zTo}l_;_c;iWuE;RR|yfT{&>;RSMO
z3S$jJJOj+7P?{N3>#St*bJJu2B@2*SAnxP^=Y@Ds8>=KW?-ox=W>Il`a#3nxNovYU
zMu=<CO4R2J3=B`u94d+GP;iw6@iIoR!b@5)@DNEBLy=GoWV99Bf&n=c5~R#Upp~OV
zuRy`coR|U+Jn$GFs+(>JLM)3<EQWanw7RqylnNOb*%+(jP~3;17^T_-IS^iLg2vfF
zjeSVZuvnplIR#XlgGNdj7eeRMq4G=%8H)|Tv-=DSSV2{57F!93#k7zyi!B>8QNf&e
zj*)>OBsC`oG(`m}iAoZS(o;)71#@0%d1?`;V270DkTF1L0S=m$f>Z~^3MECQsUY3z
z5EbeQsTG;UCB@*fJhNCK7gYWgr6#B5mE=?^<mRV<C%eGrf(s{*QR)y|)xk>@Gt(5X
z83j|LkdmKToTpxb#U*Kppb50hG=-%6k_?D5z^;I61+8z)NL46K%uQ8DOixwFFH)$?
zFU?C&g_M&Zr<7zQ=E3dPgOtSz0pRssnR)4;NP`r|$gTvr2)qCi>~kcC`Q?|Sf_z${
zP?7<%JGB@RviT*T3BpQ+#N=eqD&ABpa1B+g08QqwS^?xvco;$2mXJCYQVqd;qLi4P
zsst(0K|ZLG0OcSBb=4wua9AN+7NW@xZh?c#U(nPMD4vQyDeD${Vp1`vAil*?T#{IF
zi=((CJ{Qzd)no?eI8al#6tsGo4H8r6jayc5VtEV7gWy3e9`LH4|7@TIP)t=qpkRX)
zYkFX%A<5vJ04|vs7(h+{VQ`TFnz#YA1wo_03z%z|7J_pjs1FNXyu<`<4>Dx26*qtv
zW-u3}fK{@CR2I3UFxP;l^I7r~z@i*rQHTmo5W6@fg$1IbhNY;agsX-ng;gB97_@|Y
z0cb%K6KHOvhG79ONHrq^DEnx#RarRa7gQ=Fg5yb{C>1nmTLPXhEUMHkD$N5Yv$Xu8
z<WvQ4Zxbmt1VB1LN>#y&YgLQ=s`ypGOKlSsiYs$-GV`*lBwzxd8onqsy)-AW2y9iA
zv_g4CW^#r?d46dQs6C?qsy?A*qbA=iE=ZvspORUG6tnCpnML3ll`SVfJsmV80~)IV
zm+`mQGK)c07QF`*Vr-ekptMqS4^;Ytx`MYjlJg5H!D8<~y>M1&>}TeI#BQ<YmzIDT
ztjQUv$=SD<bBiJCmLTZ?RBPPg1epLHp<-lWU?>Jv01V7RjC|nfHPFBY7o!BYoeiqC
ztHe-}23)HjM)Cl;4xBtdquhw{tw;boV#lz687#&EiZoECw1jm58%lCvFRrU$26r~R
zN;qnmQka^VYFY9GN;tDXJkaW3mR{ysmMV!7t_9pRj5REvWDw3!!?J(}Gzyu=1!Eb2
zIx4Wl0csqx`c;X;;utbirT~lTTTJCiw;0P;GT!1y%}dTt$;?aF<U@)m*34p1%zXm|
z|924a14R4;5ughB77J*jKoMy81JbYO1_cl(0`ilxiq?aaA;%I2Xd(eT@b?cS1)5X7
z#hG7P0&x^1iomrLIG(^}K}Q3HKrscX{XlCMA#ugQ$ipPS$i&FUB*IuFff-8>Ls6<J
zP>zO26KLWJDHk(Ba&Zkq7E5swIA?+@q$0f%#szGks)>=IguMnlAJi`e8iZc}&bgq0
zkQ4?M1{Q{9W=4iQ0Yir32m|oGFVL_uBPc33A-X}ev?h~Z5fdW=gC<uII7kr_aNxiN
z1t~b)7d-%l4?80RL(u^c3mk}$E+e>TEZPjp9E@q`K_&>wc&YJ8nR$stmEa_<2nslG
ziN`1enf+ztVbnmc-7&PGq;62Kfm&GL)D4ORP_Thl+A)F#=RoNY<T*$agsBKLHF=8-
zoSagj{al2ji$IZ%?reUD{h$F-u%op=js~^R7#OQ$P+}HMA&N6WP6T1FGxL!8q{VWe
ztOs6IoK?b*#gqc-cV^WvyD-GMftJ;0F&9~ZOK)aKrYck_VSp@~2lX$V7;2at7;0I;
zDp+b*YFI(#dkMn=4lo-uPpt&<z9y^RE!KkkV$hUlR$^IVm2h%KVqQ9^V9m`>Nd>LG
zQ7x{L#3BglpQ+|+azgSQWbhBX@c>*P79q0SM^LP@gK9p|rWn@bjNJSbO*Tjg$dZ&<
zQhbXgH?cVT7Aq(R78mg_GBDg?0a=b7;2g!NC7`i^R9#R=Lz0IaGY2CZI5+X3x1wRH
zF&d`uDiLG^C{=)leQFpNf`)pS{W5bI85lDE^Mkf56-k1UJrj7~8tgC(C)wmA<|d^i
z+F3F&FcgJ=hFwvc@-TT6M}U$h2!rFi1{&v(h9_v@T@6DPXiG%}DE=3)fbwB+1xO6i
z*klBaAwY9Cc$GMF4Z{L(EzQVK!m)r8R6L6@fC}pxhAgh)v=RnT!3*W{6oE|Qg_#6S
z0Ze{X+|Hnm04UN`i;+vxq7R^a{0u~ZDz>7xAQq_W2`LB=aSSR0Zn5TOgNj{nWBxU$
znnTX}putFNK?pX<8Wf?RRV@sRJd9%CMcrKBs*MZOrWZ%aOo*yE8I*6JO&tbK21t7c
z9Hw)?VG7FZJPgfDwQQh~FHpEZM$bWES=?8{Tx?Lo01Dq4wuMYZ5j8BuRw)d%?0Isa
zu^Z6#lVT5WCCFI92AbN1ERU#V&t$0Os9`NCD`79;09AKIWhES0oLO8o94X8;3?&>{
zplXh-hCPKPjU|(zhGPk1A9y3n0-hQ+a4dkPctMq$Q)Nl2E@+ujCU}VyymAu`s7!_~
z1WW`CcKCv_jUaTn6<7qE2|_e^i?~7Yff@@%UqNEgAOcjHfG4wVaTQd?Lu^Vdk^$u}
z9%m0%XKz=Rcn`;5k6Y|8IdF;13C^0}!tWMGenClQZe~^LEmm+d46+PBI3uw*BQ+%+
z*-f`tQ@{;fj+D&AbTEq#YHECTd16sI<^V)eWl1W`Rqmh!03Lt<ujXfC6aWo5Fo7m-
zKuaNb7$q3F7^_e_pUC=AvKLCfZWA~ufEW3IR%NdPXDaY|;-WY(8<N4|U@aR^y->rD
z#a`?H%1ofl$H)N6NJZ;FBLi97Wei2@Y8bM>japE2<^>>3DJn=|s%6S!Nnx&K0-Fcg
zg24zXc)=!4Dq#RMg+aQIOyq@{$P1GLXG&JTD%qga-25_7rbG<Jfu<i65=%haiC94G
zP0(_(oYX2lxKi-)I+QF7&bVx#O8FNkQGiklXoF@_X*#5!1~n~;K<h~%y>L**g;eCA
z{y4Os0!|E&QV`tI0TbZn4j(i-7J=NFni2tuN6@-9P(}vr)&MO817XnOE;c4mT!MHY
zTqTVyTSLu3iBC{b3Bus44VwFdtRO9R0EawyCbvkXgaNcl95l$fkg1lb5F!U|41t<G
zHK5AVs?ebZv_FFdyz1ZusDxsJ)L!6`22eoVVoOX;PAx9J#S$Lx?_C6H-=H)GK&xJE
zu|c-Spw|W5nUFCF(E5{HP&hyeG{|5YA9$|{XhMh$z1@eT4Q0Rw)RX{Wu(v^B3L3dD
z<^q>V3|XLYe5N$et{&(RRSjrkC1X_>yl3m2pPQRmq5v5KNlj4z*WszfItt)zmHBCD
zP^rwkbRFnsOSoRBT10<KlLeAIK#8IVoJK&SL$F~kP_Uo}2ODVlb7n~;C?r5>jDZ!j
z>xzT1N*E>HA*xV34l33`80_&$(7~hPwi2+Hn?Y+1q-q&KD}^A{Sdl;pGpw;&C;(b7
zl*Iw6(R-O{nQEB8%_Zg%<^`OfR$nbk4NFl~4ND4hI%76daU3Wx!6tEmRy>1-_ZKqN
zvX(F};0Em!WMlxdm_a$V(5{97(r1C@&k#+<TkJ)tplSP5(0oZjC3tQlJ{~;utH}$_
zUAI_3Yf-^NTWBc_oX0@@f6!PrI7Dx;gVcg*P|y(WE!Lu35E~rKkk%5o`n<&g8o7ha
z?XjkTblhSpMxWuk#Zi=>lLH#<Zw3WFxU<LzSwG3c!p8`j4+mvMAx2P?pbb94bZRoX
zX)=a@CT3XN-2B`$g~8J^MYlnP$Q=*?8pkXGIj;y*Z9wWBMo>A!4I)78=^}m*3)F_X
zB@AkfAy!#|YcO!tU!)FFqYWbTL4*N_umTa_LIy#AikqS*3=9nSK*J%RRka+9T&x_d
z94s6nT!LKu9Go1?96TIM96Vft9HJaN99&@4C?yFfRl!?-ap05%DnrT`io`&44FhQB
zYaT}l6L`%T6LcC)r-rGPIZqF?pA@t<vX-TUrG}}7WdUmn(?Z5(rdsA278izCK2T#D
zG)WH<Df9wOt!Xm*-D1>(qz5+e#QQDwT=3jh@hz_S_{?1Ja*cTKV17|6C`=2%h0-l<
zh$?V%`WAOeeo0Ac3V5LY7ISWX3V4x4kv2#@D0iS|Ja*7>#GJC!si3HbltEmKJm94g
zY)qh~5}@6YMNW(i3>bs?pqdjrm=D^C1|Q4^@9~aePGte_?*<)F!3y5p4LU3Vw6mKb
zianJh3v}!VXE1{%*DY>W@M0ZT&@z-{P;kTAXdpJcL<80Kpei+<0ki-vo)NS_ES{-`
zrG_CMJcteMn5|?1FDn2yJ0NQh_JKkOGJb+h3N0|ebB0Sn0Rb+87}>zEN(9M;xJTPT
zp#d&~K>dUgP%8jZ0wJwg1BD`z<KBSc1TD$#WME)e4RQg<=L}3$g2;A*S5=@CexPA~
zP&k1t2Cc{g4fAKgEeEw-(^$kn10+m-Rnj&{hJl7hKr5oGz-<7#A{S65!r~&(d~Q){
zK~a4CdXTd~c>=UriQ_+dus{@{WFSzGfH2r~psE<Q=&x7+R4L~f)G%Z*)i7o;Wi#d5
zf!tcdn8gfbv(zwVu|V0ZHH=xT+28^?n4t(-6?cO|&l%)uP;U|`Six})9WiCi2hGGm
zvH)sG-(ri8Pc4j(-wg5<EZu{KO1b_sF>(E4V&?kG#8M@M6k>W14St$jSj#rhj51_~
z+ZE&}cMx$E)S2aoj|a7Y<KvN18`v%2G798_B_KEOfc6P8a<DNmaxrtTaBvlYWU6*(
z*az5vh7s*FV#;fxb@jAkHMKS2H7{tW8G&PpwQOUGwLn^u6LWGvO$(4VZB316s~El5
zm~w4REj)TPVxpnC!NaF^(J|$^vDzB8Abs{4Ix)psG379>rWWYjh?rPSdmL^-Nv5EA
zeRwhjjr)LB+JM&8fI6_n1}O}+OrV5Y#!#%3!USIVc?WqaJ#P)DG+hW<j?WCLb!%Bb
z=LJZDRu-}@U`b&E?b5GdOJUDuDoU$iO<`bSsAaF^$Wy9eOX0|7E~-K{tA=#}D@aES
z6G%-Ba|)*<19VL#L(wj%D^@^Vu?1OYIzugIo=6H;3U>=b4d(*Z6!3~h(27h@m#>Ds
zhNFhFnFZ8}2xida^(z9U`XW%Ouabgx&=f!;)|qLU$>4sO0%)ceTq@n-fJN6YMk{ay
z0Nz7Z1WL&$;Rq@eKy6#_ibYVOg>8JPVFc|dg=~BQCo@gPq9{<=$5a#u$|s;<60kUg
z0H-{VA@|_}5h|dS6_BNekR^eL^@oTZFW_BHn(VhYT>V0VBIAQxZ?P4pCKe@UK;|zv
z!7KSd2XNeCP0laPD}mHipoFZ+b&D6p_u$=2kc<iL?1M8gsAUaW&6ty)2U$aoD8(TT
zN93DT3=9lMLHWi4R9`ScCZa+8K&Jm3%%DB}pk@nb{1mh{ndv_p6R07>0q!Y+cx+4}
zjC_nmAX8967*t$=3V%@K6@!*yfmVcq7RP{=$AfD96woOYdMPZRLAEl6BE1rZEan9)
zDWH=g81s0*JaGB~FYkc1G>bsPD(p3&8A1+Ff1`$}ctHv00<IMH8b(kLGS8|?2r=-I
z!cof<&XA`DT8mpb53&xogfojPg|mh+g(HQlmzj|vg}assvhKEqsdz^T?*cy1E?uyh
zJP<R%F5w4NnF~Q@QSc@%V}hQc0+})dufTw=r&0hd<yQbLodAs>fOn99b_eBTCMkeh
zsl|E<o{;U3h`uFgx(%H5LF*J!L6eO-3Yp-EHR$}Ao<e9bXx=SV0kTO#p`a+gEEBXK
z1hhj1G|LIL6>g#q*fh{lE-+V><SVG_K^>wFn%o4NpQl~|Hwrq-=bxt#o|%`DUtX*O
zQs(3D?C9ed5a8k%;s}~UO-W75%!4c?0a=@xSC(0np9k7LssjpzJczp?))yC-g0^OY
z4`2ZwCIemA0$F(iUR#p{@fD<7rvP_9Xz&wcJmfeGNMFc5Pa(iR*fRp6J0I>$Y_0@_
zBh;l}XMvWd6sZ?0WaQ^U_A4T6(uFR=$u9=2bWY4mDJ@Pd(onBc*HqAj%uV8UBiNhB
z?gR^f4#9yq928(#rNyAhQqZ|LQ17Ee1Y{~2!~cnp)iNomkTXd@2i7Fzm!*QIlff%g
zK(>OaGFUN~ngUr5laK&OAqfePQ1h$efJOT)ro56{JjfAR#j65Js5yxR1)wFwzZmPP
zG+f}zkH87BSRtttoDxAn3K~rZRfM3u5g}E=p?M$<Xfzs<Ochj%H9-?Y70KYG)NWPE
zE|6^yi0n|BS6U3xqyr6g)nZKnNcRj>W`Wi%gVPgu)C05{y&y3!r3|#cf-AKG#0Eu9
z5qL;N2h=9e1rgwJ754JPBJe3H9Jz_vsi2P9Eq4E4@XU76AyBD(7({@&cbd$Qf)Lbm
zzQqP{4qAbD3%oN0oL#|tkDh?aM$m~G4E&%HP=t|>nTHv2_5~jkXc081T@Tt?2io<(
z!&nppYT<*Llc3@hgh3@Cyv}xlkBfoIK*$jz3n7P<Fx4;?X@K^KfqKykK|>5o3qYkK
zD`<mTEmI9+4U;$nXbW2~gC=VtsE-Fuan7LSSw$rZpaogbB~A*Ufk05yfDUnjB|LC~
z0hJh_)moXL1D?Qsgywuux=qYU&o9a>$;buem=uM~Vk^kOPRe=;$OQvv>u*AWx|MoD
z0&HqO1$+)oX0bvM<op|WdQ{id)m4WjM`b+)$Gl2~e9$t1qSU-(@H9t4LVmGcacTj`
zFs%BKwI?K~>w#Sjw!2sXa>`C>3M9D~c`-6DR59!7>Q*u7>Q=EqlxiXkHr?U^ug?QJ
z7c$5W+GYpdyr#(vPIurQei63*oggSs<4f}6!43e;QS&l0FhEYN;F16@-Qr^`ibIcm
zP)Y!$0B}7Bn-2r^XN!eEHKI6psc0}mQ6{L70m?vmDaD{nuE~gX;ExA7@K+34_$CK(
z0K6l?Sd@TnIjD&P!eGl2Ksz!SSQu&<VU5Hh(BKOAFtLS9;5GCNDa<vXIS@V2fL)$I
z4f6uV6y_8ruq<S=yH^Pl=&*uX#u}!guo9*kre?4>s4tlYn#f`CD{=#6Hju60_|Rm&
z#a09kbx0dV668;oqIhtF9+aa&=@PVTuDG~7zbFOL{Q$R4zyzp)bql&DHn}JjbSzwE
zVotFN$mgKY1TAs}HAXlX*_c3$7El)DU@S@jg#;+`!7xfRfckf!hBGJ{YT<`*fd-tx
z+frVFj(X8#0vAoUSW7{(WJTDvuz?m*gO(<PMlR#Q%8WtIf<*`yV^KQD86c}+&Hx1q
z2!kU8bQnttBWSaAEfc7p3mIdBOfHo$)-abaH8T~1wi7ZkG8F0*3e+&AFqASDTYyH-
zz{8Hrej#p}%(pmG^Gb75ixNvx5u3R*SwOo33L)*n6i|$S7AT_^bwZiNpgD8UNr1(v
zg{7c8X#w(r0LZ<JpdnO9!3NsdQIrMBUB(*GiMmw=x|Z>=+8WV%y0IW`JeULvYH4a|
z>cZ9NfzQ{g;?*sv)QCxm(X)?9vDZZD*@6NKUO0jl$b<T`DU7wukN{c02wKqy+Dr@E
zGyon-bf{rjzyjXY%M8jyph2O9(Bpw>7>j0<uz?1WO4vXt6;xnmvlPuJVPC*e!oC1J
zzYba>Q^Np0CXJ<NMh(jXu7#j35JL)M4J+u#h8l(%R**i(@d`D}Y0RL`ND5;qL(!2E
z&=xGv(QTk1%_A^(fN8dcj4-vq44Uj!<>2z!6?9@natU~0G5jP29R<h+E6~Cz(2gqw
z(3y(R1v#J$p`ekM4?5NYvL8zmQVv7gn;>}<gUV8iKx@B1M=gMD^!vrA@QYCw-1Vtq
zib(=*PSNBk0%bk$Zrxja0g)jd{(kY$vl5DYKvn5hP?lr`ueB`#&0*bQDoQN^?WMoP
zmRg*gSddx-IzH)^L_m<gm#cF~yq}}5YrLbM3(OQvwp$#axnz+0Zt)Zp<%5>AgU8aq
zsqhwSL1kHL5xBc@i!l#9De{5K2=I(P$N+axG6apjGq53&A!rm$f>8{-Pf`v#oGQjx
z1lmVfr3>n;gLHy=+X{NRkdq!`G@u>vveY8G=(w0-O^~>z3Px82UPOb=H3O9m@J_W<
z3AjrQJIDsKFcq8{m?RlM+Y>>1k!qMym?a@c)v;6^2giY<0_fnh%#uol+|-hc{1ix)
zT9U5-T8;>ECU}h%XcRj$KMxlBpxx7X>ChV4ttdZNAyqG3Pa#nu0Mg<w)^!0L%~1wg
zMh#VE1zIJZt59I2;HUr=2UW?5pq@vrf_hqhzJi9Ko`I%1*iBZDqaCdjK$Sg)8^FiD
zfDib9)TUJ`o;f+X&=Xcbs`X*6g*ej+soTw5mRh9Ac8edJB%p~ZKFAfEdcZx}B41Dn
z19hZ}dO;Nca}l_T1s$LOsd2%DJ(vKO_+pS#5J1+(C+4NVj@<w)(1FyroS=RxXhT_1
zC8&%A_2)rl76^li6A%WMv7oJHB@E3BkP^0lFP#CjlN2<3Rv-mtGeSlxiY!1o6+smO
zBWPfh(I2#j7PJGi0yK{WUJeohI)@B2o59FXXj8+y08}wD7EJ-2#0Z_F1}*qtEMqKc
zfGz)kE(l<$VJZWi-@>#2v=R$cn%mSc*ML;6f~sVOs$^Qg1h)ay+hp~-#i&)30}4D)
zwNWKfnwOHAoRe6DeCmxR8+ffTcxnT(RscK?4Qd(}MSxaPu!1&P7M7+Km!ziL;!G?{
z%mfc<L9!)d(JhYByz<1nl2nZO3@*r6MoCd(aS<p(f}6qMl|i7O2W`^^4G=)ij{t4>
zg$xsbcFz~pgQ5kw>I3cX0}Wq+qos?1fgzKjma)nYQqF^N6nHNda}DzXCQvkh%6Ui-
z7h8Y>3A)}UPojhka-svc?ZFD3E(Q-8gfrwBfj8~8Ff!D#F)~z1m9Q+}2JIJttUm~6
zh-64%sAa2T%j1I31`Gxa;EI&ZuL`t7vm`aIL^q_eAhk*$5wvRpGQ6Y@+V)wc5sEl_
z60~A6KM%AMBfm(&E7;#p0dz1)YBBhDnj-KnKsC3-%pAyW3Q&#*ZLKZJOUzLKb+tgb
zQ$ZDc9+4(b5ooxw2((D<7BgtqDI)5$K(P*9Ew>a@e=i3SpuLert3d@dXDa+SU-qI1
zkQ}&A!vb>KE%prXmeS%|Ovxpn_2{7erMDO{ws;DGcMQSY77ub;Hz=Ax?IQ-zIe#pm
z=ml>@VB%xuW8`C0VJvC~H3QT^hx`^>>Fbx5m+KX!rs$^Rm!;|@=jZAdR2F3FLks_6
zeca_N=<J*nM#zyypdq&!2Jmi7#u7$w3zG>n)d;G;K`A4cL6h09N=UU>U$q!!wjL-}
zz(ag1S#GhG78Ilw74d=sMm!$HL*PDKd}&b**x{PY;Bi7kfT34I;0?V{=Ys=eAt*pN
zK;;Uf2zWnhQ8y@MBNsTJx&xFu!6_RQ3#k68VFVvDzy$UgXrU%k2{S0|LVP6(^%Zzc
zcB-ywF~Va-9iYq$aq%s7Xz2@aI=G|+6X4<!;%bNyU{@~(xf;~AVqg?w<YFx91-TjI
z31kfN19;jA<YvUQQxr3(&D8?hJ;IX03f?`!mckA`qniVC80#%oXV5XwRnNecilahu
zPGWJfLS}A34)`Q7(8`HK$Z!`pp@XKyK#Q%5Axp>eQX#n_C$lUSR9At<GC-{c=nf#T
znc!NlI0IbD<zyxmB^G6-7V9a5fL5JDY%5O$EyXWOO@UOMNOt5aWTY0Q!uLvLmVix6
zhAlWQ1s!shRH*=-&H%072c1iz1F2_0PAShwP0fLdL+U}4<|-)2;B^aVXD_%H4_*sV
zECyK%0h+Zg0WWY`$e6{N!sx(|!j#QiWCkv_Kr3LFpi9XhN8NxMq@WWI;<-{ldl*=&
zO2IA$O-6X;WtL<n=4677TFX-at%n62tO2e0K?<O?KWO|9QmcblNF!<G;IIJs3*2c{
zD9(U|18C@{1lDl|8THa0REB^G>?&ErFc4^D9W;;y8UQLN$}CGPN%hm@2KS60-DU7_
zOeCnJ0<AYJ5(cs06%V+J4LL3Z)Oju{16BRdEjl1JTIK`K8g2olTu?p1zyYdPK<67(
z@qrT@V#W{@3$TO?VuLU^^MUdysBQ<JcFkDj2M<Z;APMN)XINTMfSkXAb(ka*GBO7a
zG)O7{1(7DCdk<TE0osm@=7U?j5JN%31Sy$Chd_P-IgWv)N*Lk?6nTu&k&}Ue0qhY_
zcQc&<H1rKRIxdT8A!zwU0jLoJ8YBnL_A!A5z^m-Q!_%ywh2q5!HXDcyK1LO~Ix!D4
z$<7Q}fn1aT8rlY_0IfwX6kuT};jXNM42{<?F5rR4L^2c#7%&tHfa^xaDkVfP=A<Tq
zHqn6g|0QQ29qgvb3rQ2Ep!f$zEocU!2sGqY1YZC28<e_06IPG`JWxbIRzHC%Gw|7L
z&^1rDxbyN$Kxeb%m!+oMVoJm4D6l4j9B~2^wBP{%7SK5<0*p-1Q))qt4<W`XZb)#0
z)%t0&qfIp4Vvmnc$xn`t2Pe6ri6B=`0TJLL6+wUs*P=c~28OjD>p+g?U}RzA;NxHe
zi{hTh2lXPbmZ*H-DSXB#R`B8Mps9S$6s{JAD0c9^JccL^@ZLH8TU@T7J(s?j6`6Te
zhT!mb1oagw6^g+HtwKR*Qch-ZhJJBr5@_FNQYy6kgrruKgayjephO5xSfHGh3EE?a
zvQL^P9&S!iaS@iuYj8N-1qA}gBnHMRVTAkO`4V*(45;=2)r??kL9=(DbyT%1pv?$n
zprc9|Ynaj*n;C0ZY8Y)8@{~X{cp{Ry$gGBS0TU!8=5f`qLUzqCGJtP8U`hlHa)AQ`
zlqDTgQb4;vVS!Ktu5l9c6jDK<hgnd9g&`#+sA~b5X+S6jnFqqqLKP7r5Df@EsK@|q
zC`|#)!DxUcT0paoph5VIRB*uocOJ+%Gz@kEs7QszU}_5V#CVW8sMU~RO)G`)49Je*
zl6>e$C#aiWP?QQfS{yXtqJZkAM98`MAcN2_cr+hWF(YXJtziNO7pQswy9$zaKwAAY
zS&F8E@&hQg!MXDm7sOFHsc9v!RphK-UAMRphC-CGfCO$a6&IqFj^Mt@15hI31C`!f
zpe>jJ;A4+?n5y`Y5>#SJ3aF<CQUu1J#uYp%fyS}GNr@SB_H!9ykre3QEzog=pfm76
z{VGY&(GB2JG{M`Qn5$;OBLuu)Gj+g{40M?#BA}~;{PK}v5!5Fr^3!C71U`5l6R6CD
zt%U@gaZxl26fd(u1X?)-QuzfGx}b83fgKdOJd9O>NZ|^x9(RKVH0}xNk3p90f)23*
zSENi;jYt6qUdEURn(G4%Ip#yM94HNeVm-MiGbyzQa&{ihoCQuckW2+;g7On&XaYGX
zKxq>ZP~fDb$$X0id}InZZ8m^f$I#XUIAl=6;}$=t^NQps&=m~DpajjpS|x=PDrm}3
zf(O)T1y#zR12Bt0n}ERQH$#thaAAn`s%5Q`s$s2ROlPcNTErN{kjYTP3|e|#%NEX%
zr@+Ec!dU48sa`<?n4pd=XcJy78+6W@WdRFhd3qsV3DW}5$*_zyOrSN93t1T%YC!El
zmPF8$0zCW!AmzS7BBY1|k0L?C4s@jj<lt8DKoDp$1r%4Hg99oRGD{$nilE$$6ef6!
zNO<Hxiz-BHz{;tj^kPUng0`}Nro0n#6cUTlOF>h@;QfK1Q-wj%3rZhg<J1w(067JY
zQQQO*g<6vhUdRryC_A+hG)+LJEegm94B?$BC0AHyS|OzrbTJMzbip2ni~{&o>4SO2
z8Q`uvXlXt8AS@jPi1VNv=-e-8L6|06(L7K#1-Ed(ZQ@1{7c{6@1nS#svO`w<gVOFT
z7Lb9r*dS(s2WB7{9kh%Moc19Es6ldz9qJHv76yi5a9^Dpw5*hgQ3`s$0_g4qj{hu7
zRYFL~9ID9=w7QfNtvysU734DT%2M!N6HrkCaXjd}8i>`XxvOXzBLl-tP-z1izu;hG
zVdh}w65-(CU<b?KZW)1=e<E5&plfWRm>~-sqgYZz!RHl#T1T++3c!nmqS#Y-Qg~ZH
zts~Hx1q@M~sa%j#3z`|DxKp_xCl@p`M)9PG1T$!g-Qo;}&Sn(hZV7<`4$=|=lZ+)y
z&7gJ>Vi6>0D?jL1#+2e)Z1KgV$;rjwVYXXr@p<_vskoa-N}y-~wSGW5<JlOigy4>W
zx0F!I7*LS}uiZd1FQD3O0V8A&1ZdSWcuA%vQ_)gTB!S{*C8X55#R75&QtW_J2M6f<
zD3F9Y$Q>ZV8Bp8+lXgR?VnGERykol#v_u!Q=n`~vpct}qYM6>vftKlldm-Qh@xYT-
z0=1ysP@uJ>;AJ?4I$$-dpj|$YTEvARRsghn4&*K9zPSL<EKL?O=<sT=86q)Epp#*1
z*oq6lD;QaA843%)YFM$TnNq`$#aaVWGX)expuLiy1ggma2_<j>1|1Ypv=|g<psJ#1
z35aD3B0%SC!E)bn(7qhj)RgqpV#t^@sC`j{I5!JqDkO-(q00@aL%~Tv3lzYRMc$wV
z-7Jh^jC>%>1e&4X0?$)ai6SB&NheCsgW?|4!T~pwL34tjnf`3%Vjl23A43-C1U)8D
z>RiaQ05pC8-qw@_I#V2+X2GJ6)(-sSBUZ4tZ*d`xbpj_{a03h+4zSJ^O9AK%4Hi)9
zhIkU}U64<~YOO#%gd}Cq2C*t$gm2K>XrROcYIuNs0Xi2H*%wt3phQ#yJsmxZu?BS4
z5lc8jo*WB92~(vLw1#9(VFYbv2esoM^<$L;_=sQdmU++=8>CYZ&XA`B)(7plmN2I<
z)iBk7PrgU!1t$w;zbZLZ(EU;+;5Hw4lSzINq}^Xxl98F0UL}EDUbRRQ5{lsPy2at0
zS_xTDf@qaNmqV`sC8@RGWCRM$;#;hs;6&ee1s<KZ2ZblN*UHGl2wFP=>8-+8RRW0c
zg`^gYf&!GE!9ff<KMS-dEsLRyp+E-AVuZ7p%HT<X8JrZro&aYJ=;#ILWQ5cLv^c-T
z4xSHAE${)k6B6$tj2!=~1QG6nsz7lVsPKTNV9>dOpxvFI@~c=3xor+QCqJE`7BsI7
zx&?z7o|>79CV=7@w5}g?U|$VO8ADMLs8yBCT+|1;38RJ;G^$nuO8;P1p<WHk0ycC}
z&~7i#T~pxoGHf-Vy(i$Ue}#G_T+jhm7QZU)(7f!t{PH|21=S+(_%S#TG`Wj5f#MMy
zyWoNYTu&Fmhb=(mE+i;Hg$d}mi4xESPaM##C@IkL1hkztFEIyPgWqB)$xq1#9|M_J
zv=L<bdJqB5VqgN4&%kF*#ut~Q78D17LLFo+Xk9qy$O+hi-dv2JLlr^03BY6Vj6950
z!iX3Fw_ic}QR+HSLIK4KsB|d~0xkVuOlRz5N@wU~&1C3g&SdChOlRn10p-h1hIWQ_
z#&)K5=605L)^@fucJKf&M<-hcXa-CKw6?edv@FD;13ab9$WUm}0dAW@P7y`17gi2{
z@Am=iQ0ZU-9pnhQBFTmU%4V)%fUsE^BpFhe%o&(LeAWdFph;IohAJM=9Y2x`wTzJK
zQA-#rLm(vtXh;lFGSq+u#Jp;mYM8(-YwKVG#V{j72~!6%Xg^5@GpMv_2J>tf3ZrV6
zI#|mXilX51jHvQZU5p^T*-S;RK<TuD6*}3=ynq2x@_?4PWHS}*D!fs+tAwS7xtXz+
zrGsSw18CbS<g_A9=qbYB$#+dwaEBN&VZ)r8nO6i#Pq$dXv#gq|Mc}%J3shR978mCi
z72o27vu_C}=jY{tZ^Zy_*38cX9RkV;+S>_cu4KQ(nqHJxka3GOGcP5z;ubHMiU+S2
z2HlXDlV1+nsaOn2iJ)oy<m_9##U(}gdFfE2!3iIHcz@AR&{4dg<OiCTVPFCsW+A}H
z#SFUW2{a1J!N|eH!6?DV!7RZn0BY-jcQA1<RT(3aA;jo-sM(qMdBuo@&k#ANlqMsj
zG+GAF4EsSWaApvKs6;j;6XYy#naK<~$R4yBfQ5;TNkR!cH^o#XgU<;lNfT6{fwBa+
z{7i#piCS<w$AuwQ3v{Ar76T|*fTnz17-Gdhqg9|4C^alKOrY5*P$5((SI7eze|2Gq
z6{=+gUpvHH!wQ+cEwlsk!KcrqfX1yD7lL*NviVhUr(}X-OTk^Cx{6x?v}Z)uPC>QU
zx{4LVvA)GvdyA1vlLb=3fXV=HVGSNYg$}oXBeDoo&lG`+5pcBwN<ollL=-5@DfuOH
zK!FD8&NDE9HhqF-YC-crpw&Fcm3T^ii63ag883Q&0NfQ=0g9GYAOc+Yf!kEzLUISF
zvg0Ty0$mVNQdx8iq~s)s06PLffTFZ$5hDYGBFH(QI0PLK$id7dz`@GF%fZ4S$;8NI
z#KZ_zqsjh@U9TjuNH4wW7YCS;RAuyw1;qNrqF0q!0Ai<Cfyg8fS)P%DI^YNz+61*g
zz$IQ3BLlcpOM@IP$pJbk95k%a!LX3Alc9vUgQ1zRlQ9Lf><6@}ilL|tv?(2Q_H>b5
z3QH|ho(GuEx{$FbD21(-DTTe3Ezblj#<7sGC@qDvmMH~voU8&^jC&ztQB?|0EmI0_
zEn6N>32O=;?DmzaeKkxep!*efff}<Zyv<CttToI<Pinx;+FJG+b{Ei<8=wOsIGRCg
z16Ji}fhV;YKpW)YYC%hsFx6fIn+>}ANvniAizkI&k|9MPn_&WDkyZ^W=wxaahFGOq
z&Jw;F&Mf{Cfo7%&jKypq_5#5a!G(-9obmh<7z^2ISQiL^LWYqcoS}ww0%K8F4eJ77
z@JTTOV15XU4><r;Q^*e`XMrjkQ0@X3`k=}NG>QZ|l)P93bm%i^*rS#Kyy24-OtOIr
z_=QZ63osY3gRCxcs$uM4lmw{)Z8h;L;Y?wI4eCLga*&yI$l-pVgJ3dKQju?L09ELk
zT#zMjpll90IvI4HGh}80JRbo*R{=aJ0iI?D9q$J|El86IGMfcjl(LfP76<6^0MH80
zTPy{j+ZMnn8kCrCae+??0`Cdj2ujnSGzY4!L9KlW#wyv;JkTbN%(7HO*@w`f$y5Y7
zpRDL2DEly1Wfo{M6`clUoAY3SlJu%7mLjY4Dov)MGazBmDV4XFOOmRpSc|NZs*H-x
zLewP|71e?!;YFb>83oWHox~Cl1#i>L0ySJfD-kqB(ESfu+f@_~vH;xJ5eH40bAX1!
zK_kMq*h><NK=ZLhpaW%Yaiph~fTW6xKuvn^`Ng+Di$Zc!b3x;LkiZ75-iDm^e+lG3
zF6i0ti8(poQ++hKZV5m`1-`ti=n6<B8^qy7|3Qwu1`=V1DlC!!@mL{NgUkoJD>E+*
zdJyepkn_PY!U+%Z^`Hm=opsE>#K#U=p8{Ht4LZpJv{VRG3c{LGpv`Ga(B)&GN`wb=
zt`{SS#l<Ma3R>DN#K^<U#>n-bjj`w{XyzO=g#sRlW?*0d9sU3+X27)wD8YbMi-9+d
zK)0`!FhfuNNvUN9ty}>$YFrp%Jz}7DpMWmvinXX^FJZ}ITfkn!QUke6js<j#6KM5e
zEhkil6D-431Dd<zsNn)_a49q?R10TFVL~}WsKo&J3?WdB!(63Rm05ti?Lq;3gh6H=
zXevPgbOc7Rr@sQ^)Y&3tMg|5yP0m|PnfbTap>p6AfJLCR0Zu-*SjrP~vLTrSoPR(k
z4QX=U;)L&|09Q}9SW<FQ^KLO!r4{9a;?x`zP2wN|9EU7vr8zmE`*U)NKvycFS6u8>
znFXL+_Y@S7BB1aF@1Esh6aihu0Y0HZkFn?-XxNvnNE(!E8NF{Y`rcx6zr`4Gi!lKA
zpi>b80|R2vDT+Bo5_~`==%8W9(gwr<nP>w}shr?rGC{j<xl%b1gHDhkrzoCO&J^%*
znazw*ys4a!BQu*pM`TI_GiXZP;s_|pPX}F-e2YEQ&)d&G9MWQb30jehF$e&vxWK6j
zJO}`;mWo9{9ouZyViE9Q03!=%hzf*3!^8~nOer8XsN2jC&yvDa!w}C3D=R@s)=iVG
zXeTHmF(;Q6-D1v7thmJvUf-FTa*I7RC$XS7HRTpdN`77{Y&?K17ksz~=!VdWvcw#;
z7y{1%{sF}f4=8pRL6h^)t-XRUk76I=0(lKoNr1fvx+e+L@2FwSW-R6ddyF9qd~|ZL
z8l)qe%~-4k76+ZR$yCA&ZHF^tv4GD!a|5-*<5}`}Ky((11Sk-|9*2ySK|Edb1C;K*
zgS^iII{UBaCy4(GlzN!K1FyG0=eU+7=G<b=%P&Xs=`FTW(5{$N7FGs^V(@GgBOjv#
zBWO+qbYyoGKis<zbtv6okVoO&VFmD5S_)$}D{Mdq)Xf16frx`o3j)R0N+w9M&}1qC
zoibMhax}c3o|%_igzh>{kRW)q4IjvXAj?1}e^d#<ods8bQcr^t1t==O(Eu50gt!LO
zvaNxS89<!@N;+64gYy^}7=%zP=7U=dPG7h!1qTO176WJ{JM?x4hAc=xfa4kz9GXmi
zA)3sP_ydQ>Z&1u(nUw|&V&oTyfm{M=eSj)r9>ywOB)8-jU^oR7J7E8V+M}Rk2u@N0
zpfgf~LHoUtLIIS5K-bBG#|yB9#4YyR#EQ(^(p+hf8$c#AFjWb_?T1RDH~|#=APjZ_
zY+AgC2ec0W)V_q|gCdy}rdq~470@BrSxlhePzeSRkmEp|6=n$rY0y4j$ia_{;6)m&
zepRf71_lbMRjdm3_6n-$p!~_e5b03GrfQs`psK3LQUne~ke9&e3tTWjvpu-%hTIha
zZt8#uaP7)fkXi&f>ohSvRUYI;a8>|a0>;P%y$GyI817w!T9oVn@+~NOz&-{oi~v=S
z*^J<0X+i0Lp;!(S_@GWzHdB!b_$(ix63|{y(D@<Yvt&R^T|lSDXtF>uN)?B_y%iW$
zaj1G&srp)}25YiGQVb~bfIV0A50v*gic5;pK>7a`TRO@apd2Zn!%8#r^B}$l`x#7t
zJ<bnln#98tX@PtXs`eQe<rvvmgcz$N;QmHaiV@wQArY|Wn?Pj&1L#CvP;`SlUCWdg
z2a0Nt=fUYv4RnZ6o)<_C)M+TT0YyIOoWX3SA}4UiL=SXH6F5<@NPreIgN8mqC(AQ{
z3PM@XvSp?eRta!o5dkF=Hc*ke0K6&))Q1J_Oz^wK;*y`2TE*fT;;2w`7gSS&N(S(l
zMHL%#Why%)!GH=(w1B<EnwFEFSW?8p#J~VcLEyzusUVZUVF)I`0m<wd;%E#CJkWd#
zs5i>O$id74N<NHYjBL!H`$PB`t9amn=^EmQ5rCi+1P(w@>kgb{LFWpAcgEy_4>tw{
zAK1&FoWWQEI;>9uv|}!XIh&!#jFF+x0d%9PEJH10p;`(nXk;216l{?61kElC44E&O
zL6;zca*sp5LluW=ih^pflYX%#OA$CA;EC%NYp9=RNHEO%pcRz2SW5FUOVEpI*5ZQH
z)D$;R2!IM)1}0F(5dyb1L7`B^2lqKxp&zIY00rYWP({U$-Y;hZZ8HaV&cOvE3y2FU
zjf+@8tW%(Jk{!h201=@0DdGpQKqq1%ISd{<MPC>h7=D5(bkJ}z2O|p;7Y7Fy2MY%a
z2P+eJ{D+H+gOiDoONfaPthS0frdlI9t~ORnGp4pmGCEE_CPt?^HbyH(s|G|s1Zrce
z1mmLPs$;ccYHMPu!Rk@BT!4y7c&vh&JD^51sG(dW1<D$rCBU%$a|!bTMzD+tD5Idr
zuz<GtfR@o#Il6-GE&{E`0bLT81X}6>y7~b$B@J123OWWKbdimMmKJ!<ygI+2#84-{
zpu`A77}x4mnS)zCnJEe&6BJa7tU%{9l@=9))~SMpl(e*z6mmg3dXrKi+c^?*K)J{W
zLt}1cac*KsGH7~1p*XcfAvduoJGDqby;>c#fJePnU6b{eXgv5VxcDGf=g^>F&oI|`
zcOQQz$W9zkzwDMURDrK&u&-l?vqyZeYsf9O_)L&nG?{L3f>u<<gE&PDplAojDVP9d
zJJ4!<hG<ZtgOu2yE)ZxS4|HNJSPmtRfx0xH9y6!`UCaR*3IxqLF@UD-Y9Y(98B-Xu
zS&A}1q2J61+6_^x<HZ14o(;OkFowAnasdx`yC8U}q6+9Vrxcb2EHz9utTilY%nKR8
zlYCsDo7ln_7#Rv93LWz1fEMSMF&4FfiZrM^YYi({z9O#<yd#4Z<O=YfICk(@2UF1^
z(0B~!pucRUq75nRwd{E!HS7!6QaBbef<{vou%&=*)n+eYhb(yn-<8E&%T~)#%UQyn
z#kqhBwBn+ct%MoOV*%X@wvY*GJ68=C*!FLQ=fEuyE<bRg2;M;jKC=Pb@2FzZ(kik6
zg?bf;09}yyi!lb&9SZVv_JBkr__#)JS6dX613{gpTb#uuDUb*RU*HJtSrxqi8Ic3Z
z@)JN=p1VkliGkr3Ur}aq26&tS635{36+ABix(W!q3?>)c9lOO|l$es43~I)L&aDD>
zwkCs&1g8Zs0ZtGgSEPXw1bBp(5j4UJTF(w@)q)Nw;$h@s5&$1$%)!XU44P&DHSWb2
zi$MA`nQ!rUgoFeHdnD$i<fIne;sYn|_>BBw@aVuT0q4}B63BTRso+^MP)Y(7qHqk#
z@Zh!PGU#0~CeUp!DJ<Z1=AgbS>n(n;UCxm4@67x>zYvtv3aU;)H8HqG04<JzlpWwI
zkvR?2T4Dk1o(82U&`#=R<{|@76&TM3I<ONord7gG!kNO{%mkij<|^_i;mqQ$Wy)hK
z;mqQxWh&v!;svSC;;UiE;;#YmL5)MM6qa7L8ishbytWd~1%f4<Spo||+Y~`&u{JXm
zO{-yMVaO6H;mi{DXJBH82h~gbMQdu97l?q(VaVbGb>K5WGhYl@Tt$ySw$?Dmi`Fn_
zfu`8GQrLPK85v4gOThQGH!~MK0@Z3YEGZl|3^mLkH>ELVGSskuRu_TX0XoZY0%K8B
z4MUbVh^|s80nM_qEs$IYs{ENiH_??yEs##(1epV}JDed;kA<N`W&&en1S5FJpoSrf
zZGmhFLzWz*1CYhGKpqrAO$?A(7HA&0#S>prnwOWF1CDXGTU^1xKA`)+Q!7e9+fS2I
zi$E)O3yW`Y7Z>Ni_G*F7Vu=Sy72o3a4~X~kj}H#^DKpY!yv3HB2pVC!#qQx493SlG
zd5ga|wFq=0Gb}w-33}uggAbJlpRNx&aX?d{=rpLuF9<np0BM5Y77Iw*Ef&zBUbomm
zExr8G67aEJw^)kvle2HJLmdw}lasl)IHyPrl*M?RU4ug6gIohcJ%e0bZgGOSe*S*0
zx41z!uf>Bjr<UB}$WDcvj(m#~<Qwo1)-C>kApa15XMZ1vr;Lk~K_;?;j_m}UxS|f?
z@q;dk1BU?Un#jz&Tij)-MVV=p@t{L?Z;66sp(5bb_@F71TRf2A!j$~n#LT=Rd5}5W
z>8T|Jsi1avQ3>RHU(o8IA_b5fM{!1JNlJcs-Yw2xkI<0#AeZnU$e<f^a#|l;_<)qM
zC+FvZ4oxmvfLS_#jv@umHuZx_2+$b?pnW6YWkgI|Ol*uCOrTTjKvz<-{N-W=RV1Lx
zz(D)0K|Ny7BsLeL2>8NlAx6-F+n_5vtHjZ=u^w#xhYh_|1B#9!8<0yKK?JzaLJ;8M
z3v@Jf7szp-o&;!<Hw$wSNDQN(0ktZ?1r2Dg8hp%$6Fj4d^<osz*=a>`ObiSmxCdlF
zi##Bu3^<>Fd#a$Z2c#p@G+Ay5I3*URf;|l_C&A+-;KT;@9jvj4@GhDsK@GcYFi(Pd
zvuuo2qR0j!23J7sby(pF>i&Z;c#$HgB?{UCk;zcQ1S%>(D|50Ki&Q{8iW=s4PzRE!
zhB=-Id{7=^qBIlqFdNvKJMbo(%wh%TlID_p=rs-siJ&`zKr@n{4Xg0IC<=c0MY-Th
zfGYD#)l=Z>6hX#;7yqGXgKXX@$yZ3pj|UwFuLC(?qy&7k1L!;&_?1H7YycY3MlmrF
zve^i73JmygmDGxY)MU{09AF27P8ZQra4c5H$<Ip%-RD#e+6e@{UjnQew8s_2K*&Ag
zrJyU9pqCPW6zeFIry}i@@%IKF+ml%WS`}CXJJ3_1I3L`!L@}>CRY42XMATA%c^<Sm
z3S^#oP7XXI^Atk!iWAcyX$4WwK|F_Q9{9Qhu-l7MONtf1!4eNC9YE_U-5_^_fLEPE
zv@3v*zR3i&e8ItlVq9`YetvN(^b&^rJn-dDV22{21hFa-6os0QT!xf}p@&P)2NfdV
zk_43Ckop#&+<J=}Tt3I=CT6D=?FJ=i@H`0@=+*?#Fng5*YN7@e3=qW_0|y|D;EEo!
zceqLbys(4;G<vp>33^E@6KHWjEfXU{l}-vHXlGp(OEc)IU%L`k&<s)*8)WBp9#azo
zbO$I?9TRv5C{rC1Xa^{`l4JI(k^~j+&_)bsuSI5Br9v8b7iX0g;<Ot`iLC&su@sQC
zfX-G?E!Jee#STr~Mb4no3^dGii@CT2d|y;zaef}S<Sx=d>O6x^<|qQ)yoer-Tp1-L
z1;ya3avBtj;2tC+6QcklXfq}YBg=mdW@tGJEpqe_I>0MEG0Iv{83S<`=<sJG3&CX(
zDE7dG;Z~4!kg}GGl|uk5hEdkS8+D+;dU#n2J+~5kg&)f;0dQ3N=jBvFU5FCJAQM0(
zHaLnwzAFJ8!T`PZ2OKd>epQa4h^@CE(_p)8L6?Y?gKla=Y->wYC{9f-ElNcytH7-X
z#v)KOK*v;zz~K${FPH#%`W7cB;J_h$ALe!N7TEt)QXo5nk$eCSW3W=tJ_*q6c}T~z
zdV=B{Y%GERSy1G`#K3S5WHiXn9E@Q8OAvb{Q;`=F1H(&DXk!F1C~&~l8OZ(cAZ7)x
zm<3g5piSazw^%?<1b0m^Zzu#A>kYb?6V&jpf!t@n13D-Wk(WTL8(<69K@}V*;ER};
z7#LPE-C_gXNLX4BB?!*akUMDO!R7c$Xi)%4$wi>M0kE|!z*XRDkhekZ0G-yt!dS%%
zaxT0s(`16Ud?gEdy8xV45y1#%fy2_5iGkr2$WT!DaWEEv_+$nhE66Ru5Eq~{06;Y=
z$j#)2U6CIsB?N#7u*1Ow*!3W9eFnK6WIQxT_`uG<2$P~fRQ(7;f|wW>K7kB@1_6kV
zI|x9-JMh#4S>6RoJ&^sqEGeL~@i}gBh7={{6@%K*;B|2*p#e&Vpb!CPRM1c!sEZWO
z0KWT#xdya6iV3m+3Ni)5QltlRIOtN-qF@jU<mZ);c^9zMEuPZiRM1xCR8Wf@sThKX
z&@YhZKvsg5QCA7U-3AXMl!62llpw`m_kr>^ICV2FWP}Y)fEFTVGZkro&MX3rsirXX
zGS#wzhum3;Y(T!rVo70^WXNVN3Id;r%UZ(-+Oi8;_yy`z#)Fp1v49WFWUXNZ9l_;S
z<P9pr8NvPmhZuOQK$GJZFK9^~s8<3$3hfprs7nN9f)grOJ+z91<fmJFpgrqFiSf{F
z`$eEZn_J){foL7TmH~mX+bzb7TTH1Lw^%An4J@&bUxVsiq%8Xn6q=v{7IY^L=vH45
zM$l>hpws;kA&aKRPm>Yst(A}~LXiqNP;3^(f#MaMAQ1#O_COK-6J#GKLO2+?Sinhu
z!o<lNoS2phcPiLj)JmWUAdi5(6ar$Q`35Ax&Bnk`4Dt;)EsCKy1$TM`4OD>BV*_~H
zA95coEIrn+6iYw{0~l*qQW$L*N|-<cYejb8^#crPOt8*=Eo&a=Okb9wAe2;Egh-`X
zprJ7&9k|jfI8TBSEjaj~skJB!<Y}-}IEV!*NQyug3KT_xxS*s6?r9;XzoKZ6R1Ao~
z)dmD74}MU%fjUp1R0mqQ2U>_G!URfte2h&0xtO>Zt7K6_6Gs{>iU(PSh#D{poZ3LK
z#|5$n6hGk91`@$YZJ=TjT#@2wt8fQ{#~}iW@+(lU8U}3v0~rsl3qVU3YM2&)&P`)j
z$ixDgd}ai#7z9sg#zBTiW0-1LYFR-GmO&lQg-o?<H7ua{oFa!3mRj~amJ(LbP-P8s
z4O<FpFUSn06gC^s4JRC+p`8-;ERHPB8V1mkc33|SQo3rg`+<v(qEJw9fI5M<SV0Y!
zVogS{&@IjqSQ)O#1zv3mQ4Y%aMWBVtMWDa|=f@&Y`B?-mp%X!dfzr7q^b!(K=s{|8
zaJm5P*(m}on1tBDQUbbz7|Uc2xUyFO#RVvk85o6_L1!a^mg0c!pa8{sl?YN0!*h-w
z?rIL?G<lGTp!nlpECTUC4u|!98DJF?IBGz%i=Y!3Kr4<@n6ep)Bx)E_n9Uh#8Nt`S
zGo`TFFr={6Fr~1AvKwju2Qz4LKxTu$qrJBnlfaFFTkLtMpp~?#;MHeEpc|<)nGvg@
zz{{jGnTx<fuAoIrkYEERPcQ*WqqjKYlZ(s1Ek+ZNUqGE221Y(cE+)_kyG7|t447xa
zgOVFKy_z5mn5HtPFg7!$GN&+sN#<t86qY&6Q7qt1<)CX`A?L!gr9e)EXLk+`1C2?5
zN3MS{DixgojW9Fc;!H`+$;<`qq`bvhSejpwnw*hXbc-)1GcOf#<Y;0^KIYCTP-+7g
zXCSA+7YjhDZfukDobmCgc_pbu@$qgTPlF<mfw4*u>L$=3;1F4q!CjCl5OxQ(SV3hE
zXu1z{G7u#FLs}P1Mc^Cm*CQP#5d!Luf&&~(fJ2=lK0dVqbho!BlKlcm_JbucPX{P+
z1&x<+Ku^ytE&|;uQj`bEBVe-;1jv@63?>E!dyoY@pmWE;bK`7(+1NOk!7`wn1W&6V
z2FP>Zcm?&F;Y~7lp9wq=4v)`N)+n|Vc2LT^#pxUz76d-k2PM2vl0T^31G;aijG@Q`
zG|3LSRsozHm?Rlen6p`nbikWXSr#&a7R%RyXO81R*9NlIFs86dGNiCIgVqqSlz{Ha
zX2@az4>&Vqae&5=Y8c|#LHz<y2?P#(P;vn06iCJZ&tQO-C2DdO!Pg2xF8c!?Uj)_z
zO6j+llZ(rWT0!xZ4{AR_8-?I{1gr=xd_m=sA1Hi5sR7hl=3wLlok7hcz*r>&4-|M=
zf)Y9)H-a!J$rf}YJUG=xf-D6^7ij++ibY^)6pKJv0))X9feyd~Er88pYzAFU&XmOr
zFOQr`SU|I8E)1~>;5jYk64n~#61HZhVuc#!1?-^p$2E*KOg0RK3ZQizE1~Nh5aF!J
zaf>Anw7?P^fQW$30EK5aXch@Hkyiv-hzZ*@4oYZ6pao||pus*!eg%gyIQf<^F)+k{
zd<sgwpfN{2M$js80mdpmgr7k+V#z0<s3|G}Wekuhw>aYCK?-r4&tJgAz~BqA2sC%Y
z!N|eQ!OX!?1QNxaM^Gn=&^C*L8sTi<d=Xv*D$8(J3!o4Hjfti(g3~u+2~!p`Xgm~}
zzF|`;;H{saorItTk(#XFav4(66oLu_wsNpFMaZcZT<n9BE;vNN1UOhhL6Z*hEhtq$
z)@C^ehd~^QNUPw~1u7L77(lzz!5Ex`{Gi7K!xN4jX!8_!(~A;l162)k33D@3ksf&4
z6f<Zd3cO7Ua%GNK4e0P-(9{k)XcHE+<OFSf*W^ITn~2oH2TDBPO$X&5k8(gfnqLl0
zLARKT^2@<Xj<Keo3MK}IY>-z$jSNt=23dCt*%ArPqEK(cjP=vR-k|^)gp@oHfmz1H
zz>o&A0Th@Vj2tXQAQ6mY1Cj*=W-;heX;{&k%ACrQ#o7$oQ_Pskn!;qmkiyf>kj4mJ
z0LmG~2HtTDI)4SS<Cr4_vH+B`oq>fRiVJiB!7b3yaA}$8pyfjOMYp&!^O8XwE6^?O
zx0o~Yl2M0TKm{@k7lXpIgrS77hM}1Wa?v2@bio2C(CQ}8EFEOICZtkh1MM3Gonlr6
z%21&61DPK_4$9P^BXywD2cTp9^U^ZY!KW#$WW2>04;hYuWjlECtAm9YsPSDT>YNYK
z1@Q#-6bNdTfcnuO=NE5aU;u9lgKePbWb9yAzyK<sYMDyF^+&N*2gp;PRs2j~IhGXA
znX1fSHt6VnCeRsvMKLAJ?Tl%RDWIkaM-7V$Lo=vYWC3kCOJhpmOyOwZ0BtjCW&~g4
z!`jSP%LcmUCzGLu4OH*cvez(!r%_oKf;OW`#4v#;^4UPwM07CLa5gi7?outBR0FCe
zxlp$yfII?96vCj!1SkkWr84Lkwlt<@rXsBpX3+W(aAE+}zZ^9TP{%Rmd4N^2G&2=t
zfY#uZF%)@pFfL#PtwX70EGz;YT?kSgD^kk@+R6ahG}O!pEx7~oxH>==MS>2Ag{;nF
zL3I`=*TbC!YAL5P)PS~tFm`~KR3KeG0nQDY(5ojvMfgfa@KhZr?SbVWySG3WP_(ka
zZo+gziRol$w5P@=mll`g=jz#jCL42#?evl%2ZtjB5Z6=uV$#smWQVNo2k)5P1zJkS
zQc_uv3c3g@x#X4ry17M7;L7|KV?Ja&0<?o#lL;&eUTuryT#(9UP~rsn9aLb*fDhK=
zVFDE#BA`B@9%)`E0$sNSUXW466den;38i)>Gr-$H8L<&WAc`VTP|tt|wIPx2M1(Ac
zyFeKZoIXJ-M8F9_26XHfsFhH}0@@M-N)(a|&5UVGNC`ueu?VCImNcM&T?cY2D0IO=
zfJhrNVGh=0hx7?OK?Oee5+zW?7PW%(tprW4vlpk9B$kvEX>vg#4Q%3MkPItmyH{}$
zc-{x36w=QD)vQIOAk#og^T5_>G8ch$f!%Q#RCs|)q&6l7h9*#?gN7m*82R`>Ljj;I
zt)PvrV$dc2prgEm7^`IQ1}oNj9$agJx=Nt_0(g5lxRe4Np<QGE+E!l1P-IX8x~!0C
zA$S#i76a(qDNq|2eC9Ve32CxGoDQxT!GQvDHMHC<0&Q%Dq-}6=023gufo`EoPc6wT
zNzILqUkLIdsD%S+N(nK7ZktB&Og!kwO^8wye}KvZkT$SCKyzK7b~~iXD3$@UK`j>0
zrJ10UF<G<NK<#_b*g`LJzf>&~Y_U@<b2vi^3(D>gAC%o8pflQ8tF&NuGeFCLRKzJh
znR&@p`ud=YK}zzI^K<kd^*(4PQ4tGdp9rK{0=4&Vv1S%0CKZEsDT1pbNP8c&bEpV@
zTq(2>0lCo$e0>f$(SU;wOn}0$sG5m^VL2%5K$Q?^1F8U{5a{Y@36#)7s(L{;<Z+`<
z7=YspwC(YhKpE(eWLQ0&T2u@kn<xUsXHgd@xq~dc#S5)FlT&kYVD%^1P4yrpV26Qf
z<4TajK<#4=CeZ4CJ{Asn4z?nY3`QFSRONuXcc9r8SQ{h-G}g`qZgF7SasrAI?pyr9
zrAY-v`Jlt(A;-QsgQsr6Y|uowLQ!d69%x}>F<f10F?cOwa$-RV<kXsyjMU5`h5XWz
zf>Ox2mu{Gi6Hs9YPGz9x8fZijb`u<^cL!;TFo91SP0BA$y#?Ck3Esd0%LV<QkeL7?
zzySp&zySqnv1|ba6euZ!$4Mp7e1vFqfI<n>QUhU70SF%{1udlm<zUFF1@Qh`Ch*zp
zti@7=aW%{-jHQgAR&Nb!4S0c5Ax{lUu>*KdA^2KAMut2g2(N~90UM~b0-DbPi?D+h
zHWl*JFfQN#vB0Ovu~e-92Qp}?8`Qa001bf@L(UXU1f3NGjSzKcm?}W-i3f*zY9{DL
zGzHl7c_JvwfI|vyB4`N(Xhnj8MrIn~suoSq8c=Xk7_LJBys<48a+y_0KIkYvz2cIT
z)S@E9Y`h=1egpTlH93pG5deycTO38Hi76mwgIo5u*dY2KH^GB?fuP0OrNtSLMM2OD
zEy3Mv2T&Zs&B1or1h|vF0~Dp82_FVlHbyq^X>FjrbD+wak4Xr06oD9eG=p4}3Lahr
z#V;7cA{jhNHxJsmsbNe5-Q>gsx&bPMaSjt~!3rq4z{k5VXR)O)r7@*2_kx>}pkrV_
zcY|hureauYn6o%iSfH}3klnP544_jVK+y|1)Sr=|h81+UKO<;G9Cr#sDPvJb4Fl*<
z=oB{4ia7A<ah{@CCA?W23;0slL5T&tFowfVlL;J_ptWR^Kp`~+)VyIT`U0xZz?C3K
zw2Bq9c}fp-lX_-e6&sktrO6LI5)YbmZm|Y{R=V6`3GfVXy~SCQ0ScYWy!2aaAz&sr
zkc&X37l9XYgNz03w#zJm6sw3B0(bVo`|cpoc#AnXHw97+gSH{wVk$Ab#Z+Phu7n{3
zC|};<E-K9f9U+jLn3r-E6q%q-38+WP@}Gqfbc2@|BL^c0gH~pM?)n0)(%@mNlE#Qu
zggKf_Zdir`5Qj*C2Pfu(f(=|gAPA6)iu#xs7&d@h0;=#pM@Mn7aEO9MQCdf!fg5<i
z04mf$E3iN-I%^mfGB03S2)c}sxk?AJ04cKybgCcpQiTG@Nyy+U7Zef|auO8+TmuwL
z4UDVUqIKi-Vzt31s%tVA<%62F%*CZikW=XyA%{bwI`<Y|9(ajUW>soDXg}&bkjp`Z
zC<AlRLU5w+15K2j0u4qo`hlt?(DtPka8-DVJ2^im2QtZ53>qk5xWxrsh6g&=7(A@N
z0$#%nDiMn$K_T`G)S3d-p10U@^3&5Z^U@&|t{g}l<Y4eZ$Ra~fPo3Kne3vPB$!*az
zkZy1yxdT!PzW4~#iz}MR#J~{6pHiBeTNw{ef8gCQ;1O={0sWv}Wo|)YNf9Wg7J<i*
zK(SNA2}<vvI=Kk6NE~ulIp~;e@DwFv_5f6m6bXXVfg%aqE-eDJ?2AM}VxV;kkbR_}
zLIiRL1!zVHeC~-)etLRp5u_FepOB^iaye+!r^pke8Pt(4G6%81rxRO)Sg{~N8ALdO
zhzt+`nqVtx2eEoU#1s%Q6GVWH|1UZSYQOS9!#y`KFA-$tF_1Lq!jYm2AQtF?$s+L0
zlaE1M(1o|)yIR4QN8Vx&a}9C=-6-V^av$ifJMcA6;M;z{x9)&1oB?0=0=_2Y7NciT
zAxLR1h$sUQ6(9n1R{{8B{GxUcw+lpojuQu;&ka6O7JPbI5$Mc>TSAUO&K{tR0j?1t
zu71Iu{(iyW-N@h_utfr(*amIiD3SoNgh7M|hyX3v1~1nsasqKdOGqIrjzG&L!K+Td
z+qjFslYO9t6Gh+|KhUHtWO4{J#R3`o0u610N9e%gE#L+ZIGcjgJ*0?1%PSl<x!{X-
z?LZl~7!-=286Z%}0-6N^(J+j3v<P@J3<ncLgpZMfiH9+Ujf)Mm2ptJCb3}4fa!7G-
zaR_h;aBy<ya|p9Aa<Q{8a&fXS@^A|9aYzf)Ggxr&3&^lBv;1XY<&fvn<PhXw<KX9D
z<=|ptWckm+#Kp`d$;HgU&mqYn!otMC#=$0_Bj6!W&%ndN%w@(Q$igfT3$~M)gPTK|
sjZuU{NLxTth?9?ri&2Q3jZuhQNPvw|NK{CagIj=4KvF<hz+6BN00=*ZF8}}l

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/version.cpython-39.pyc
deleted file mode 100644
index c97c1bf37a7349062ebe174707b8fa0b26df4e40..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/__pycache__/wheel.cpython-39.pyc
deleted file mode 100644
index 7f8f24b6fb063e31e3d632d990e4a98405483d5c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py
deleted file mode 100644
index f7dbf4c9..00000000
--- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__init__.py
+++ /dev/null
@@ -1,6 +0,0 @@
-"""Modules copied from Python 3 standard libraries, for internal use only.
-
-Individual classes and functions are found in d2._backport.misc.  Intended
-usage is to always import things missing from 3.1 from that module: the
-built-in/stdlib objects will be used if found.
-"""
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 2d3302e2a94dfc0aeb36363d66d4ae1a5bc139ad..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 511
zcmYe~<>g{vU|^UdaWGYgk%8ech=Yt785kHG7#J9eIT#oiQW&BbQW%37G?@~)85tOS
z^HWN5Qi~Om^9wRlQxwvQ@^cjeDoZl*^AwB~ic1pnQWA?&6ml|?iV}-5Q;T&J((;QG
zGV@AOi}Dh46iSOz74q|PD)qRyJo8dA%Q90+6LS=ja}tY-Q;QW6^HLPjO7oISGV}9_
z6%vb571Huc^HLNt^Au8y^x~5eld}u*i%RrzGmDe;6cjx3N>cMuQd77}ixbmR6*7wz
zO7ayFbIKDdixo0+K`IqWGBWehixqM+i;FY!(jl%j)-!}KN-`2l6mr4-u~I0>Naac@
z&CDs$&CJs;E=kGBOj5{C%1TWxDOM=Y%*jzmN(H$-MIkc{;wn8ZKTXD4?D6p_`N{F|
zD;bKI7#JYLuP$e+n9$<XqT-m;oRrL>82`Lfm!izFR0UmyP(RNw*Pvj}5XWEzPd^ub
zKi6PS$CzMOU)SIe*B}M6n1BGEm_!rZoc#36;*!klnAE(o7@y3fnBvTmRNaEa<m|-s
z)Z&<e%mV%Rvedkk{3897%;J)q%p`qy_~^&SXXa&=#K-FuRNmsSf%wo46sey<u?zqL
Cr=rmS

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/misc.cpython-39.pyc
deleted file mode 100644
index 8dd32bbd50bc42f64a21559f56a58dd142c39776..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1131
zcmYe~<>g{vU|^UdaWM5XGXuk85C<7^FfcGUFfcF_FJWL{NMVR#NMTH2%3+LR1k+4W
zOz8|M%!?SKn5zU*7*kksSaMmTSQ#0@8S-RU7*g3PJs254FoidTErq>>F^V;kA&<#`
zp^77wJ&HY?Ay18kA(f-D0;Gl!WHv_*XD(M17b8OoX9`yfLliqyJy$AY7IzePI76Nk
z3qvYT<vgek?i8LDhA3``suZSR22H*yeW%3a?1KEFl46Cl{33<Syp+tc%#_l^9EIeZ
z#Ny)AVui%K6os_XyyTM1{Jdhlmmm-OX)@muOioPBNR3Y`%Fm52&Mz%WPQAsEoS2i7
zn3R)xizBT#H7_|oB~_ELh>3xLAtV_@g0zA#GXnzyi0=#vD-i|;h8o5qjugfMt`w$P
zrW%GCCUJ&f22EzaTa3xK81q*$Xfj8!7gWZlW#**bVoga+Doww|oLW&*#LmFL049F5
zIa|eq7N-^!$E4<@WEREv=cT$7WtOEX=qiNzd4{<L1$%}#1}k{_x%m6J275Zj1iSjW
z28Xx?DVW6s1o*@xn&{@_r)L(IWM;>t=9R_xWG2NFXO^Vu79=KTC#I(s#}s51=*O3(
z=B4Bp>8E5Cm*iw7>BlEQ!%japvp89=pc3p?L6EOlK>lRpf%smN@fL?OG-#3;K{8Mb
zVuJz$91x(iRl-oiP{P;@iW){gO{QC1nZ=oT#U+V($*D!$3=9mKjJKHcld`~`h7cfK
zMIbYzLDqsom4Ok=$FK<GB(Oy`3=9k~i;DPa7=j@@re>xhwHk&6%q1)fSQj!ZWDI5~
zVM}2wVXt9mX3XLcV`ye<VoU+W43l4#bZSLGYI2D}Qe{bMu|j^4LUBovjzV63iGpge
zCT9^30|Ub?R<PtP=Hil~TWpZzaErOPviO#0dTI$MGK(vVOHy;eGMRblw>U#83sPN+
zit>wYv6NI6q~79)kIzfYO^uHS1t3TRhzIdDIO@TE2YE{g<aa($pfYkXvM_Qn@-eY6
za{Mm>$!Ri%X!71-kB?8uPmYhj#gt!M1d1V$NMcS-eEcou%-jNS#NFcd%mw8HuoJ*x
zc#G37F&FA2?&SQOoK#3I0LKN`^jmz6B_&0fNu?zaWk{}rJMk8WO>TZlX-=vg8_1ms
n3=9k`OdO0HOdQNii~@{2i~_7oj2w(Sj66(yEKH1Cj6940kn0Y4

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/shutil.cpython-39.pyc
deleted file mode 100644
index 6276239783ad31ee70781dd0ba8b38c5ae70d506..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 21705
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
Qx?`TdY;2(UYOrc{0BP7n2LJ#7

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/sysconfig.cpython-39.pyc
deleted file mode 100644
index 605f0df3d550f1f368c94f5d5ce6f660fc318f3f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 15995
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
VGq7-Qa?~>@bFgr*b8vGp0st_My^;U`

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/distlib/_backport/__pycache__/tarfile.cpython-39.pyc
deleted file mode 100644
index 81af67a91a823524ed75c3f3cc508531e7e39f6c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 62759
zcmYe~<>g{vU|^UdaWM5tCL_aR5C<9aGB7YWFfcF_yRk4Zq%fo~<}l<kMlmunq%cJ>
zr7%Y^r?5n^q_9S@rm#h^rLae_r!b^&<ZwiBfN9PsPB6_C#RaChqqxB|PZSTB=8fV7
z(|l2UV46RQze)tm5{ME2(}Gcg;S70FEDWham6I45Krn@ag&|5HN-&ZkkI8@`RX9~7
zjVVgBiZ4|(RV<CsoFPgyoFPw$g&|eEat}y7BLhTbIztNQBE~3*RE{jk6b4C#6s~NB
zqI+Olq@twrATE}Ul1`P*l8KT{;f|6^;faz@l~3UnVTe*l;fqpC;g3>E5r|Sw5r|Sr
z5sXqz5sFev;f_*I5suPG5sA`F5slJH5sT7J5s%VIk%-bwk&Mzyk&4n!k&ZG*k%=-)
zk&QA+k&7};k&iM-VTdwKQHU~2QH(NAHH)%HRZCS*)kxJ$)k)P&)l1b%)lSt<HApo~
z<B75a%ju;Wrm;j>K}DIPtW%VtY*KAgl$#l&>{9K)&>__!)geV?4qKFCifWWoidvL&
zih7hwibj-cie{8sidK|+iguJoicXYg3Qv?*if)v5ie8jYihh)Dib0fLieZ$0icwTR
zig8q6iegkyib7OyDrZ(mib)y61g0Xk6w|2CJdRY31z`&rqC!*5Qp{TzqQX-wQY>2-
zq9RhPQmk7Tq9Rj_QZ3S$QfyLeTNtCFQtVRfTNt9EQ>s%OQXE?tqheB>Qk>G5Qk_$r
z)0k3SQe4uQQe9JA)0k4-Qryy*Qr%PB)0ooOQoU0=(wNd1Q+-lA!L)CxhZ94JR~l2Q
zM~ZhEQ>t%@Pa0DibE+Ryoj+7vK&mHHohMjb090KdR9z5MU2v+G6GMt`8dIuQieDO2
zYA{4y8dp?oihoK#3qw?#J3~rfN>B?!N>FNiGjmjeJ3~rvN=OSsN=Rx#Gjmj;J3~rn
zN>~d+N*I`*<j#;1o)Xc*kP-prC%ZGGM5aWwFr-9*`6=!UDbXo0Eet6!V1BAQLrQE)
zTnj@=Txx1Fb5xo;LrQ!~LJLDm0+^rf&XAIrlGMVGk_6^wxHF_Ar=+wnq@;lPneGfJ
zsVQkK3@K?~ewI5!N_t903qwjqYIZYoRE|4CN@hw{3qwj4n4jy;kdmE})54IF1Lo(s
zGo<9E<h3xQ<bnD5?hGmUDFrPIDFtADfjdJ=VM<X8LrM{tU+B(|Qk+uK!jMt|<`=m$
zq?D$VwJ@ZVf%(Pm3@PO)6)g-Y6<~fzN@Yq_3qw?Cs!UW_YH^lKluQaoFoR~zOHc`;
z$#{#epeQr1BtES)FS#T$Kd*{QB`CElvp6$9Po;|0K+jUopj3&0fx#!Ss93?hw7BH(
zlBCoe1&y4<qGE^i(&CcD)TGoLy_8hVDpM7g#FA7i1tSAPLtO(ST_aNkLvt$=BP#<#
z1#JT(0|NyOx1vlP1tU`hx6~xCGED`QDti^r6f1?2#G<s!oK(GnN(BoGQwuY&G|UuJ
zh$&GDxrs%|x`}xyMX7o@skup|Md=DEr6vpv3?P>!mgOt>Wv1q)R;Cu|fLJ+5F4j>9
z%1q8kEJ{%b$uG|<PR&cv^V4Lx#U7Ga<d&I}3TAlbrRCq^$}EnDI_4HfNMey|QBi);
zOJ)WJhR=+kAbZKc#K7=U1XLVzFfcHHLZC=NfuR`AVK6XwnZm%p@Nzaxj{#VxA(%7*
zlg41u1WcNONi#5M4kmrTq&Juh29p(FG964tyac)9B@+V!gC@r<mV(5Rj9VNznR(e@
z7E5tvRq8F)+>*@P)LYD@nJKrJ(=$_Uv6ki~=BD0aO$Sk$EJd;m3=BnbAVL{LsDKP(
zyTzIa*2bC)qKXtiGKwGqlmLq485kHc85V$u1`v_J!0-}OEoCw&fVcu6f&(PR0wNe0
z7+yAjLIG59y#yKcQUJsS1=C9wkabMAnDR=Zn37YgSW8RNbS;uWqM#54VGtXHok8KO
z!N9;!!?1v%hN*^mAyX|w4MPfJ4Pz^lBts2j31baIGou7U36lteI72XlCR3G#bADb~
zYEg+oqC#;=QD$DcLP@?tqC#G2PL6I#YEf=xUSdgVib7IlNouh|eo|Iya)}<7f`WpA
zpC<Dyw$!}j{FKyN%sHufx0wAxeKc8aF&5uq%Sp{k2L&`(Ix{c*7F#MPVHB@qD6(K+
zVEEPPY!wq)oLW>IlbVx~Srp@+m+DfKS(d7xs}Snv8Ri-k>>1)1tl;VA;_v4g?CBU2
z?CR?p9O4?JU=|Y);1iQ*qMMVSo>^RynH`gwR~F-wnG{o;S(2(-keHmEn4Vf3Q;=Dp
zA77T5my%zkpORTzl9QRFAD@(%oL!J#RH6?}vU&xTx0s7d@^*s44HSS3%sh-mRtyXb
z$)F?*3R(~b$$&68c(tIxo5Hw|v6i`pIfW^kxk#>tA%(ey85GE%0AIjZ!&t+#kSUl!
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
Z1?n021nL=JPz;F;5(^Q~;^1as1ONu;lz0FD

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py
deleted file mode 100644
index cfb318d3..00000000
--- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/misc.py
+++ /dev/null
@@ -1,41 +0,0 @@
-# -*- coding: utf-8 -*-
-#
-# Copyright (C) 2012 The Python Software Foundation.
-# See LICENSE.txt and CONTRIBUTORS.txt.
-#
-"""Backports for individual classes and functions."""
-
-import os
-import sys
-
-__all__ = ['cache_from_source', 'callable', 'fsencode']
-
-
-try:
-    from imp import cache_from_source
-except ImportError:
-    def cache_from_source(py_file, debug=__debug__):
-        ext = debug and 'c' or 'o'
-        return py_file + ext
-
-
-try:
-    callable = callable
-except NameError:
-    from collections import Callable
-
-    def callable(obj):
-        return isinstance(obj, Callable)
-
-
-try:
-    fsencode = os.fsencode
-except AttributeError:
-    def fsencode(filename):
-        if isinstance(filename, bytes):
-            return filename
-        elif isinstance(filename, str):
-            return filename.encode(sys.getfilesystemencoding())
-        else:
-            raise TypeError("expect bytes or str, not %s" %
-                            type(filename).__name__)
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py
deleted file mode 100644
index 10ed3625..00000000
--- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/shutil.py
+++ /dev/null
@@ -1,764 +0,0 @@
-# -*- coding: utf-8 -*-
-#
-# Copyright (C) 2012 The Python Software Foundation.
-# See LICENSE.txt and CONTRIBUTORS.txt.
-#
-"""Utility functions for copying and archiving files and directory trees.
-
-XXX The functions here don't copy the resource fork or other metadata on Mac.
-
-"""
-
-import os
-import sys
-import stat
-from os.path import abspath
-import fnmatch
-try:
-    from collections.abc import Callable
-except ImportError:
-    from collections import Callable
-import errno
-from . import tarfile
-
-try:
-    import bz2
-    _BZ2_SUPPORTED = True
-except ImportError:
-    _BZ2_SUPPORTED = False
-
-try:
-    from pwd import getpwnam
-except ImportError:
-    getpwnam = None
-
-try:
-    from grp import getgrnam
-except ImportError:
-    getgrnam = None
-
-__all__ = ["copyfileobj", "copyfile", "copymode", "copystat", "copy", "copy2",
-           "copytree", "move", "rmtree", "Error", "SpecialFileError",
-           "ExecError", "make_archive", "get_archive_formats",
-           "register_archive_format", "unregister_archive_format",
-           "get_unpack_formats", "register_unpack_format",
-           "unregister_unpack_format", "unpack_archive", "ignore_patterns"]
-
-class Error(EnvironmentError):
-    pass
-
-class SpecialFileError(EnvironmentError):
-    """Raised when trying to do a kind of operation (e.g. copying) which is
-    not supported on a special file (e.g. a named pipe)"""
-
-class ExecError(EnvironmentError):
-    """Raised when a command could not be executed"""
-
-class ReadError(EnvironmentError):
-    """Raised when an archive cannot be read"""
-
-class RegistryError(Exception):
-    """Raised when a registry operation with the archiving
-    and unpacking registries fails"""
-
-
-try:
-    WindowsError
-except NameError:
-    WindowsError = None
-
-def copyfileobj(fsrc, fdst, length=16*1024):
-    """copy data from file-like object fsrc to file-like object fdst"""
-    while 1:
-        buf = fsrc.read(length)
-        if not buf:
-            break
-        fdst.write(buf)
-
-def _samefile(src, dst):
-    # Macintosh, Unix.
-    if hasattr(os.path, 'samefile'):
-        try:
-            return os.path.samefile(src, dst)
-        except OSError:
-            return False
-
-    # All other platforms: check for same pathname.
-    return (os.path.normcase(os.path.abspath(src)) ==
-            os.path.normcase(os.path.abspath(dst)))
-
-def copyfile(src, dst):
-    """Copy data from src to dst"""
-    if _samefile(src, dst):
-        raise Error("`%s` and `%s` are the same file" % (src, dst))
-
-    for fn in [src, dst]:
-        try:
-            st = os.stat(fn)
-        except OSError:
-            # File most likely does not exist
-            pass
-        else:
-            # XXX What about other special files? (sockets, devices...)
-            if stat.S_ISFIFO(st.st_mode):
-                raise SpecialFileError("`%s` is a named pipe" % fn)
-
-    with open(src, 'rb') as fsrc:
-        with open(dst, 'wb') as fdst:
-            copyfileobj(fsrc, fdst)
-
-def copymode(src, dst):
-    """Copy mode bits from src to dst"""
-    if hasattr(os, 'chmod'):
-        st = os.stat(src)
-        mode = stat.S_IMODE(st.st_mode)
-        os.chmod(dst, mode)
-
-def copystat(src, dst):
-    """Copy all stat info (mode bits, atime, mtime, flags) from src to dst"""
-    st = os.stat(src)
-    mode = stat.S_IMODE(st.st_mode)
-    if hasattr(os, 'utime'):
-        os.utime(dst, (st.st_atime, st.st_mtime))
-    if hasattr(os, 'chmod'):
-        os.chmod(dst, mode)
-    if hasattr(os, 'chflags') and hasattr(st, 'st_flags'):
-        try:
-            os.chflags(dst, st.st_flags)
-        except OSError as why:
-            if (not hasattr(errno, 'EOPNOTSUPP') or
-                why.errno != errno.EOPNOTSUPP):
-                raise
-
-def copy(src, dst):
-    """Copy data and mode bits ("cp src dst").
-
-    The destination may be a directory.
-
-    """
-    if os.path.isdir(dst):
-        dst = os.path.join(dst, os.path.basename(src))
-    copyfile(src, dst)
-    copymode(src, dst)
-
-def copy2(src, dst):
-    """Copy data and all stat info ("cp -p src dst").
-
-    The destination may be a directory.
-
-    """
-    if os.path.isdir(dst):
-        dst = os.path.join(dst, os.path.basename(src))
-    copyfile(src, dst)
-    copystat(src, dst)
-
-def ignore_patterns(*patterns):
-    """Function that can be used as copytree() ignore parameter.
-
-    Patterns is a sequence of glob-style patterns
-    that are used to exclude files"""
-    def _ignore_patterns(path, names):
-        ignored_names = []
-        for pattern in patterns:
-            ignored_names.extend(fnmatch.filter(names, pattern))
-        return set(ignored_names)
-    return _ignore_patterns
-
-def copytree(src, dst, symlinks=False, ignore=None, copy_function=copy2,
-             ignore_dangling_symlinks=False):
-    """Recursively copy a directory tree.
-
-    The destination directory must not already exist.
-    If exception(s) occur, an Error is raised with a list of reasons.
-
-    If the optional symlinks flag is true, symbolic links in the
-    source tree result in symbolic links in the destination tree; if
-    it is false, the contents of the files pointed to by symbolic
-    links are copied. If the file pointed by the symlink doesn't
-    exist, an exception will be added in the list of errors raised in
-    an Error exception at the end of the copy process.
-
-    You can set the optional ignore_dangling_symlinks flag to true if you
-    want to silence this exception. Notice that this has no effect on
-    platforms that don't support os.symlink.
-
-    The optional ignore argument is a callable. If given, it
-    is called with the `src` parameter, which is the directory
-    being visited by copytree(), and `names` which is the list of
-    `src` contents, as returned by os.listdir():
-
-        callable(src, names) -> ignored_names
-
-    Since copytree() is called recursively, the callable will be
-    called once for each directory that is copied. It returns a
-    list of names relative to the `src` directory that should
-    not be copied.
-
-    The optional copy_function argument is a callable that will be used
-    to copy each file. It will be called with the source path and the
-    destination path as arguments. By default, copy2() is used, but any
-    function that supports the same signature (like copy()) can be used.
-
-    """
-    names = os.listdir(src)
-    if ignore is not None:
-        ignored_names = ignore(src, names)
-    else:
-        ignored_names = set()
-
-    os.makedirs(dst)
-    errors = []
-    for name in names:
-        if name in ignored_names:
-            continue
-        srcname = os.path.join(src, name)
-        dstname = os.path.join(dst, name)
-        try:
-            if os.path.islink(srcname):
-                linkto = os.readlink(srcname)
-                if symlinks:
-                    os.symlink(linkto, dstname)
-                else:
-                    # ignore dangling symlink if the flag is on
-                    if not os.path.exists(linkto) and ignore_dangling_symlinks:
-                        continue
-                    # otherwise let the copy occurs. copy2 will raise an error
-                    copy_function(srcname, dstname)
-            elif os.path.isdir(srcname):
-                copytree(srcname, dstname, symlinks, ignore, copy_function)
-            else:
-                # Will raise a SpecialFileError for unsupported file types
-                copy_function(srcname, dstname)
-        # catch the Error from the recursive copytree so that we can
-        # continue with other files
-        except Error as err:
-            errors.extend(err.args[0])
-        except EnvironmentError as why:
-            errors.append((srcname, dstname, str(why)))
-    try:
-        copystat(src, dst)
-    except OSError as why:
-        if WindowsError is not None and isinstance(why, WindowsError):
-            # Copying file access times may fail on Windows
-            pass
-        else:
-            errors.extend((src, dst, str(why)))
-    if errors:
-        raise Error(errors)
-
-def rmtree(path, ignore_errors=False, onerror=None):
-    """Recursively delete a directory tree.
-
-    If ignore_errors is set, errors are ignored; otherwise, if onerror
-    is set, it is called to handle the error with arguments (func,
-    path, exc_info) where func is os.listdir, os.remove, or os.rmdir;
-    path is the argument to that function that caused it to fail; and
-    exc_info is a tuple returned by sys.exc_info().  If ignore_errors
-    is false and onerror is None, an exception is raised.
-
-    """
-    if ignore_errors:
-        def onerror(*args):
-            pass
-    elif onerror is None:
-        def onerror(*args):
-            raise
-    try:
-        if os.path.islink(path):
-            # symlinks to directories are forbidden, see bug #1669
-            raise OSError("Cannot call rmtree on a symbolic link")
-    except OSError:
-        onerror(os.path.islink, path, sys.exc_info())
-        # can't continue even if onerror hook returns
-        return
-    names = []
-    try:
-        names = os.listdir(path)
-    except os.error:
-        onerror(os.listdir, path, sys.exc_info())
-    for name in names:
-        fullname = os.path.join(path, name)
-        try:
-            mode = os.lstat(fullname).st_mode
-        except os.error:
-            mode = 0
-        if stat.S_ISDIR(mode):
-            rmtree(fullname, ignore_errors, onerror)
-        else:
-            try:
-                os.remove(fullname)
-            except os.error:
-                onerror(os.remove, fullname, sys.exc_info())
-    try:
-        os.rmdir(path)
-    except os.error:
-        onerror(os.rmdir, path, sys.exc_info())
-
-
-def _basename(path):
-    # A basename() variant which first strips the trailing slash, if present.
-    # Thus we always get the last component of the path, even for directories.
-    return os.path.basename(path.rstrip(os.path.sep))
-
-def move(src, dst):
-    """Recursively move a file or directory to another location. This is
-    similar to the Unix "mv" command.
-
-    If the destination is a directory or a symlink to a directory, the source
-    is moved inside the directory. The destination path must not already
-    exist.
-
-    If the destination already exists but is not a directory, it may be
-    overwritten depending on os.rename() semantics.
-
-    If the destination is on our current filesystem, then rename() is used.
-    Otherwise, src is copied to the destination and then removed.
-    A lot more could be done here...  A look at a mv.c shows a lot of
-    the issues this implementation glosses over.
-
-    """
-    real_dst = dst
-    if os.path.isdir(dst):
-        if _samefile(src, dst):
-            # We might be on a case insensitive filesystem,
-            # perform the rename anyway.
-            os.rename(src, dst)
-            return
-
-        real_dst = os.path.join(dst, _basename(src))
-        if os.path.exists(real_dst):
-            raise Error("Destination path '%s' already exists" % real_dst)
-    try:
-        os.rename(src, real_dst)
-    except OSError:
-        if os.path.isdir(src):
-            if _destinsrc(src, dst):
-                raise Error("Cannot move a directory '%s' into itself '%s'." % (src, dst))
-            copytree(src, real_dst, symlinks=True)
-            rmtree(src)
-        else:
-            copy2(src, real_dst)
-            os.unlink(src)
-
-def _destinsrc(src, dst):
-    src = abspath(src)
-    dst = abspath(dst)
-    if not src.endswith(os.path.sep):
-        src += os.path.sep
-    if not dst.endswith(os.path.sep):
-        dst += os.path.sep
-    return dst.startswith(src)
-
-def _get_gid(name):
-    """Returns a gid, given a group name."""
-    if getgrnam is None or name is None:
-        return None
-    try:
-        result = getgrnam(name)
-    except KeyError:
-        result = None
-    if result is not None:
-        return result[2]
-    return None
-
-def _get_uid(name):
-    """Returns an uid, given a user name."""
-    if getpwnam is None or name is None:
-        return None
-    try:
-        result = getpwnam(name)
-    except KeyError:
-        result = None
-    if result is not None:
-        return result[2]
-    return None
-
-def _make_tarball(base_name, base_dir, compress="gzip", verbose=0, dry_run=0,
-                  owner=None, group=None, logger=None):
-    """Create a (possibly compressed) tar file from all the files under
-    'base_dir'.
-
-    'compress' must be "gzip" (the default), "bzip2", or None.
-
-    'owner' and 'group' can be used to define an owner and a group for the
-    archive that is being built. If not provided, the current owner and group
-    will be used.
-
-    The output tar file will be named 'base_name' +  ".tar", possibly plus
-    the appropriate compression extension (".gz", or ".bz2").
-
-    Returns the output filename.
-    """
-    tar_compression = {'gzip': 'gz', None: ''}
-    compress_ext = {'gzip': '.gz'}
-
-    if _BZ2_SUPPORTED:
-        tar_compression['bzip2'] = 'bz2'
-        compress_ext['bzip2'] = '.bz2'
-
-    # flags for compression program, each element of list will be an argument
-    if compress is not None and compress not in compress_ext:
-        raise ValueError("bad value for 'compress', or compression format not "
-                         "supported : {0}".format(compress))
-
-    archive_name = base_name + '.tar' + compress_ext.get(compress, '')
-    archive_dir = os.path.dirname(archive_name)
-
-    if not os.path.exists(archive_dir):
-        if logger is not None:
-            logger.info("creating %s", archive_dir)
-        if not dry_run:
-            os.makedirs(archive_dir)
-
-    # creating the tarball
-    if logger is not None:
-        logger.info('Creating tar archive')
-
-    uid = _get_uid(owner)
-    gid = _get_gid(group)
-
-    def _set_uid_gid(tarinfo):
-        if gid is not None:
-            tarinfo.gid = gid
-            tarinfo.gname = group
-        if uid is not None:
-            tarinfo.uid = uid
-            tarinfo.uname = owner
-        return tarinfo
-
-    if not dry_run:
-        tar = tarfile.open(archive_name, 'w|%s' % tar_compression[compress])
-        try:
-            tar.add(base_dir, filter=_set_uid_gid)
-        finally:
-            tar.close()
-
-    return archive_name
-
-def _call_external_zip(base_dir, zip_filename, verbose=False, dry_run=False):
-    # XXX see if we want to keep an external call here
-    if verbose:
-        zipoptions = "-r"
-    else:
-        zipoptions = "-rq"
-    from distutils.errors import DistutilsExecError
-    from distutils.spawn import spawn
-    try:
-        spawn(["zip", zipoptions, zip_filename, base_dir], dry_run=dry_run)
-    except DistutilsExecError:
-        # XXX really should distinguish between "couldn't find
-        # external 'zip' command" and "zip failed".
-        raise ExecError("unable to create zip file '%s': "
-            "could neither import the 'zipfile' module nor "
-            "find a standalone zip utility") % zip_filename
-
-def _make_zipfile(base_name, base_dir, verbose=0, dry_run=0, logger=None):
-    """Create a zip file from all the files under 'base_dir'.
-
-    The output zip file will be named 'base_name' + ".zip".  Uses either the
-    "zipfile" Python module (if available) or the InfoZIP "zip" utility
-    (if installed and found on the default search path).  If neither tool is
-    available, raises ExecError.  Returns the name of the output zip
-    file.
-    """
-    zip_filename = base_name + ".zip"
-    archive_dir = os.path.dirname(base_name)
-
-    if not os.path.exists(archive_dir):
-        if logger is not None:
-            logger.info("creating %s", archive_dir)
-        if not dry_run:
-            os.makedirs(archive_dir)
-
-    # If zipfile module is not available, try spawning an external 'zip'
-    # command.
-    try:
-        import zipfile
-    except ImportError:
-        zipfile = None
-
-    if zipfile is None:
-        _call_external_zip(base_dir, zip_filename, verbose, dry_run)
-    else:
-        if logger is not None:
-            logger.info("creating '%s' and adding '%s' to it",
-                        zip_filename, base_dir)
-
-        if not dry_run:
-            zip = zipfile.ZipFile(zip_filename, "w",
-                                  compression=zipfile.ZIP_DEFLATED)
-
-            for dirpath, dirnames, filenames in os.walk(base_dir):
-                for name in filenames:
-                    path = os.path.normpath(os.path.join(dirpath, name))
-                    if os.path.isfile(path):
-                        zip.write(path, path)
-                        if logger is not None:
-                            logger.info("adding '%s'", path)
-            zip.close()
-
-    return zip_filename
-
-_ARCHIVE_FORMATS = {
-    'gztar': (_make_tarball, [('compress', 'gzip')], "gzip'ed tar-file"),
-    'bztar': (_make_tarball, [('compress', 'bzip2')], "bzip2'ed tar-file"),
-    'tar':   (_make_tarball, [('compress', None)], "uncompressed tar file"),
-    'zip':   (_make_zipfile, [], "ZIP file"),
-    }
-
-if _BZ2_SUPPORTED:
-    _ARCHIVE_FORMATS['bztar'] = (_make_tarball, [('compress', 'bzip2')],
-                                "bzip2'ed tar-file")
-
-def get_archive_formats():
-    """Returns a list of supported formats for archiving and unarchiving.
-
-    Each element of the returned sequence is a tuple (name, description)
-    """
-    formats = [(name, registry[2]) for name, registry in
-               _ARCHIVE_FORMATS.items()]
-    formats.sort()
-    return formats
-
-def register_archive_format(name, function, extra_args=None, description=''):
-    """Registers an archive format.
-
-    name is the name of the format. function is the callable that will be
-    used to create archives. If provided, extra_args is a sequence of
-    (name, value) tuples that will be passed as arguments to the callable.
-    description can be provided to describe the format, and will be returned
-    by the get_archive_formats() function.
-    """
-    if extra_args is None:
-        extra_args = []
-    if not isinstance(function, Callable):
-        raise TypeError('The %s object is not callable' % function)
-    if not isinstance(extra_args, (tuple, list)):
-        raise TypeError('extra_args needs to be a sequence')
-    for element in extra_args:
-        if not isinstance(element, (tuple, list)) or len(element) !=2:
-            raise TypeError('extra_args elements are : (arg_name, value)')
-
-    _ARCHIVE_FORMATS[name] = (function, extra_args, description)
-
-def unregister_archive_format(name):
-    del _ARCHIVE_FORMATS[name]
-
-def make_archive(base_name, format, root_dir=None, base_dir=None, verbose=0,
-                 dry_run=0, owner=None, group=None, logger=None):
-    """Create an archive file (eg. zip or tar).
-
-    'base_name' is the name of the file to create, minus any format-specific
-    extension; 'format' is the archive format: one of "zip", "tar", "bztar"
-    or "gztar".
-
-    'root_dir' is a directory that will be the root directory of the
-    archive; ie. we typically chdir into 'root_dir' before creating the
-    archive.  'base_dir' is the directory where we start archiving from;
-    ie. 'base_dir' will be the common prefix of all files and
-    directories in the archive.  'root_dir' and 'base_dir' both default
-    to the current directory.  Returns the name of the archive file.
-
-    'owner' and 'group' are used when creating a tar archive. By default,
-    uses the current owner and group.
-    """
-    save_cwd = os.getcwd()
-    if root_dir is not None:
-        if logger is not None:
-            logger.debug("changing into '%s'", root_dir)
-        base_name = os.path.abspath(base_name)
-        if not dry_run:
-            os.chdir(root_dir)
-
-    if base_dir is None:
-        base_dir = os.curdir
-
-    kwargs = {'dry_run': dry_run, 'logger': logger}
-
-    try:
-        format_info = _ARCHIVE_FORMATS[format]
-    except KeyError:
-        raise ValueError("unknown archive format '%s'" % format)
-
-    func = format_info[0]
-    for arg, val in format_info[1]:
-        kwargs[arg] = val
-
-    if format != 'zip':
-        kwargs['owner'] = owner
-        kwargs['group'] = group
-
-    try:
-        filename = func(base_name, base_dir, **kwargs)
-    finally:
-        if root_dir is not None:
-            if logger is not None:
-                logger.debug("changing back to '%s'", save_cwd)
-            os.chdir(save_cwd)
-
-    return filename
-
-
-def get_unpack_formats():
-    """Returns a list of supported formats for unpacking.
-
-    Each element of the returned sequence is a tuple
-    (name, extensions, description)
-    """
-    formats = [(name, info[0], info[3]) for name, info in
-               _UNPACK_FORMATS.items()]
-    formats.sort()
-    return formats
-
-def _check_unpack_options(extensions, function, extra_args):
-    """Checks what gets registered as an unpacker."""
-    # first make sure no other unpacker is registered for this extension
-    existing_extensions = {}
-    for name, info in _UNPACK_FORMATS.items():
-        for ext in info[0]:
-            existing_extensions[ext] = name
-
-    for extension in extensions:
-        if extension in existing_extensions:
-            msg = '%s is already registered for "%s"'
-            raise RegistryError(msg % (extension,
-                                       existing_extensions[extension]))
-
-    if not isinstance(function, Callable):
-        raise TypeError('The registered function must be a callable')
-
-
-def register_unpack_format(name, extensions, function, extra_args=None,
-                           description=''):
-    """Registers an unpack format.
-
-    `name` is the name of the format. `extensions` is a list of extensions
-    corresponding to the format.
-
-    `function` is the callable that will be
-    used to unpack archives. The callable will receive archives to unpack.
-    If it's unable to handle an archive, it needs to raise a ReadError
-    exception.
-
-    If provided, `extra_args` is a sequence of
-    (name, value) tuples that will be passed as arguments to the callable.
-    description can be provided to describe the format, and will be returned
-    by the get_unpack_formats() function.
-    """
-    if extra_args is None:
-        extra_args = []
-    _check_unpack_options(extensions, function, extra_args)
-    _UNPACK_FORMATS[name] = extensions, function, extra_args, description
-
-def unregister_unpack_format(name):
-    """Removes the pack format from the registry."""
-    del _UNPACK_FORMATS[name]
-
-def _ensure_directory(path):
-    """Ensure that the parent directory of `path` exists"""
-    dirname = os.path.dirname(path)
-    if not os.path.isdir(dirname):
-        os.makedirs(dirname)
-
-def _unpack_zipfile(filename, extract_dir):
-    """Unpack zip `filename` to `extract_dir`
-    """
-    try:
-        import zipfile
-    except ImportError:
-        raise ReadError('zlib not supported, cannot unpack this archive.')
-
-    if not zipfile.is_zipfile(filename):
-        raise ReadError("%s is not a zip file" % filename)
-
-    zip = zipfile.ZipFile(filename)
-    try:
-        for info in zip.infolist():
-            name = info.filename
-
-            # don't extract absolute paths or ones with .. in them
-            if name.startswith('/') or '..' in name:
-                continue
-
-            target = os.path.join(extract_dir, *name.split('/'))
-            if not target:
-                continue
-
-            _ensure_directory(target)
-            if not name.endswith('/'):
-                # file
-                data = zip.read(info.filename)
-                f = open(target, 'wb')
-                try:
-                    f.write(data)
-                finally:
-                    f.close()
-                    del data
-    finally:
-        zip.close()
-
-def _unpack_tarfile(filename, extract_dir):
-    """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir`
-    """
-    try:
-        tarobj = tarfile.open(filename)
-    except tarfile.TarError:
-        raise ReadError(
-            "%s is not a compressed or uncompressed tar file" % filename)
-    try:
-        tarobj.extractall(extract_dir)
-    finally:
-        tarobj.close()
-
-_UNPACK_FORMATS = {
-    'gztar': (['.tar.gz', '.tgz'], _unpack_tarfile, [], "gzip'ed tar-file"),
-    'tar':   (['.tar'], _unpack_tarfile, [], "uncompressed tar file"),
-    'zip':   (['.zip'], _unpack_zipfile, [], "ZIP file")
-    }
-
-if _BZ2_SUPPORTED:
-    _UNPACK_FORMATS['bztar'] = (['.bz2'], _unpack_tarfile, [],
-                                "bzip2'ed tar-file")
-
-def _find_unpack_format(filename):
-    for name, info in _UNPACK_FORMATS.items():
-        for extension in info[0]:
-            if filename.endswith(extension):
-                return name
-    return None
-
-def unpack_archive(filename, extract_dir=None, format=None):
-    """Unpack an archive.
-
-    `filename` is the name of the archive.
-
-    `extract_dir` is the name of the target directory, where the archive
-    is unpacked. If not provided, the current working directory is used.
-
-    `format` is the archive format: one of "zip", "tar", or "gztar". Or any
-    other registered format. If not provided, unpack_archive will use the
-    filename extension and see if an unpacker was registered for that
-    extension.
-
-    In case none is found, a ValueError is raised.
-    """
-    if extract_dir is None:
-        extract_dir = os.getcwd()
-
-    if format is not None:
-        try:
-            format_info = _UNPACK_FORMATS[format]
-        except KeyError:
-            raise ValueError("Unknown unpack format '{0}'".format(format))
-
-        func = format_info[1]
-        func(filename, extract_dir, **dict(format_info[2]))
-    else:
-        # we need to look at the registered unpackers supported extensions
-        format = _find_unpack_format(filename)
-        if format is None:
-            raise ReadError("Unknown archive format '{0}'".format(filename))
-
-        func = _UNPACK_FORMATS[format][1]
-        kwargs = dict(_UNPACK_FORMATS[format][2])
-        func(filename, extract_dir, **kwargs)
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg b/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg
deleted file mode 100644
index 1746bd01..00000000
--- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.cfg
+++ /dev/null
@@ -1,84 +0,0 @@
-[posix_prefix]
-# Configuration directories.  Some of these come straight out of the
-# configure script.  They are for implementing the other variables, not to
-# be used directly in [resource_locations].
-confdir = /etc
-datadir = /usr/share
-libdir = /usr/lib
-statedir = /var
-# User resource directory
-local = ~/.local/{distribution.name}
-
-stdlib = {base}/lib/python{py_version_short}
-platstdlib = {platbase}/lib/python{py_version_short}
-purelib = {base}/lib/python{py_version_short}/site-packages
-platlib = {platbase}/lib/python{py_version_short}/site-packages
-include = {base}/include/python{py_version_short}{abiflags}
-platinclude = {platbase}/include/python{py_version_short}{abiflags}
-data = {base}
-
-[posix_home]
-stdlib = {base}/lib/python
-platstdlib = {base}/lib/python
-purelib = {base}/lib/python
-platlib = {base}/lib/python
-include = {base}/include/python
-platinclude = {base}/include/python
-scripts = {base}/bin
-data = {base}
-
-[nt]
-stdlib = {base}/Lib
-platstdlib = {base}/Lib
-purelib = {base}/Lib/site-packages
-platlib = {base}/Lib/site-packages
-include = {base}/Include
-platinclude = {base}/Include
-scripts = {base}/Scripts
-data = {base}
-
-[os2]
-stdlib = {base}/Lib
-platstdlib = {base}/Lib
-purelib = {base}/Lib/site-packages
-platlib = {base}/Lib/site-packages
-include = {base}/Include
-platinclude = {base}/Include
-scripts = {base}/Scripts
-data = {base}
-
-[os2_home]
-stdlib = {userbase}/lib/python{py_version_short}
-platstdlib = {userbase}/lib/python{py_version_short}
-purelib = {userbase}/lib/python{py_version_short}/site-packages
-platlib = {userbase}/lib/python{py_version_short}/site-packages
-include = {userbase}/include/python{py_version_short}
-scripts = {userbase}/bin
-data = {userbase}
-
-[nt_user]
-stdlib = {userbase}/Python{py_version_nodot}
-platstdlib = {userbase}/Python{py_version_nodot}
-purelib = {userbase}/Python{py_version_nodot}/site-packages
-platlib = {userbase}/Python{py_version_nodot}/site-packages
-include = {userbase}/Python{py_version_nodot}/Include
-scripts = {userbase}/Scripts
-data = {userbase}
-
-[posix_user]
-stdlib = {userbase}/lib/python{py_version_short}
-platstdlib = {userbase}/lib/python{py_version_short}
-purelib = {userbase}/lib/python{py_version_short}/site-packages
-platlib = {userbase}/lib/python{py_version_short}/site-packages
-include = {userbase}/include/python{py_version_short}
-scripts = {userbase}/bin
-data = {userbase}
-
-[osx_framework_user]
-stdlib = {userbase}/lib/python
-platstdlib = {userbase}/lib/python
-purelib = {userbase}/lib/python/site-packages
-platlib = {userbase}/lib/python/site-packages
-include = {userbase}/include
-scripts = {userbase}/bin
-data = {userbase}
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py
deleted file mode 100644
index b470a373..00000000
--- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/sysconfig.py
+++ /dev/null
@@ -1,786 +0,0 @@
-# -*- coding: utf-8 -*-
-#
-# Copyright (C) 2012 The Python Software Foundation.
-# See LICENSE.txt and CONTRIBUTORS.txt.
-#
-"""Access to Python's configuration information."""
-
-import codecs
-import os
-import re
-import sys
-from os.path import pardir, realpath
-try:
-    import configparser
-except ImportError:
-    import ConfigParser as configparser
-
-
-__all__ = [
-    'get_config_h_filename',
-    'get_config_var',
-    'get_config_vars',
-    'get_makefile_filename',
-    'get_path',
-    'get_path_names',
-    'get_paths',
-    'get_platform',
-    'get_python_version',
-    'get_scheme_names',
-    'parse_config_h',
-]
-
-
-def _safe_realpath(path):
-    try:
-        return realpath(path)
-    except OSError:
-        return path
-
-
-if sys.executable:
-    _PROJECT_BASE = os.path.dirname(_safe_realpath(sys.executable))
-else:
-    # sys.executable can be empty if argv[0] has been changed and Python is
-    # unable to retrieve the real program name
-    _PROJECT_BASE = _safe_realpath(os.getcwd())
-
-if os.name == "nt" and "pcbuild" in _PROJECT_BASE[-8:].lower():
-    _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir))
-# PC/VS7.1
-if os.name == "nt" and "\\pc\\v" in _PROJECT_BASE[-10:].lower():
-    _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir))
-# PC/AMD64
-if os.name == "nt" and "\\pcbuild\\amd64" in _PROJECT_BASE[-14:].lower():
-    _PROJECT_BASE = _safe_realpath(os.path.join(_PROJECT_BASE, pardir, pardir))
-
-
-def is_python_build():
-    for fn in ("Setup.dist", "Setup.local"):
-        if os.path.isfile(os.path.join(_PROJECT_BASE, "Modules", fn)):
-            return True
-    return False
-
-_PYTHON_BUILD = is_python_build()
-
-_cfg_read = False
-
-def _ensure_cfg_read():
-    global _cfg_read
-    if not _cfg_read:
-        from ..resources import finder
-        backport_package = __name__.rsplit('.', 1)[0]
-        _finder = finder(backport_package)
-        _cfgfile = _finder.find('sysconfig.cfg')
-        assert _cfgfile, 'sysconfig.cfg exists'
-        with _cfgfile.as_stream() as s:
-            _SCHEMES.readfp(s)
-        if _PYTHON_BUILD:
-            for scheme in ('posix_prefix', 'posix_home'):
-                _SCHEMES.set(scheme, 'include', '{srcdir}/Include')
-                _SCHEMES.set(scheme, 'platinclude', '{projectbase}/.')
-
-        _cfg_read = True
-
-
-_SCHEMES = configparser.RawConfigParser()
-_VAR_REPL = re.compile(r'\{([^{]*?)\}')
-
-def _expand_globals(config):
-    _ensure_cfg_read()
-    if config.has_section('globals'):
-        globals = config.items('globals')
-    else:
-        globals = tuple()
-
-    sections = config.sections()
-    for section in sections:
-        if section == 'globals':
-            continue
-        for option, value in globals:
-            if config.has_option(section, option):
-                continue
-            config.set(section, option, value)
-    config.remove_section('globals')
-
-    # now expanding local variables defined in the cfg file
-    #
-    for section in config.sections():
-        variables = dict(config.items(section))
-
-        def _replacer(matchobj):
-            name = matchobj.group(1)
-            if name in variables:
-                return variables[name]
-            return matchobj.group(0)
-
-        for option, value in config.items(section):
-            config.set(section, option, _VAR_REPL.sub(_replacer, value))
-
-#_expand_globals(_SCHEMES)
-
-_PY_VERSION = '%s.%s.%s' % sys.version_info[:3]
-_PY_VERSION_SHORT = '%s.%s' % sys.version_info[:2]
-_PY_VERSION_SHORT_NO_DOT = '%s%s' % sys.version_info[:2]
-_PREFIX = os.path.normpath(sys.prefix)
-_EXEC_PREFIX = os.path.normpath(sys.exec_prefix)
-_CONFIG_VARS = None
-_USER_BASE = None
-
-
-def _subst_vars(path, local_vars):
-    """In the string `path`, replace tokens like {some.thing} with the
-    corresponding value from the map `local_vars`.
-
-    If there is no corresponding value, leave the token unchanged.
-    """
-    def _replacer(matchobj):
-        name = matchobj.group(1)
-        if name in local_vars:
-            return local_vars[name]
-        elif name in os.environ:
-            return os.environ[name]
-        return matchobj.group(0)
-    return _VAR_REPL.sub(_replacer, path)
-
-
-def _extend_dict(target_dict, other_dict):
-    target_keys = target_dict.keys()
-    for key, value in other_dict.items():
-        if key in target_keys:
-            continue
-        target_dict[key] = value
-
-
-def _expand_vars(scheme, vars):
-    res = {}
-    if vars is None:
-        vars = {}
-    _extend_dict(vars, get_config_vars())
-
-    for key, value in _SCHEMES.items(scheme):
-        if os.name in ('posix', 'nt'):
-            value = os.path.expanduser(value)
-        res[key] = os.path.normpath(_subst_vars(value, vars))
-    return res
-
-
-def format_value(value, vars):
-    def _replacer(matchobj):
-        name = matchobj.group(1)
-        if name in vars:
-            return vars[name]
-        return matchobj.group(0)
-    return _VAR_REPL.sub(_replacer, value)
-
-
-def _get_default_scheme():
-    if os.name == 'posix':
-        # the default scheme for posix is posix_prefix
-        return 'posix_prefix'
-    return os.name
-
-
-def _getuserbase():
-    env_base = os.environ.get("PYTHONUSERBASE", None)
-
-    def joinuser(*args):
-        return os.path.expanduser(os.path.join(*args))
-
-    # what about 'os2emx', 'riscos' ?
-    if os.name == "nt":
-        base = os.environ.get("APPDATA") or "~"
-        if env_base:
-            return env_base
-        else:
-            return joinuser(base, "Python")
-
-    if sys.platform == "darwin":
-        framework = get_config_var("PYTHONFRAMEWORK")
-        if framework:
-            if env_base:
-                return env_base
-            else:
-                return joinuser("~", "Library", framework, "%d.%d" %
-                                sys.version_info[:2])
-
-    if env_base:
-        return env_base
-    else:
-        return joinuser("~", ".local")
-
-
-def _parse_makefile(filename, vars=None):
-    """Parse a Makefile-style file.
-
-    A dictionary containing name/value pairs is returned.  If an
-    optional dictionary is passed in as the second argument, it is
-    used instead of a new dictionary.
-    """
-    # Regexes needed for parsing Makefile (and similar syntaxes,
-    # like old-style Setup files).
-    _variable_rx = re.compile(r"([a-zA-Z][a-zA-Z0-9_]+)\s*=\s*(.*)")
-    _findvar1_rx = re.compile(r"\$\(([A-Za-z][A-Za-z0-9_]*)\)")
-    _findvar2_rx = re.compile(r"\${([A-Za-z][A-Za-z0-9_]*)}")
-
-    if vars is None:
-        vars = {}
-    done = {}
-    notdone = {}
-
-    with codecs.open(filename, encoding='utf-8', errors="surrogateescape") as f:
-        lines = f.readlines()
-
-    for line in lines:
-        if line.startswith('#') or line.strip() == '':
-            continue
-        m = _variable_rx.match(line)
-        if m:
-            n, v = m.group(1, 2)
-            v = v.strip()
-            # `$$' is a literal `$' in make
-            tmpv = v.replace('$$', '')
-
-            if "$" in tmpv:
-                notdone[n] = v
-            else:
-                try:
-                    v = int(v)
-                except ValueError:
-                    # insert literal `$'
-                    done[n] = v.replace('$$', '$')
-                else:
-                    done[n] = v
-
-    # do variable interpolation here
-    variables = list(notdone.keys())
-
-    # Variables with a 'PY_' prefix in the makefile. These need to
-    # be made available without that prefix through sysconfig.
-    # Special care is needed to ensure that variable expansion works, even
-    # if the expansion uses the name without a prefix.
-    renamed_variables = ('CFLAGS', 'LDFLAGS', 'CPPFLAGS')
-
-    while len(variables) > 0:
-        for name in tuple(variables):
-            value = notdone[name]
-            m = _findvar1_rx.search(value) or _findvar2_rx.search(value)
-            if m is not None:
-                n = m.group(1)
-                found = True
-                if n in done:
-                    item = str(done[n])
-                elif n in notdone:
-                    # get it on a subsequent round
-                    found = False
-                elif n in os.environ:
-                    # do it like make: fall back to environment
-                    item = os.environ[n]
-
-                elif n in renamed_variables:
-                    if (name.startswith('PY_') and
-                        name[3:] in renamed_variables):
-                        item = ""
-
-                    elif 'PY_' + n in notdone:
-                        found = False
-
-                    else:
-                        item = str(done['PY_' + n])
-
-                else:
-                    done[n] = item = ""
-
-                if found:
-                    after = value[m.end():]
-                    value = value[:m.start()] + item + after
-                    if "$" in after:
-                        notdone[name] = value
-                    else:
-                        try:
-                            value = int(value)
-                        except ValueError:
-                            done[name] = value.strip()
-                        else:
-                            done[name] = value
-                        variables.remove(name)
-
-                        if (name.startswith('PY_') and
-                            name[3:] in renamed_variables):
-
-                            name = name[3:]
-                            if name not in done:
-                                done[name] = value
-
-            else:
-                # bogus variable reference (e.g. "prefix=$/opt/python");
-                # just drop it since we can't deal
-                done[name] = value
-                variables.remove(name)
-
-    # strip spurious spaces
-    for k, v in done.items():
-        if isinstance(v, str):
-            done[k] = v.strip()
-
-    # save the results in the global dictionary
-    vars.update(done)
-    return vars
-
-
-def get_makefile_filename():
-    """Return the path of the Makefile."""
-    if _PYTHON_BUILD:
-        return os.path.join(_PROJECT_BASE, "Makefile")
-    if hasattr(sys, 'abiflags'):
-        config_dir_name = 'config-%s%s' % (_PY_VERSION_SHORT, sys.abiflags)
-    else:
-        config_dir_name = 'config'
-    return os.path.join(get_path('stdlib'), config_dir_name, 'Makefile')
-
-
-def _init_posix(vars):
-    """Initialize the module as appropriate for POSIX systems."""
-    # load the installed Makefile:
-    makefile = get_makefile_filename()
-    try:
-        _parse_makefile(makefile, vars)
-    except IOError as e:
-        msg = "invalid Python installation: unable to open %s" % makefile
-        if hasattr(e, "strerror"):
-            msg = msg + " (%s)" % e.strerror
-        raise IOError(msg)
-    # load the installed pyconfig.h:
-    config_h = get_config_h_filename()
-    try:
-        with open(config_h) as f:
-            parse_config_h(f, vars)
-    except IOError as e:
-        msg = "invalid Python installation: unable to open %s" % config_h
-        if hasattr(e, "strerror"):
-            msg = msg + " (%s)" % e.strerror
-        raise IOError(msg)
-    # On AIX, there are wrong paths to the linker scripts in the Makefile
-    # -- these paths are relative to the Python source, but when installed
-    # the scripts are in another directory.
-    if _PYTHON_BUILD:
-        vars['LDSHARED'] = vars['BLDSHARED']
-
-
-def _init_non_posix(vars):
-    """Initialize the module as appropriate for NT"""
-    # set basic install directories
-    vars['LIBDEST'] = get_path('stdlib')
-    vars['BINLIBDEST'] = get_path('platstdlib')
-    vars['INCLUDEPY'] = get_path('include')
-    vars['SO'] = '.pyd'
-    vars['EXE'] = '.exe'
-    vars['VERSION'] = _PY_VERSION_SHORT_NO_DOT
-    vars['BINDIR'] = os.path.dirname(_safe_realpath(sys.executable))
-
-#
-# public APIs
-#
-
-
-def parse_config_h(fp, vars=None):
-    """Parse a config.h-style file.
-
-    A dictionary containing name/value pairs is returned.  If an
-    optional dictionary is passed in as the second argument, it is
-    used instead of a new dictionary.
-    """
-    if vars is None:
-        vars = {}
-    define_rx = re.compile("#define ([A-Z][A-Za-z0-9_]+) (.*)\n")
-    undef_rx = re.compile("/[*] #undef ([A-Z][A-Za-z0-9_]+) [*]/\n")
-
-    while True:
-        line = fp.readline()
-        if not line:
-            break
-        m = define_rx.match(line)
-        if m:
-            n, v = m.group(1, 2)
-            try:
-                v = int(v)
-            except ValueError:
-                pass
-            vars[n] = v
-        else:
-            m = undef_rx.match(line)
-            if m:
-                vars[m.group(1)] = 0
-    return vars
-
-
-def get_config_h_filename():
-    """Return the path of pyconfig.h."""
-    if _PYTHON_BUILD:
-        if os.name == "nt":
-            inc_dir = os.path.join(_PROJECT_BASE, "PC")
-        else:
-            inc_dir = _PROJECT_BASE
-    else:
-        inc_dir = get_path('platinclude')
-    return os.path.join(inc_dir, 'pyconfig.h')
-
-
-def get_scheme_names():
-    """Return a tuple containing the schemes names."""
-    return tuple(sorted(_SCHEMES.sections()))
-
-
-def get_path_names():
-    """Return a tuple containing the paths names."""
-    # xxx see if we want a static list
-    return _SCHEMES.options('posix_prefix')
-
-
-def get_paths(scheme=_get_default_scheme(), vars=None, expand=True):
-    """Return a mapping containing an install scheme.
-
-    ``scheme`` is the install scheme name. If not provided, it will
-    return the default scheme for the current platform.
-    """
-    _ensure_cfg_read()
-    if expand:
-        return _expand_vars(scheme, vars)
-    else:
-        return dict(_SCHEMES.items(scheme))
-
-
-def get_path(name, scheme=_get_default_scheme(), vars=None, expand=True):
-    """Return a path corresponding to the scheme.
-
-    ``scheme`` is the install scheme name.
-    """
-    return get_paths(scheme, vars, expand)[name]
-
-
-def get_config_vars(*args):
-    """With no arguments, return a dictionary of all configuration
-    variables relevant for the current platform.
-
-    On Unix, this means every variable defined in Python's installed Makefile;
-    On Windows and Mac OS it's a much smaller set.
-
-    With arguments, return a list of values that result from looking up
-    each argument in the configuration variable dictionary.
-    """
-    global _CONFIG_VARS
-    if _CONFIG_VARS is None:
-        _CONFIG_VARS = {}
-        # Normalized versions of prefix and exec_prefix are handy to have;
-        # in fact, these are the standard versions used most places in the
-        # distutils2 module.
-        _CONFIG_VARS['prefix'] = _PREFIX
-        _CONFIG_VARS['exec_prefix'] = _EXEC_PREFIX
-        _CONFIG_VARS['py_version'] = _PY_VERSION
-        _CONFIG_VARS['py_version_short'] = _PY_VERSION_SHORT
-        _CONFIG_VARS['py_version_nodot'] = _PY_VERSION[0] + _PY_VERSION[2]
-        _CONFIG_VARS['base'] = _PREFIX
-        _CONFIG_VARS['platbase'] = _EXEC_PREFIX
-        _CONFIG_VARS['projectbase'] = _PROJECT_BASE
-        try:
-            _CONFIG_VARS['abiflags'] = sys.abiflags
-        except AttributeError:
-            # sys.abiflags may not be defined on all platforms.
-            _CONFIG_VARS['abiflags'] = ''
-
-        if os.name in ('nt', 'os2'):
-            _init_non_posix(_CONFIG_VARS)
-        if os.name == 'posix':
-            _init_posix(_CONFIG_VARS)
-        # Setting 'userbase' is done below the call to the
-        # init function to enable using 'get_config_var' in
-        # the init-function.
-        if sys.version >= '2.6':
-            _CONFIG_VARS['userbase'] = _getuserbase()
-
-        if 'srcdir' not in _CONFIG_VARS:
-            _CONFIG_VARS['srcdir'] = _PROJECT_BASE
-        else:
-            _CONFIG_VARS['srcdir'] = _safe_realpath(_CONFIG_VARS['srcdir'])
-
-        # Convert srcdir into an absolute path if it appears necessary.
-        # Normally it is relative to the build directory.  However, during
-        # testing, for example, we might be running a non-installed python
-        # from a different directory.
-        if _PYTHON_BUILD and os.name == "posix":
-            base = _PROJECT_BASE
-            try:
-                cwd = os.getcwd()
-            except OSError:
-                cwd = None
-            if (not os.path.isabs(_CONFIG_VARS['srcdir']) and
-                base != cwd):
-                # srcdir is relative and we are not in the same directory
-                # as the executable. Assume executable is in the build
-                # directory and make srcdir absolute.
-                srcdir = os.path.join(base, _CONFIG_VARS['srcdir'])
-                _CONFIG_VARS['srcdir'] = os.path.normpath(srcdir)
-
-        if sys.platform == 'darwin':
-            kernel_version = os.uname()[2]  # Kernel version (8.4.3)
-            major_version = int(kernel_version.split('.')[0])
-
-            if major_version < 8:
-                # On Mac OS X before 10.4, check if -arch and -isysroot
-                # are in CFLAGS or LDFLAGS and remove them if they are.
-                # This is needed when building extensions on a 10.3 system
-                # using a universal build of python.
-                for key in ('LDFLAGS', 'BASECFLAGS',
-                        # a number of derived variables. These need to be
-                        # patched up as well.
-                        'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'):
-                    flags = _CONFIG_VARS[key]
-                    flags = re.sub(r'-arch\s+\w+\s', ' ', flags)
-                    flags = re.sub('-isysroot [^ \t]*', ' ', flags)
-                    _CONFIG_VARS[key] = flags
-            else:
-                # Allow the user to override the architecture flags using
-                # an environment variable.
-                # NOTE: This name was introduced by Apple in OSX 10.5 and
-                # is used by several scripting languages distributed with
-                # that OS release.
-                if 'ARCHFLAGS' in os.environ:
-                    arch = os.environ['ARCHFLAGS']
-                    for key in ('LDFLAGS', 'BASECFLAGS',
-                        # a number of derived variables. These need to be
-                        # patched up as well.
-                        'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'):
-
-                        flags = _CONFIG_VARS[key]
-                        flags = re.sub(r'-arch\s+\w+\s', ' ', flags)
-                        flags = flags + ' ' + arch
-                        _CONFIG_VARS[key] = flags
-
-                # If we're on OSX 10.5 or later and the user tries to
-                # compiles an extension using an SDK that is not present
-                # on the current machine it is better to not use an SDK
-                # than to fail.
-                #
-                # The major usecase for this is users using a Python.org
-                # binary installer  on OSX 10.6: that installer uses
-                # the 10.4u SDK, but that SDK is not installed by default
-                # when you install Xcode.
-                #
-                CFLAGS = _CONFIG_VARS.get('CFLAGS', '')
-                m = re.search(r'-isysroot\s+(\S+)', CFLAGS)
-                if m is not None:
-                    sdk = m.group(1)
-                    if not os.path.exists(sdk):
-                        for key in ('LDFLAGS', 'BASECFLAGS',
-                             # a number of derived variables. These need to be
-                             # patched up as well.
-                            'CFLAGS', 'PY_CFLAGS', 'BLDSHARED'):
-
-                            flags = _CONFIG_VARS[key]
-                            flags = re.sub(r'-isysroot\s+\S+(\s|$)', ' ', flags)
-                            _CONFIG_VARS[key] = flags
-
-    if args:
-        vals = []
-        for name in args:
-            vals.append(_CONFIG_VARS.get(name))
-        return vals
-    else:
-        return _CONFIG_VARS
-
-
-def get_config_var(name):
-    """Return the value of a single variable using the dictionary returned by
-    'get_config_vars()'.
-
-    Equivalent to get_config_vars().get(name)
-    """
-    return get_config_vars().get(name)
-
-
-def get_platform():
-    """Return a string that identifies the current platform.
-
-    This is used mainly to distinguish platform-specific build directories and
-    platform-specific built distributions.  Typically includes the OS name
-    and version and the architecture (as supplied by 'os.uname()'),
-    although the exact information included depends on the OS; eg. for IRIX
-    the architecture isn't particularly important (IRIX only runs on SGI
-    hardware), but for Linux the kernel version isn't particularly
-    important.
-
-    Examples of returned values:
-       linux-i586
-       linux-alpha (?)
-       solaris-2.6-sun4u
-       irix-5.3
-       irix64-6.2
-
-    Windows will return one of:
-       win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc)
-       win-ia64 (64bit Windows on Itanium)
-       win32 (all others - specifically, sys.platform is returned)
-
-    For other non-POSIX platforms, currently just returns 'sys.platform'.
-    """
-    if os.name == 'nt':
-        # sniff sys.version for architecture.
-        prefix = " bit ("
-        i = sys.version.find(prefix)
-        if i == -1:
-            return sys.platform
-        j = sys.version.find(")", i)
-        look = sys.version[i+len(prefix):j].lower()
-        if look == 'amd64':
-            return 'win-amd64'
-        if look == 'itanium':
-            return 'win-ia64'
-        return sys.platform
-
-    if os.name != "posix" or not hasattr(os, 'uname'):
-        # XXX what about the architecture? NT is Intel or Alpha,
-        # Mac OS is M68k or PPC, etc.
-        return sys.platform
-
-    # Try to distinguish various flavours of Unix
-    osname, host, release, version, machine = os.uname()
-
-    # Convert the OS name to lowercase, remove '/' characters
-    # (to accommodate BSD/OS), and translate spaces (for "Power Macintosh")
-    osname = osname.lower().replace('/', '')
-    machine = machine.replace(' ', '_')
-    machine = machine.replace('/', '-')
-
-    if osname[:5] == "linux":
-        # At least on Linux/Intel, 'machine' is the processor --
-        # i386, etc.
-        # XXX what about Alpha, SPARC, etc?
-        return  "%s-%s" % (osname, machine)
-    elif osname[:5] == "sunos":
-        if release[0] >= "5":           # SunOS 5 == Solaris 2
-            osname = "solaris"
-            release = "%d.%s" % (int(release[0]) - 3, release[2:])
-        # fall through to standard osname-release-machine representation
-    elif osname[:4] == "irix":              # could be "irix64"!
-        return "%s-%s" % (osname, release)
-    elif osname[:3] == "aix":
-        return "%s-%s.%s" % (osname, version, release)
-    elif osname[:6] == "cygwin":
-        osname = "cygwin"
-        rel_re = re.compile(r'[\d.]+')
-        m = rel_re.match(release)
-        if m:
-            release = m.group()
-    elif osname[:6] == "darwin":
-        #
-        # For our purposes, we'll assume that the system version from
-        # distutils' perspective is what MACOSX_DEPLOYMENT_TARGET is set
-        # to. This makes the compatibility story a bit more sane because the
-        # machine is going to compile and link as if it were
-        # MACOSX_DEPLOYMENT_TARGET.
-        cfgvars = get_config_vars()
-        macver = cfgvars.get('MACOSX_DEPLOYMENT_TARGET')
-
-        if True:
-            # Always calculate the release of the running machine,
-            # needed to determine if we can build fat binaries or not.
-
-            macrelease = macver
-            # Get the system version. Reading this plist is a documented
-            # way to get the system version (see the documentation for
-            # the Gestalt Manager)
-            try:
-                f = open('/System/Library/CoreServices/SystemVersion.plist')
-            except IOError:
-                # We're on a plain darwin box, fall back to the default
-                # behaviour.
-                pass
-            else:
-                try:
-                    m = re.search(r'<key>ProductUserVisibleVersion</key>\s*'
-                                  r'<string>(.*?)</string>', f.read())
-                finally:
-                    f.close()
-                if m is not None:
-                    macrelease = '.'.join(m.group(1).split('.')[:2])
-                # else: fall back to the default behaviour
-
-        if not macver:
-            macver = macrelease
-
-        if macver:
-            release = macver
-            osname = "macosx"
-
-            if ((macrelease + '.') >= '10.4.' and
-                '-arch' in get_config_vars().get('CFLAGS', '').strip()):
-                # The universal build will build fat binaries, but not on
-                # systems before 10.4
-                #
-                # Try to detect 4-way universal builds, those have machine-type
-                # 'universal' instead of 'fat'.
-
-                machine = 'fat'
-                cflags = get_config_vars().get('CFLAGS')
-
-                archs = re.findall(r'-arch\s+(\S+)', cflags)
-                archs = tuple(sorted(set(archs)))
-
-                if len(archs) == 1:
-                    machine = archs[0]
-                elif archs == ('i386', 'ppc'):
-                    machine = 'fat'
-                elif archs == ('i386', 'x86_64'):
-                    machine = 'intel'
-                elif archs == ('i386', 'ppc', 'x86_64'):
-                    machine = 'fat3'
-                elif archs == ('ppc64', 'x86_64'):
-                    machine = 'fat64'
-                elif archs == ('i386', 'ppc', 'ppc64', 'x86_64'):
-                    machine = 'universal'
-                else:
-                    raise ValueError(
-                       "Don't know machine value for archs=%r" % (archs,))
-
-            elif machine == 'i386':
-                # On OSX the machine type returned by uname is always the
-                # 32-bit variant, even if the executable architecture is
-                # the 64-bit variant
-                if sys.maxsize >= 2**32:
-                    machine = 'x86_64'
-
-            elif machine in ('PowerPC', 'Power_Macintosh'):
-                # Pick a sane name for the PPC architecture.
-                # See 'i386' case
-                if sys.maxsize >= 2**32:
-                    machine = 'ppc64'
-                else:
-                    machine = 'ppc'
-
-    return "%s-%s-%s" % (osname, release, machine)
-
-
-def get_python_version():
-    return _PY_VERSION_SHORT
-
-
-def _print_dict(title, data):
-    for index, (key, value) in enumerate(sorted(data.items())):
-        if index == 0:
-            print('%s: ' % (title))
-        print('\t%s = "%s"' % (key, value))
-
-
-def _main():
-    """Display all information sysconfig detains."""
-    print('Platform: "%s"' % get_platform())
-    print('Python version: "%s"' % get_python_version())
-    print('Current installation scheme: "%s"' % _get_default_scheme())
-    print()
-    _print_dict('Paths', get_paths())
-    print()
-    _print_dict('Variables', get_config_vars())
-
-
-if __name__ == '__main__':
-    _main()
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py b/env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py
deleted file mode 100644
index d66d8566..00000000
--- a/env/Lib/site-packages/pip/_vendor/distlib/_backport/tarfile.py
+++ /dev/null
@@ -1,2607 +0,0 @@
-#-------------------------------------------------------------------
-# tarfile.py
-#-------------------------------------------------------------------
-# Copyright (C) 2002 Lars Gustaebel <lars@gustaebel.de>
-# All rights reserved.
-#
-# Permission  is  hereby granted,  free  of charge,  to  any person
-# obtaining a  copy of  this software  and associated documentation
-# files  (the  "Software"),  to   deal  in  the  Software   without
-# restriction,  including  without limitation  the  rights to  use,
-# copy, modify, merge, publish, distribute, sublicense, and/or sell
-# copies  of  the  Software,  and to  permit  persons  to  whom the
-# Software  is  furnished  to  do  so,  subject  to  the  following
-# conditions:
-#
-# The above copyright  notice and this  permission notice shall  be
-# included in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS  IS", WITHOUT WARRANTY OF ANY  KIND,
-# EXPRESS OR IMPLIED, INCLUDING  BUT NOT LIMITED TO  THE WARRANTIES
-# OF  MERCHANTABILITY,  FITNESS   FOR  A  PARTICULAR   PURPOSE  AND
-# NONINFRINGEMENT.  IN  NO  EVENT SHALL  THE  AUTHORS  OR COPYRIGHT
-# HOLDERS  BE LIABLE  FOR ANY  CLAIM, DAMAGES  OR OTHER  LIABILITY,
-# WHETHER  IN AN  ACTION OF  CONTRACT, TORT  OR OTHERWISE,  ARISING
-# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
-# OTHER DEALINGS IN THE SOFTWARE.
-#
-from __future__ import print_function
-
-"""Read from and write to tar format archives.
-"""
-
-__version__ = "$Revision$"
-
-version     = "0.9.0"
-__author__  = "Lars Gust\u00e4bel (lars@gustaebel.de)"
-__date__    = "$Date: 2011-02-25 17:42:01 +0200 (Fri, 25 Feb 2011) $"
-__cvsid__   = "$Id: tarfile.py 88586 2011-02-25 15:42:01Z marc-andre.lemburg $"
-__credits__ = "Gustavo Niemeyer, Niels Gust\u00e4bel, Richard Townsend."
-
-#---------
-# Imports
-#---------
-import sys
-import os
-import stat
-import errno
-import time
-import struct
-import copy
-import re
-
-try:
-    import grp, pwd
-except ImportError:
-    grp = pwd = None
-
-# os.symlink on Windows prior to 6.0 raises NotImplementedError
-symlink_exception = (AttributeError, NotImplementedError)
-try:
-    # WindowsError (1314) will be raised if the caller does not hold the
-    # SeCreateSymbolicLinkPrivilege privilege
-    symlink_exception += (WindowsError,)
-except NameError:
-    pass
-
-# from tarfile import *
-__all__ = ["TarFile", "TarInfo", "is_tarfile", "TarError"]
-
-if sys.version_info[0] < 3:
-    import __builtin__ as builtins
-else:
-    import builtins
-
-_open = builtins.open   # Since 'open' is TarFile.open
-
-#---------------------------------------------------------
-# tar constants
-#---------------------------------------------------------
-NUL = b"\0"                     # the null character
-BLOCKSIZE = 512                 # length of processing blocks
-RECORDSIZE = BLOCKSIZE * 20     # length of records
-GNU_MAGIC = b"ustar  \0"        # magic gnu tar string
-POSIX_MAGIC = b"ustar\x0000"    # magic posix tar string
-
-LENGTH_NAME = 100               # maximum length of a filename
-LENGTH_LINK = 100               # maximum length of a linkname
-LENGTH_PREFIX = 155             # maximum length of the prefix field
-
-REGTYPE = b"0"                  # regular file
-AREGTYPE = b"\0"                # regular file
-LNKTYPE = b"1"                  # link (inside tarfile)
-SYMTYPE = b"2"                  # symbolic link
-CHRTYPE = b"3"                  # character special device
-BLKTYPE = b"4"                  # block special device
-DIRTYPE = b"5"                  # directory
-FIFOTYPE = b"6"                 # fifo special device
-CONTTYPE = b"7"                 # contiguous file
-
-GNUTYPE_LONGNAME = b"L"         # GNU tar longname
-GNUTYPE_LONGLINK = b"K"         # GNU tar longlink
-GNUTYPE_SPARSE = b"S"           # GNU tar sparse file
-
-XHDTYPE = b"x"                  # POSIX.1-2001 extended header
-XGLTYPE = b"g"                  # POSIX.1-2001 global header
-SOLARIS_XHDTYPE = b"X"          # Solaris extended header
-
-USTAR_FORMAT = 0                # POSIX.1-1988 (ustar) format
-GNU_FORMAT = 1                  # GNU tar format
-PAX_FORMAT = 2                  # POSIX.1-2001 (pax) format
-DEFAULT_FORMAT = GNU_FORMAT
-
-#---------------------------------------------------------
-# tarfile constants
-#---------------------------------------------------------
-# File types that tarfile supports:
-SUPPORTED_TYPES = (REGTYPE, AREGTYPE, LNKTYPE,
-                   SYMTYPE, DIRTYPE, FIFOTYPE,
-                   CONTTYPE, CHRTYPE, BLKTYPE,
-                   GNUTYPE_LONGNAME, GNUTYPE_LONGLINK,
-                   GNUTYPE_SPARSE)
-
-# File types that will be treated as a regular file.
-REGULAR_TYPES = (REGTYPE, AREGTYPE,
-                 CONTTYPE, GNUTYPE_SPARSE)
-
-# File types that are part of the GNU tar format.
-GNU_TYPES = (GNUTYPE_LONGNAME, GNUTYPE_LONGLINK,
-             GNUTYPE_SPARSE)
-
-# Fields from a pax header that override a TarInfo attribute.
-PAX_FIELDS = ("path", "linkpath", "size", "mtime",
-              "uid", "gid", "uname", "gname")
-
-# Fields from a pax header that are affected by hdrcharset.
-PAX_NAME_FIELDS = set(("path", "linkpath", "uname", "gname"))
-
-# Fields in a pax header that are numbers, all other fields
-# are treated as strings.
-PAX_NUMBER_FIELDS = {
-    "atime": float,
-    "ctime": float,
-    "mtime": float,
-    "uid": int,
-    "gid": int,
-    "size": int
-}
-
-#---------------------------------------------------------
-# Bits used in the mode field, values in octal.
-#---------------------------------------------------------
-S_IFLNK = 0o120000        # symbolic link
-S_IFREG = 0o100000        # regular file
-S_IFBLK = 0o060000        # block device
-S_IFDIR = 0o040000        # directory
-S_IFCHR = 0o020000        # character device
-S_IFIFO = 0o010000        # fifo
-
-TSUID   = 0o4000          # set UID on execution
-TSGID   = 0o2000          # set GID on execution
-TSVTX   = 0o1000          # reserved
-
-TUREAD  = 0o400           # read by owner
-TUWRITE = 0o200           # write by owner
-TUEXEC  = 0o100           # execute/search by owner
-TGREAD  = 0o040           # read by group
-TGWRITE = 0o020           # write by group
-TGEXEC  = 0o010           # execute/search by group
-TOREAD  = 0o004           # read by other
-TOWRITE = 0o002           # write by other
-TOEXEC  = 0o001           # execute/search by other
-
-#---------------------------------------------------------
-# initialization
-#---------------------------------------------------------
-if os.name in ("nt", "ce"):
-    ENCODING = "utf-8"
-else:
-    ENCODING = sys.getfilesystemencoding()
-
-#---------------------------------------------------------
-# Some useful functions
-#---------------------------------------------------------
-
-def stn(s, length, encoding, errors):
-    """Convert a string to a null-terminated bytes object.
-    """
-    s = s.encode(encoding, errors)
-    return s[:length] + (length - len(s)) * NUL
-
-def nts(s, encoding, errors):
-    """Convert a null-terminated bytes object to a string.
-    """
-    p = s.find(b"\0")
-    if p != -1:
-        s = s[:p]
-    return s.decode(encoding, errors)
-
-def nti(s):
-    """Convert a number field to a python number.
-    """
-    # There are two possible encodings for a number field, see
-    # itn() below.
-    if s[0] != chr(0o200):
-        try:
-            n = int(nts(s, "ascii", "strict") or "0", 8)
-        except ValueError:
-            raise InvalidHeaderError("invalid header")
-    else:
-        n = 0
-        for i in range(len(s) - 1):
-            n <<= 8
-            n += ord(s[i + 1])
-    return n
-
-def itn(n, digits=8, format=DEFAULT_FORMAT):
-    """Convert a python number to a number field.
-    """
-    # POSIX 1003.1-1988 requires numbers to be encoded as a string of
-    # octal digits followed by a null-byte, this allows values up to
-    # (8**(digits-1))-1. GNU tar allows storing numbers greater than
-    # that if necessary. A leading 0o200 byte indicates this particular
-    # encoding, the following digits-1 bytes are a big-endian
-    # representation. This allows values up to (256**(digits-1))-1.
-    if 0 <= n < 8 ** (digits - 1):
-        s = ("%0*o" % (digits - 1, n)).encode("ascii") + NUL
-    else:
-        if format != GNU_FORMAT or n >= 256 ** (digits - 1):
-            raise ValueError("overflow in number field")
-
-        if n < 0:
-            # XXX We mimic GNU tar's behaviour with negative numbers,
-            # this could raise OverflowError.
-            n = struct.unpack("L", struct.pack("l", n))[0]
-
-        s = bytearray()
-        for i in range(digits - 1):
-            s.insert(0, n & 0o377)
-            n >>= 8
-        s.insert(0, 0o200)
-    return s
-
-def calc_chksums(buf):
-    """Calculate the checksum for a member's header by summing up all
-       characters except for the chksum field which is treated as if
-       it was filled with spaces. According to the GNU tar sources,
-       some tars (Sun and NeXT) calculate chksum with signed char,
-       which will be different if there are chars in the buffer with
-       the high bit set. So we calculate two checksums, unsigned and
-       signed.
-    """
-    unsigned_chksum = 256 + sum(struct.unpack("148B", buf[:148]) + struct.unpack("356B", buf[156:512]))
-    signed_chksum = 256 + sum(struct.unpack("148b", buf[:148]) + struct.unpack("356b", buf[156:512]))
-    return unsigned_chksum, signed_chksum
-
-def copyfileobj(src, dst, length=None):
-    """Copy length bytes from fileobj src to fileobj dst.
-       If length is None, copy the entire content.
-    """
-    if length == 0:
-        return
-    if length is None:
-        while True:
-            buf = src.read(16*1024)
-            if not buf:
-                break
-            dst.write(buf)
-        return
-
-    BUFSIZE = 16 * 1024
-    blocks, remainder = divmod(length, BUFSIZE)
-    for b in range(blocks):
-        buf = src.read(BUFSIZE)
-        if len(buf) < BUFSIZE:
-            raise IOError("end of file reached")
-        dst.write(buf)
-
-    if remainder != 0:
-        buf = src.read(remainder)
-        if len(buf) < remainder:
-            raise IOError("end of file reached")
-        dst.write(buf)
-    return
-
-filemode_table = (
-    ((S_IFLNK,      "l"),
-     (S_IFREG,      "-"),
-     (S_IFBLK,      "b"),
-     (S_IFDIR,      "d"),
-     (S_IFCHR,      "c"),
-     (S_IFIFO,      "p")),
-
-    ((TUREAD,       "r"),),
-    ((TUWRITE,      "w"),),
-    ((TUEXEC|TSUID, "s"),
-     (TSUID,        "S"),
-     (TUEXEC,       "x")),
-
-    ((TGREAD,       "r"),),
-    ((TGWRITE,      "w"),),
-    ((TGEXEC|TSGID, "s"),
-     (TSGID,        "S"),
-     (TGEXEC,       "x")),
-
-    ((TOREAD,       "r"),),
-    ((TOWRITE,      "w"),),
-    ((TOEXEC|TSVTX, "t"),
-     (TSVTX,        "T"),
-     (TOEXEC,       "x"))
-)
-
-def filemode(mode):
-    """Convert a file's mode to a string of the form
-       -rwxrwxrwx.
-       Used by TarFile.list()
-    """
-    perm = []
-    for table in filemode_table:
-        for bit, char in table:
-            if mode & bit == bit:
-                perm.append(char)
-                break
-        else:
-            perm.append("-")
-    return "".join(perm)
-
-class TarError(Exception):
-    """Base exception."""
-    pass
-class ExtractError(TarError):
-    """General exception for extract errors."""
-    pass
-class ReadError(TarError):
-    """Exception for unreadable tar archives."""
-    pass
-class CompressionError(TarError):
-    """Exception for unavailable compression methods."""
-    pass
-class StreamError(TarError):
-    """Exception for unsupported operations on stream-like TarFiles."""
-    pass
-class HeaderError(TarError):
-    """Base exception for header errors."""
-    pass
-class EmptyHeaderError(HeaderError):
-    """Exception for empty headers."""
-    pass
-class TruncatedHeaderError(HeaderError):
-    """Exception for truncated headers."""
-    pass
-class EOFHeaderError(HeaderError):
-    """Exception for end of file headers."""
-    pass
-class InvalidHeaderError(HeaderError):
-    """Exception for invalid headers."""
-    pass
-class SubsequentHeaderError(HeaderError):
-    """Exception for missing and invalid extended headers."""
-    pass
-
-#---------------------------
-# internal stream interface
-#---------------------------
-class _LowLevelFile(object):
-    """Low-level file object. Supports reading and writing.
-       It is used instead of a regular file object for streaming
-       access.
-    """
-
-    def __init__(self, name, mode):
-        mode = {
-            "r": os.O_RDONLY,
-            "w": os.O_WRONLY | os.O_CREAT | os.O_TRUNC,
-        }[mode]
-        if hasattr(os, "O_BINARY"):
-            mode |= os.O_BINARY
-        self.fd = os.open(name, mode, 0o666)
-
-    def close(self):
-        os.close(self.fd)
-
-    def read(self, size):
-        return os.read(self.fd, size)
-
-    def write(self, s):
-        os.write(self.fd, s)
-
-class _Stream(object):
-    """Class that serves as an adapter between TarFile and
-       a stream-like object.  The stream-like object only
-       needs to have a read() or write() method and is accessed
-       blockwise.  Use of gzip or bzip2 compression is possible.
-       A stream-like object could be for example: sys.stdin,
-       sys.stdout, a socket, a tape device etc.
-
-       _Stream is intended to be used only internally.
-    """
-
-    def __init__(self, name, mode, comptype, fileobj, bufsize):
-        """Construct a _Stream object.
-        """
-        self._extfileobj = True
-        if fileobj is None:
-            fileobj = _LowLevelFile(name, mode)
-            self._extfileobj = False
-
-        if comptype == '*':
-            # Enable transparent compression detection for the
-            # stream interface
-            fileobj = _StreamProxy(fileobj)
-            comptype = fileobj.getcomptype()
-
-        self.name     = name or ""
-        self.mode     = mode
-        self.comptype = comptype
-        self.fileobj  = fileobj
-        self.bufsize  = bufsize
-        self.buf      = b""
-        self.pos      = 0
-        self.closed   = False
-
-        try:
-            if comptype == "gz":
-                try:
-                    import zlib
-                except ImportError:
-                    raise CompressionError("zlib module is not available")
-                self.zlib = zlib
-                self.crc = zlib.crc32(b"")
-                if mode == "r":
-                    self._init_read_gz()
-                else:
-                    self._init_write_gz()
-
-            if comptype == "bz2":
-                try:
-                    import bz2
-                except ImportError:
-                    raise CompressionError("bz2 module is not available")
-                if mode == "r":
-                    self.dbuf = b""
-                    self.cmp = bz2.BZ2Decompressor()
-                else:
-                    self.cmp = bz2.BZ2Compressor()
-        except:
-            if not self._extfileobj:
-                self.fileobj.close()
-            self.closed = True
-            raise
-
-    def __del__(self):
-        if hasattr(self, "closed") and not self.closed:
-            self.close()
-
-    def _init_write_gz(self):
-        """Initialize for writing with gzip compression.
-        """
-        self.cmp = self.zlib.compressobj(9, self.zlib.DEFLATED,
-                                            -self.zlib.MAX_WBITS,
-                                            self.zlib.DEF_MEM_LEVEL,
-                                            0)
-        timestamp = struct.pack("<L", int(time.time()))
-        self.__write(b"\037\213\010\010" + timestamp + b"\002\377")
-        if self.name.endswith(".gz"):
-            self.name = self.name[:-3]
-        # RFC1952 says we must use ISO-8859-1 for the FNAME field.
-        self.__write(self.name.encode("iso-8859-1", "replace") + NUL)
-
-    def write(self, s):
-        """Write string s to the stream.
-        """
-        if self.comptype == "gz":
-            self.crc = self.zlib.crc32(s, self.crc)
-        self.pos += len(s)
-        if self.comptype != "tar":
-            s = self.cmp.compress(s)
-        self.__write(s)
-
-    def __write(self, s):
-        """Write string s to the stream if a whole new block
-           is ready to be written.
-        """
-        self.buf += s
-        while len(self.buf) > self.bufsize:
-            self.fileobj.write(self.buf[:self.bufsize])
-            self.buf = self.buf[self.bufsize:]
-
-    def close(self):
-        """Close the _Stream object. No operation should be
-           done on it afterwards.
-        """
-        if self.closed:
-            return
-
-        if self.mode == "w" and self.comptype != "tar":
-            self.buf += self.cmp.flush()
-
-        if self.mode == "w" and self.buf:
-            self.fileobj.write(self.buf)
-            self.buf = b""
-            if self.comptype == "gz":
-                # The native zlib crc is an unsigned 32-bit integer, but
-                # the Python wrapper implicitly casts that to a signed C
-                # long.  So, on a 32-bit box self.crc may "look negative",
-                # while the same crc on a 64-bit box may "look positive".
-                # To avoid irksome warnings from the `struct` module, force
-                # it to look positive on all boxes.
-                self.fileobj.write(struct.pack("<L", self.crc & 0xffffffff))
-                self.fileobj.write(struct.pack("<L", self.pos & 0xffffFFFF))
-
-        if not self._extfileobj:
-            self.fileobj.close()
-
-        self.closed = True
-
-    def _init_read_gz(self):
-        """Initialize for reading a gzip compressed fileobj.
-        """
-        self.cmp = self.zlib.decompressobj(-self.zlib.MAX_WBITS)
-        self.dbuf = b""
-
-        # taken from gzip.GzipFile with some alterations
-        if self.__read(2) != b"\037\213":
-            raise ReadError("not a gzip file")
-        if self.__read(1) != b"\010":
-            raise CompressionError("unsupported compression method")
-
-        flag = ord(self.__read(1))
-        self.__read(6)
-
-        if flag & 4:
-            xlen = ord(self.__read(1)) + 256 * ord(self.__read(1))
-            self.read(xlen)
-        if flag & 8:
-            while True:
-                s = self.__read(1)
-                if not s or s == NUL:
-                    break
-        if flag & 16:
-            while True:
-                s = self.__read(1)
-                if not s or s == NUL:
-                    break
-        if flag & 2:
-            self.__read(2)
-
-    def tell(self):
-        """Return the stream's file pointer position.
-        """
-        return self.pos
-
-    def seek(self, pos=0):
-        """Set the stream's file pointer to pos. Negative seeking
-           is forbidden.
-        """
-        if pos - self.pos >= 0:
-            blocks, remainder = divmod(pos - self.pos, self.bufsize)
-            for i in range(blocks):
-                self.read(self.bufsize)
-            self.read(remainder)
-        else:
-            raise StreamError("seeking backwards is not allowed")
-        return self.pos
-
-    def read(self, size=None):
-        """Return the next size number of bytes from the stream.
-           If size is not defined, return all bytes of the stream
-           up to EOF.
-        """
-        if size is None:
-            t = []
-            while True:
-                buf = self._read(self.bufsize)
-                if not buf:
-                    break
-                t.append(buf)
-            buf = "".join(t)
-        else:
-            buf = self._read(size)
-        self.pos += len(buf)
-        return buf
-
-    def _read(self, size):
-        """Return size bytes from the stream.
-        """
-        if self.comptype == "tar":
-            return self.__read(size)
-
-        c = len(self.dbuf)
-        while c < size:
-            buf = self.__read(self.bufsize)
-            if not buf:
-                break
-            try:
-                buf = self.cmp.decompress(buf)
-            except IOError:
-                raise ReadError("invalid compressed data")
-            self.dbuf += buf
-            c += len(buf)
-        buf = self.dbuf[:size]
-        self.dbuf = self.dbuf[size:]
-        return buf
-
-    def __read(self, size):
-        """Return size bytes from stream. If internal buffer is empty,
-           read another block from the stream.
-        """
-        c = len(self.buf)
-        while c < size:
-            buf = self.fileobj.read(self.bufsize)
-            if not buf:
-                break
-            self.buf += buf
-            c += len(buf)
-        buf = self.buf[:size]
-        self.buf = self.buf[size:]
-        return buf
-# class _Stream
-
-class _StreamProxy(object):
-    """Small proxy class that enables transparent compression
-       detection for the Stream interface (mode 'r|*').
-    """
-
-    def __init__(self, fileobj):
-        self.fileobj = fileobj
-        self.buf = self.fileobj.read(BLOCKSIZE)
-
-    def read(self, size):
-        self.read = self.fileobj.read
-        return self.buf
-
-    def getcomptype(self):
-        if self.buf.startswith(b"\037\213\010"):
-            return "gz"
-        if self.buf.startswith(b"BZh91"):
-            return "bz2"
-        return "tar"
-
-    def close(self):
-        self.fileobj.close()
-# class StreamProxy
-
-class _BZ2Proxy(object):
-    """Small proxy class that enables external file object
-       support for "r:bz2" and "w:bz2" modes. This is actually
-       a workaround for a limitation in bz2 module's BZ2File
-       class which (unlike gzip.GzipFile) has no support for
-       a file object argument.
-    """
-
-    blocksize = 16 * 1024
-
-    def __init__(self, fileobj, mode):
-        self.fileobj = fileobj
-        self.mode = mode
-        self.name = getattr(self.fileobj, "name", None)
-        self.init()
-
-    def init(self):
-        import bz2
-        self.pos = 0
-        if self.mode == "r":
-            self.bz2obj = bz2.BZ2Decompressor()
-            self.fileobj.seek(0)
-            self.buf = b""
-        else:
-            self.bz2obj = bz2.BZ2Compressor()
-
-    def read(self, size):
-        x = len(self.buf)
-        while x < size:
-            raw = self.fileobj.read(self.blocksize)
-            if not raw:
-                break
-            data = self.bz2obj.decompress(raw)
-            self.buf += data
-            x += len(data)
-
-        buf = self.buf[:size]
-        self.buf = self.buf[size:]
-        self.pos += len(buf)
-        return buf
-
-    def seek(self, pos):
-        if pos < self.pos:
-            self.init()
-        self.read(pos - self.pos)
-
-    def tell(self):
-        return self.pos
-
-    def write(self, data):
-        self.pos += len(data)
-        raw = self.bz2obj.compress(data)
-        self.fileobj.write(raw)
-
-    def close(self):
-        if self.mode == "w":
-            raw = self.bz2obj.flush()
-            self.fileobj.write(raw)
-# class _BZ2Proxy
-
-#------------------------
-# Extraction file object
-#------------------------
-class _FileInFile(object):
-    """A thin wrapper around an existing file object that
-       provides a part of its data as an individual file
-       object.
-    """
-
-    def __init__(self, fileobj, offset, size, blockinfo=None):
-        self.fileobj = fileobj
-        self.offset = offset
-        self.size = size
-        self.position = 0
-
-        if blockinfo is None:
-            blockinfo = [(0, size)]
-
-        # Construct a map with data and zero blocks.
-        self.map_index = 0
-        self.map = []
-        lastpos = 0
-        realpos = self.offset
-        for offset, size in blockinfo:
-            if offset > lastpos:
-                self.map.append((False, lastpos, offset, None))
-            self.map.append((True, offset, offset + size, realpos))
-            realpos += size
-            lastpos = offset + size
-        if lastpos < self.size:
-            self.map.append((False, lastpos, self.size, None))
-
-    def seekable(self):
-        if not hasattr(self.fileobj, "seekable"):
-            # XXX gzip.GzipFile and bz2.BZ2File
-            return True
-        return self.fileobj.seekable()
-
-    def tell(self):
-        """Return the current file position.
-        """
-        return self.position
-
-    def seek(self, position):
-        """Seek to a position in the file.
-        """
-        self.position = position
-
-    def read(self, size=None):
-        """Read data from the file.
-        """
-        if size is None:
-            size = self.size - self.position
-        else:
-            size = min(size, self.size - self.position)
-
-        buf = b""
-        while size > 0:
-            while True:
-                data, start, stop, offset = self.map[self.map_index]
-                if start <= self.position < stop:
-                    break
-                else:
-                    self.map_index += 1
-                    if self.map_index == len(self.map):
-                        self.map_index = 0
-            length = min(size, stop - self.position)
-            if data:
-                self.fileobj.seek(offset + (self.position - start))
-                buf += self.fileobj.read(length)
-            else:
-                buf += NUL * length
-            size -= length
-            self.position += length
-        return buf
-#class _FileInFile
-
-
-class ExFileObject(object):
-    """File-like object for reading an archive member.
-       Is returned by TarFile.extractfile().
-    """
-    blocksize = 1024
-
-    def __init__(self, tarfile, tarinfo):
-        self.fileobj = _FileInFile(tarfile.fileobj,
-                                   tarinfo.offset_data,
-                                   tarinfo.size,
-                                   tarinfo.sparse)
-        self.name = tarinfo.name
-        self.mode = "r"
-        self.closed = False
-        self.size = tarinfo.size
-
-        self.position = 0
-        self.buffer = b""
-
-    def readable(self):
-        return True
-
-    def writable(self):
-        return False
-
-    def seekable(self):
-        return self.fileobj.seekable()
-
-    def read(self, size=None):
-        """Read at most size bytes from the file. If size is not
-           present or None, read all data until EOF is reached.
-        """
-        if self.closed:
-            raise ValueError("I/O operation on closed file")
-
-        buf = b""
-        if self.buffer:
-            if size is None:
-                buf = self.buffer
-                self.buffer = b""
-            else:
-                buf = self.buffer[:size]
-                self.buffer = self.buffer[size:]
-
-        if size is None:
-            buf += self.fileobj.read()
-        else:
-            buf += self.fileobj.read(size - len(buf))
-
-        self.position += len(buf)
-        return buf
-
-    # XXX TextIOWrapper uses the read1() method.
-    read1 = read
-
-    def readline(self, size=-1):
-        """Read one entire line from the file. If size is present
-           and non-negative, return a string with at most that
-           size, which may be an incomplete line.
-        """
-        if self.closed:
-            raise ValueError("I/O operation on closed file")
-
-        pos = self.buffer.find(b"\n") + 1
-        if pos == 0:
-            # no newline found.
-            while True:
-                buf = self.fileobj.read(self.blocksize)
-                self.buffer += buf
-                if not buf or b"\n" in buf:
-                    pos = self.buffer.find(b"\n") + 1
-                    if pos == 0:
-                        # no newline found.
-                        pos = len(self.buffer)
-                    break
-
-        if size != -1:
-            pos = min(size, pos)
-
-        buf = self.buffer[:pos]
-        self.buffer = self.buffer[pos:]
-        self.position += len(buf)
-        return buf
-
-    def readlines(self):
-        """Return a list with all remaining lines.
-        """
-        result = []
-        while True:
-            line = self.readline()
-            if not line: break
-            result.append(line)
-        return result
-
-    def tell(self):
-        """Return the current file position.
-        """
-        if self.closed:
-            raise ValueError("I/O operation on closed file")
-
-        return self.position
-
-    def seek(self, pos, whence=os.SEEK_SET):
-        """Seek to a position in the file.
-        """
-        if self.closed:
-            raise ValueError("I/O operation on closed file")
-
-        if whence == os.SEEK_SET:
-            self.position = min(max(pos, 0), self.size)
-        elif whence == os.SEEK_CUR:
-            if pos < 0:
-                self.position = max(self.position + pos, 0)
-            else:
-                self.position = min(self.position + pos, self.size)
-        elif whence == os.SEEK_END:
-            self.position = max(min(self.size + pos, self.size), 0)
-        else:
-            raise ValueError("Invalid argument")
-
-        self.buffer = b""
-        self.fileobj.seek(self.position)
-
-    def close(self):
-        """Close the file object.
-        """
-        self.closed = True
-
-    def __iter__(self):
-        """Get an iterator over the file's lines.
-        """
-        while True:
-            line = self.readline()
-            if not line:
-                break
-            yield line
-#class ExFileObject
-
-#------------------
-# Exported Classes
-#------------------
-class TarInfo(object):
-    """Informational class which holds the details about an
-       archive member given by a tar header block.
-       TarInfo objects are returned by TarFile.getmember(),
-       TarFile.getmembers() and TarFile.gettarinfo() and are
-       usually created internally.
-    """
-
-    __slots__ = ("name", "mode", "uid", "gid", "size", "mtime",
-                 "chksum", "type", "linkname", "uname", "gname",
-                 "devmajor", "devminor",
-                 "offset", "offset_data", "pax_headers", "sparse",
-                 "tarfile", "_sparse_structs", "_link_target")
-
-    def __init__(self, name=""):
-        """Construct a TarInfo object. name is the optional name
-           of the member.
-        """
-        self.name = name        # member name
-        self.mode = 0o644       # file permissions
-        self.uid = 0            # user id
-        self.gid = 0            # group id
-        self.size = 0           # file size
-        self.mtime = 0          # modification time
-        self.chksum = 0         # header checksum
-        self.type = REGTYPE     # member type
-        self.linkname = ""      # link name
-        self.uname = ""         # user name
-        self.gname = ""         # group name
-        self.devmajor = 0       # device major number
-        self.devminor = 0       # device minor number
-
-        self.offset = 0         # the tar header starts here
-        self.offset_data = 0    # the file's data starts here
-
-        self.sparse = None      # sparse member information
-        self.pax_headers = {}   # pax header information
-
-    # In pax headers the "name" and "linkname" field are called
-    # "path" and "linkpath".
-    def _getpath(self):
-        return self.name
-    def _setpath(self, name):
-        self.name = name
-    path = property(_getpath, _setpath)
-
-    def _getlinkpath(self):
-        return self.linkname
-    def _setlinkpath(self, linkname):
-        self.linkname = linkname
-    linkpath = property(_getlinkpath, _setlinkpath)
-
-    def __repr__(self):
-        return "<%s %r at %#x>" % (self.__class__.__name__,self.name,id(self))
-
-    def get_info(self):
-        """Return the TarInfo's attributes as a dictionary.
-        """
-        info = {
-            "name":     self.name,
-            "mode":     self.mode & 0o7777,
-            "uid":      self.uid,
-            "gid":      self.gid,
-            "size":     self.size,
-            "mtime":    self.mtime,
-            "chksum":   self.chksum,
-            "type":     self.type,
-            "linkname": self.linkname,
-            "uname":    self.uname,
-            "gname":    self.gname,
-            "devmajor": self.devmajor,
-            "devminor": self.devminor
-        }
-
-        if info["type"] == DIRTYPE and not info["name"].endswith("/"):
-            info["name"] += "/"
-
-        return info
-
-    def tobuf(self, format=DEFAULT_FORMAT, encoding=ENCODING, errors="surrogateescape"):
-        """Return a tar header as a string of 512 byte blocks.
-        """
-        info = self.get_info()
-
-        if format == USTAR_FORMAT:
-            return self.create_ustar_header(info, encoding, errors)
-        elif format == GNU_FORMAT:
-            return self.create_gnu_header(info, encoding, errors)
-        elif format == PAX_FORMAT:
-            return self.create_pax_header(info, encoding)
-        else:
-            raise ValueError("invalid format")
-
-    def create_ustar_header(self, info, encoding, errors):
-        """Return the object as a ustar header block.
-        """
-        info["magic"] = POSIX_MAGIC
-
-        if len(info["linkname"]) > LENGTH_LINK:
-            raise ValueError("linkname is too long")
-
-        if len(info["name"]) > LENGTH_NAME:
-            info["prefix"], info["name"] = self._posix_split_name(info["name"])
-
-        return self._create_header(info, USTAR_FORMAT, encoding, errors)
-
-    def create_gnu_header(self, info, encoding, errors):
-        """Return the object as a GNU header block sequence.
-        """
-        info["magic"] = GNU_MAGIC
-
-        buf = b""
-        if len(info["linkname"]) > LENGTH_LINK:
-            buf += self._create_gnu_long_header(info["linkname"], GNUTYPE_LONGLINK, encoding, errors)
-
-        if len(info["name"]) > LENGTH_NAME:
-            buf += self._create_gnu_long_header(info["name"], GNUTYPE_LONGNAME, encoding, errors)
-
-        return buf + self._create_header(info, GNU_FORMAT, encoding, errors)
-
-    def create_pax_header(self, info, encoding):
-        """Return the object as a ustar header block. If it cannot be
-           represented this way, prepend a pax extended header sequence
-           with supplement information.
-        """
-        info["magic"] = POSIX_MAGIC
-        pax_headers = self.pax_headers.copy()
-
-        # Test string fields for values that exceed the field length or cannot
-        # be represented in ASCII encoding.
-        for name, hname, length in (
-                ("name", "path", LENGTH_NAME), ("linkname", "linkpath", LENGTH_LINK),
-                ("uname", "uname", 32), ("gname", "gname", 32)):
-
-            if hname in pax_headers:
-                # The pax header has priority.
-                continue
-
-            # Try to encode the string as ASCII.
-            try:
-                info[name].encode("ascii", "strict")
-            except UnicodeEncodeError:
-                pax_headers[hname] = info[name]
-                continue
-
-            if len(info[name]) > length:
-                pax_headers[hname] = info[name]
-
-        # Test number fields for values that exceed the field limit or values
-        # that like to be stored as float.
-        for name, digits in (("uid", 8), ("gid", 8), ("size", 12), ("mtime", 12)):
-            if name in pax_headers:
-                # The pax header has priority. Avoid overflow.
-                info[name] = 0
-                continue
-
-            val = info[name]
-            if not 0 <= val < 8 ** (digits - 1) or isinstance(val, float):
-                pax_headers[name] = str(val)
-                info[name] = 0
-
-        # Create a pax extended header if necessary.
-        if pax_headers:
-            buf = self._create_pax_generic_header(pax_headers, XHDTYPE, encoding)
-        else:
-            buf = b""
-
-        return buf + self._create_header(info, USTAR_FORMAT, "ascii", "replace")
-
-    @classmethod
-    def create_pax_global_header(cls, pax_headers):
-        """Return the object as a pax global header block sequence.
-        """
-        return cls._create_pax_generic_header(pax_headers, XGLTYPE, "utf8")
-
-    def _posix_split_name(self, name):
-        """Split a name longer than 100 chars into a prefix
-           and a name part.
-        """
-        prefix = name[:LENGTH_PREFIX + 1]
-        while prefix and prefix[-1] != "/":
-            prefix = prefix[:-1]
-
-        name = name[len(prefix):]
-        prefix = prefix[:-1]
-
-        if not prefix or len(name) > LENGTH_NAME:
-            raise ValueError("name is too long")
-        return prefix, name
-
-    @staticmethod
-    def _create_header(info, format, encoding, errors):
-        """Return a header block. info is a dictionary with file
-           information, format must be one of the *_FORMAT constants.
-        """
-        parts = [
-            stn(info.get("name", ""), 100, encoding, errors),
-            itn(info.get("mode", 0) & 0o7777, 8, format),
-            itn(info.get("uid", 0), 8, format),
-            itn(info.get("gid", 0), 8, format),
-            itn(info.get("size", 0), 12, format),
-            itn(info.get("mtime", 0), 12, format),
-            b"        ", # checksum field
-            info.get("type", REGTYPE),
-            stn(info.get("linkname", ""), 100, encoding, errors),
-            info.get("magic", POSIX_MAGIC),
-            stn(info.get("uname", ""), 32, encoding, errors),
-            stn(info.get("gname", ""), 32, encoding, errors),
-            itn(info.get("devmajor", 0), 8, format),
-            itn(info.get("devminor", 0), 8, format),
-            stn(info.get("prefix", ""), 155, encoding, errors)
-        ]
-
-        buf = struct.pack("%ds" % BLOCKSIZE, b"".join(parts))
-        chksum = calc_chksums(buf[-BLOCKSIZE:])[0]
-        buf = buf[:-364] + ("%06o\0" % chksum).encode("ascii") + buf[-357:]
-        return buf
-
-    @staticmethod
-    def _create_payload(payload):
-        """Return the string payload filled with zero bytes
-           up to the next 512 byte border.
-        """
-        blocks, remainder = divmod(len(payload), BLOCKSIZE)
-        if remainder > 0:
-            payload += (BLOCKSIZE - remainder) * NUL
-        return payload
-
-    @classmethod
-    def _create_gnu_long_header(cls, name, type, encoding, errors):
-        """Return a GNUTYPE_LONGNAME or GNUTYPE_LONGLINK sequence
-           for name.
-        """
-        name = name.encode(encoding, errors) + NUL
-
-        info = {}
-        info["name"] = "././@LongLink"
-        info["type"] = type
-        info["size"] = len(name)
-        info["magic"] = GNU_MAGIC
-
-        # create extended header + name blocks.
-        return cls._create_header(info, USTAR_FORMAT, encoding, errors) + \
-                cls._create_payload(name)
-
-    @classmethod
-    def _create_pax_generic_header(cls, pax_headers, type, encoding):
-        """Return a POSIX.1-2008 extended or global header sequence
-           that contains a list of keyword, value pairs. The values
-           must be strings.
-        """
-        # Check if one of the fields contains surrogate characters and thereby
-        # forces hdrcharset=BINARY, see _proc_pax() for more information.
-        binary = False
-        for keyword, value in pax_headers.items():
-            try:
-                value.encode("utf8", "strict")
-            except UnicodeEncodeError:
-                binary = True
-                break
-
-        records = b""
-        if binary:
-            # Put the hdrcharset field at the beginning of the header.
-            records += b"21 hdrcharset=BINARY\n"
-
-        for keyword, value in pax_headers.items():
-            keyword = keyword.encode("utf8")
-            if binary:
-                # Try to restore the original byte representation of `value'.
-                # Needless to say, that the encoding must match the string.
-                value = value.encode(encoding, "surrogateescape")
-            else:
-                value = value.encode("utf8")
-
-            l = len(keyword) + len(value) + 3   # ' ' + '=' + '\n'
-            n = p = 0
-            while True:
-                n = l + len(str(p))
-                if n == p:
-                    break
-                p = n
-            records += bytes(str(p), "ascii") + b" " + keyword + b"=" + value + b"\n"
-
-        # We use a hardcoded "././@PaxHeader" name like star does
-        # instead of the one that POSIX recommends.
-        info = {}
-        info["name"] = "././@PaxHeader"
-        info["type"] = type
-        info["size"] = len(records)
-        info["magic"] = POSIX_MAGIC
-
-        # Create pax header + record blocks.
-        return cls._create_header(info, USTAR_FORMAT, "ascii", "replace") + \
-                cls._create_payload(records)
-
-    @classmethod
-    def frombuf(cls, buf, encoding, errors):
-        """Construct a TarInfo object from a 512 byte bytes object.
-        """
-        if len(buf) == 0:
-            raise EmptyHeaderError("empty header")
-        if len(buf) != BLOCKSIZE:
-            raise TruncatedHeaderError("truncated header")
-        if buf.count(NUL) == BLOCKSIZE:
-            raise EOFHeaderError("end of file header")
-
-        chksum = nti(buf[148:156])
-        if chksum not in calc_chksums(buf):
-            raise InvalidHeaderError("bad checksum")
-
-        obj = cls()
-        obj.name = nts(buf[0:100], encoding, errors)
-        obj.mode = nti(buf[100:108])
-        obj.uid = nti(buf[108:116])
-        obj.gid = nti(buf[116:124])
-        obj.size = nti(buf[124:136])
-        obj.mtime = nti(buf[136:148])
-        obj.chksum = chksum
-        obj.type = buf[156:157]
-        obj.linkname = nts(buf[157:257], encoding, errors)
-        obj.uname = nts(buf[265:297], encoding, errors)
-        obj.gname = nts(buf[297:329], encoding, errors)
-        obj.devmajor = nti(buf[329:337])
-        obj.devminor = nti(buf[337:345])
-        prefix = nts(buf[345:500], encoding, errors)
-
-        # Old V7 tar format represents a directory as a regular
-        # file with a trailing slash.
-        if obj.type == AREGTYPE and obj.name.endswith("/"):
-            obj.type = DIRTYPE
-
-        # The old GNU sparse format occupies some of the unused
-        # space in the buffer for up to 4 sparse structures.
-        # Save the them for later processing in _proc_sparse().
-        if obj.type == GNUTYPE_SPARSE:
-            pos = 386
-            structs = []
-            for i in range(4):
-                try:
-                    offset = nti(buf[pos:pos + 12])
-                    numbytes = nti(buf[pos + 12:pos + 24])
-                except ValueError:
-                    break
-                structs.append((offset, numbytes))
-                pos += 24
-            isextended = bool(buf[482])
-            origsize = nti(buf[483:495])
-            obj._sparse_structs = (structs, isextended, origsize)
-
-        # Remove redundant slashes from directories.
-        if obj.isdir():
-            obj.name = obj.name.rstrip("/")
-
-        # Reconstruct a ustar longname.
-        if prefix and obj.type not in GNU_TYPES:
-            obj.name = prefix + "/" + obj.name
-        return obj
-
-    @classmethod
-    def fromtarfile(cls, tarfile):
-        """Return the next TarInfo object from TarFile object
-           tarfile.
-        """
-        buf = tarfile.fileobj.read(BLOCKSIZE)
-        obj = cls.frombuf(buf, tarfile.encoding, tarfile.errors)
-        obj.offset = tarfile.fileobj.tell() - BLOCKSIZE
-        return obj._proc_member(tarfile)
-
-    #--------------------------------------------------------------------------
-    # The following are methods that are called depending on the type of a
-    # member. The entry point is _proc_member() which can be overridden in a
-    # subclass to add custom _proc_*() methods. A _proc_*() method MUST
-    # implement the following
-    # operations:
-    # 1. Set self.offset_data to the position where the data blocks begin,
-    #    if there is data that follows.
-    # 2. Set tarfile.offset to the position where the next member's header will
-    #    begin.
-    # 3. Return self or another valid TarInfo object.
-    def _proc_member(self, tarfile):
-        """Choose the right processing method depending on
-           the type and call it.
-        """
-        if self.type in (GNUTYPE_LONGNAME, GNUTYPE_LONGLINK):
-            return self._proc_gnulong(tarfile)
-        elif self.type == GNUTYPE_SPARSE:
-            return self._proc_sparse(tarfile)
-        elif self.type in (XHDTYPE, XGLTYPE, SOLARIS_XHDTYPE):
-            return self._proc_pax(tarfile)
-        else:
-            return self._proc_builtin(tarfile)
-
-    def _proc_builtin(self, tarfile):
-        """Process a builtin type or an unknown type which
-           will be treated as a regular file.
-        """
-        self.offset_data = tarfile.fileobj.tell()
-        offset = self.offset_data
-        if self.isreg() or self.type not in SUPPORTED_TYPES:
-            # Skip the following data blocks.
-            offset += self._block(self.size)
-        tarfile.offset = offset
-
-        # Patch the TarInfo object with saved global
-        # header information.
-        self._apply_pax_info(tarfile.pax_headers, tarfile.encoding, tarfile.errors)
-
-        return self
-
-    def _proc_gnulong(self, tarfile):
-        """Process the blocks that hold a GNU longname
-           or longlink member.
-        """
-        buf = tarfile.fileobj.read(self._block(self.size))
-
-        # Fetch the next header and process it.
-        try:
-            next = self.fromtarfile(tarfile)
-        except HeaderError:
-            raise SubsequentHeaderError("missing or bad subsequent header")
-
-        # Patch the TarInfo object from the next header with
-        # the longname information.
-        next.offset = self.offset
-        if self.type == GNUTYPE_LONGNAME:
-            next.name = nts(buf, tarfile.encoding, tarfile.errors)
-        elif self.type == GNUTYPE_LONGLINK:
-            next.linkname = nts(buf, tarfile.encoding, tarfile.errors)
-
-        return next
-
-    def _proc_sparse(self, tarfile):
-        """Process a GNU sparse header plus extra headers.
-        """
-        # We already collected some sparse structures in frombuf().
-        structs, isextended, origsize = self._sparse_structs
-        del self._sparse_structs
-
-        # Collect sparse structures from extended header blocks.
-        while isextended:
-            buf = tarfile.fileobj.read(BLOCKSIZE)
-            pos = 0
-            for i in range(21):
-                try:
-                    offset = nti(buf[pos:pos + 12])
-                    numbytes = nti(buf[pos + 12:pos + 24])
-                except ValueError:
-                    break
-                if offset and numbytes:
-                    structs.append((offset, numbytes))
-                pos += 24
-            isextended = bool(buf[504])
-        self.sparse = structs
-
-        self.offset_data = tarfile.fileobj.tell()
-        tarfile.offset = self.offset_data + self._block(self.size)
-        self.size = origsize
-        return self
-
-    def _proc_pax(self, tarfile):
-        """Process an extended or global header as described in
-           POSIX.1-2008.
-        """
-        # Read the header information.
-        buf = tarfile.fileobj.read(self._block(self.size))
-
-        # A pax header stores supplemental information for either
-        # the following file (extended) or all following files
-        # (global).
-        if self.type == XGLTYPE:
-            pax_headers = tarfile.pax_headers
-        else:
-            pax_headers = tarfile.pax_headers.copy()
-
-        # Check if the pax header contains a hdrcharset field. This tells us
-        # the encoding of the path, linkpath, uname and gname fields. Normally,
-        # these fields are UTF-8 encoded but since POSIX.1-2008 tar
-        # implementations are allowed to store them as raw binary strings if
-        # the translation to UTF-8 fails.
-        match = re.search(br"\d+ hdrcharset=([^\n]+)\n", buf)
-        if match is not None:
-            pax_headers["hdrcharset"] = match.group(1).decode("utf8")
-
-        # For the time being, we don't care about anything other than "BINARY".
-        # The only other value that is currently allowed by the standard is
-        # "ISO-IR 10646 2000 UTF-8" in other words UTF-8.
-        hdrcharset = pax_headers.get("hdrcharset")
-        if hdrcharset == "BINARY":
-            encoding = tarfile.encoding
-        else:
-            encoding = "utf8"
-
-        # Parse pax header information. A record looks like that:
-        # "%d %s=%s\n" % (length, keyword, value). length is the size
-        # of the complete record including the length field itself and
-        # the newline. keyword and value are both UTF-8 encoded strings.
-        regex = re.compile(br"(\d+) ([^=]+)=")
-        pos = 0
-        while True:
-            match = regex.match(buf, pos)
-            if not match:
-                break
-
-            length, keyword = match.groups()
-            length = int(length)
-            value = buf[match.end(2) + 1:match.start(1) + length - 1]
-
-            # Normally, we could just use "utf8" as the encoding and "strict"
-            # as the error handler, but we better not take the risk. For
-            # example, GNU tar <= 1.23 is known to store filenames it cannot
-            # translate to UTF-8 as raw strings (unfortunately without a
-            # hdrcharset=BINARY header).
-            # We first try the strict standard encoding, and if that fails we
-            # fall back on the user's encoding and error handler.
-            keyword = self._decode_pax_field(keyword, "utf8", "utf8",
-                    tarfile.errors)
-            if keyword in PAX_NAME_FIELDS:
-                value = self._decode_pax_field(value, encoding, tarfile.encoding,
-                        tarfile.errors)
-            else:
-                value = self._decode_pax_field(value, "utf8", "utf8",
-                        tarfile.errors)
-
-            pax_headers[keyword] = value
-            pos += length
-
-        # Fetch the next header.
-        try:
-            next = self.fromtarfile(tarfile)
-        except HeaderError:
-            raise SubsequentHeaderError("missing or bad subsequent header")
-
-        # Process GNU sparse information.
-        if "GNU.sparse.map" in pax_headers:
-            # GNU extended sparse format version 0.1.
-            self._proc_gnusparse_01(next, pax_headers)
-
-        elif "GNU.sparse.size" in pax_headers:
-            # GNU extended sparse format version 0.0.
-            self._proc_gnusparse_00(next, pax_headers, buf)
-
-        elif pax_headers.get("GNU.sparse.major") == "1" and pax_headers.get("GNU.sparse.minor") == "0":
-            # GNU extended sparse format version 1.0.
-            self._proc_gnusparse_10(next, pax_headers, tarfile)
-
-        if self.type in (XHDTYPE, SOLARIS_XHDTYPE):
-            # Patch the TarInfo object with the extended header info.
-            next._apply_pax_info(pax_headers, tarfile.encoding, tarfile.errors)
-            next.offset = self.offset
-
-            if "size" in pax_headers:
-                # If the extended header replaces the size field,
-                # we need to recalculate the offset where the next
-                # header starts.
-                offset = next.offset_data
-                if next.isreg() or next.type not in SUPPORTED_TYPES:
-                    offset += next._block(next.size)
-                tarfile.offset = offset
-
-        return next
-
-    def _proc_gnusparse_00(self, next, pax_headers, buf):
-        """Process a GNU tar extended sparse header, version 0.0.
-        """
-        offsets = []
-        for match in re.finditer(br"\d+ GNU.sparse.offset=(\d+)\n", buf):
-            offsets.append(int(match.group(1)))
-        numbytes = []
-        for match in re.finditer(br"\d+ GNU.sparse.numbytes=(\d+)\n", buf):
-            numbytes.append(int(match.group(1)))
-        next.sparse = list(zip(offsets, numbytes))
-
-    def _proc_gnusparse_01(self, next, pax_headers):
-        """Process a GNU tar extended sparse header, version 0.1.
-        """
-        sparse = [int(x) for x in pax_headers["GNU.sparse.map"].split(",")]
-        next.sparse = list(zip(sparse[::2], sparse[1::2]))
-
-    def _proc_gnusparse_10(self, next, pax_headers, tarfile):
-        """Process a GNU tar extended sparse header, version 1.0.
-        """
-        fields = None
-        sparse = []
-        buf = tarfile.fileobj.read(BLOCKSIZE)
-        fields, buf = buf.split(b"\n", 1)
-        fields = int(fields)
-        while len(sparse) < fields * 2:
-            if b"\n" not in buf:
-                buf += tarfile.fileobj.read(BLOCKSIZE)
-            number, buf = buf.split(b"\n", 1)
-            sparse.append(int(number))
-        next.offset_data = tarfile.fileobj.tell()
-        next.sparse = list(zip(sparse[::2], sparse[1::2]))
-
-    def _apply_pax_info(self, pax_headers, encoding, errors):
-        """Replace fields with supplemental information from a previous
-           pax extended or global header.
-        """
-        for keyword, value in pax_headers.items():
-            if keyword == "GNU.sparse.name":
-                setattr(self, "path", value)
-            elif keyword == "GNU.sparse.size":
-                setattr(self, "size", int(value))
-            elif keyword == "GNU.sparse.realsize":
-                setattr(self, "size", int(value))
-            elif keyword in PAX_FIELDS:
-                if keyword in PAX_NUMBER_FIELDS:
-                    try:
-                        value = PAX_NUMBER_FIELDS[keyword](value)
-                    except ValueError:
-                        value = 0
-                if keyword == "path":
-                    value = value.rstrip("/")
-                setattr(self, keyword, value)
-
-        self.pax_headers = pax_headers.copy()
-
-    def _decode_pax_field(self, value, encoding, fallback_encoding, fallback_errors):
-        """Decode a single field from a pax record.
-        """
-        try:
-            return value.decode(encoding, "strict")
-        except UnicodeDecodeError:
-            return value.decode(fallback_encoding, fallback_errors)
-
-    def _block(self, count):
-        """Round up a byte count by BLOCKSIZE and return it,
-           e.g. _block(834) => 1024.
-        """
-        blocks, remainder = divmod(count, BLOCKSIZE)
-        if remainder:
-            blocks += 1
-        return blocks * BLOCKSIZE
-
-    def isreg(self):
-        return self.type in REGULAR_TYPES
-    def isfile(self):
-        return self.isreg()
-    def isdir(self):
-        return self.type == DIRTYPE
-    def issym(self):
-        return self.type == SYMTYPE
-    def islnk(self):
-        return self.type == LNKTYPE
-    def ischr(self):
-        return self.type == CHRTYPE
-    def isblk(self):
-        return self.type == BLKTYPE
-    def isfifo(self):
-        return self.type == FIFOTYPE
-    def issparse(self):
-        return self.sparse is not None
-    def isdev(self):
-        return self.type in (CHRTYPE, BLKTYPE, FIFOTYPE)
-# class TarInfo
-
-class TarFile(object):
-    """The TarFile Class provides an interface to tar archives.
-    """
-
-    debug = 0                   # May be set from 0 (no msgs) to 3 (all msgs)
-
-    dereference = False         # If true, add content of linked file to the
-                                # tar file, else the link.
-
-    ignore_zeros = False        # If true, skips empty or invalid blocks and
-                                # continues processing.
-
-    errorlevel = 1              # If 0, fatal errors only appear in debug
-                                # messages (if debug >= 0). If > 0, errors
-                                # are passed to the caller as exceptions.
-
-    format = DEFAULT_FORMAT     # The format to use when creating an archive.
-
-    encoding = ENCODING         # Encoding for 8-bit character strings.
-
-    errors = None               # Error handler for unicode conversion.
-
-    tarinfo = TarInfo           # The default TarInfo class to use.
-
-    fileobject = ExFileObject   # The default ExFileObject class to use.
-
-    def __init__(self, name=None, mode="r", fileobj=None, format=None,
-            tarinfo=None, dereference=None, ignore_zeros=None, encoding=None,
-            errors="surrogateescape", pax_headers=None, debug=None, errorlevel=None):
-        """Open an (uncompressed) tar archive `name'. `mode' is either 'r' to
-           read from an existing archive, 'a' to append data to an existing
-           file or 'w' to create a new file overwriting an existing one. `mode'
-           defaults to 'r'.
-           If `fileobj' is given, it is used for reading or writing data. If it
-           can be determined, `mode' is overridden by `fileobj's mode.
-           `fileobj' is not closed, when TarFile is closed.
-        """
-        if len(mode) > 1 or mode not in "raw":
-            raise ValueError("mode must be 'r', 'a' or 'w'")
-        self.mode = mode
-        self._mode = {"r": "rb", "a": "r+b", "w": "wb"}[mode]
-
-        if not fileobj:
-            if self.mode == "a" and not os.path.exists(name):
-                # Create nonexistent files in append mode.
-                self.mode = "w"
-                self._mode = "wb"
-            fileobj = bltn_open(name, self._mode)
-            self._extfileobj = False
-        else:
-            if name is None and hasattr(fileobj, "name"):
-                name = fileobj.name
-            if hasattr(fileobj, "mode"):
-                self._mode = fileobj.mode
-            self._extfileobj = True
-        self.name = os.path.abspath(name) if name else None
-        self.fileobj = fileobj
-
-        # Init attributes.
-        if format is not None:
-            self.format = format
-        if tarinfo is not None:
-            self.tarinfo = tarinfo
-        if dereference is not None:
-            self.dereference = dereference
-        if ignore_zeros is not None:
-            self.ignore_zeros = ignore_zeros
-        if encoding is not None:
-            self.encoding = encoding
-        self.errors = errors
-
-        if pax_headers is not None and self.format == PAX_FORMAT:
-            self.pax_headers = pax_headers
-        else:
-            self.pax_headers = {}
-
-        if debug is not None:
-            self.debug = debug
-        if errorlevel is not None:
-            self.errorlevel = errorlevel
-
-        # Init datastructures.
-        self.closed = False
-        self.members = []       # list of members as TarInfo objects
-        self._loaded = False    # flag if all members have been read
-        self.offset = self.fileobj.tell()
-                                # current position in the archive file
-        self.inodes = {}        # dictionary caching the inodes of
-                                # archive members already added
-
-        try:
-            if self.mode == "r":
-                self.firstmember = None
-                self.firstmember = self.next()
-
-            if self.mode == "a":
-                # Move to the end of the archive,
-                # before the first empty block.
-                while True:
-                    self.fileobj.seek(self.offset)
-                    try:
-                        tarinfo = self.tarinfo.fromtarfile(self)
-                        self.members.append(tarinfo)
-                    except EOFHeaderError:
-                        self.fileobj.seek(self.offset)
-                        break
-                    except HeaderError as e:
-                        raise ReadError(str(e))
-
-            if self.mode in "aw":
-                self._loaded = True
-
-                if self.pax_headers:
-                    buf = self.tarinfo.create_pax_global_header(self.pax_headers.copy())
-                    self.fileobj.write(buf)
-                    self.offset += len(buf)
-        except:
-            if not self._extfileobj:
-                self.fileobj.close()
-            self.closed = True
-            raise
-
-    #--------------------------------------------------------------------------
-    # Below are the classmethods which act as alternate constructors to the
-    # TarFile class. The open() method is the only one that is needed for
-    # public use; it is the "super"-constructor and is able to select an
-    # adequate "sub"-constructor for a particular compression using the mapping
-    # from OPEN_METH.
-    #
-    # This concept allows one to subclass TarFile without losing the comfort of
-    # the super-constructor. A sub-constructor is registered and made available
-    # by adding it to the mapping in OPEN_METH.
-
-    @classmethod
-    def open(cls, name=None, mode="r", fileobj=None, bufsize=RECORDSIZE, **kwargs):
-        """Open a tar archive for reading, writing or appending. Return
-           an appropriate TarFile class.
-
-           mode:
-           'r' or 'r:*' open for reading with transparent compression
-           'r:'         open for reading exclusively uncompressed
-           'r:gz'       open for reading with gzip compression
-           'r:bz2'      open for reading with bzip2 compression
-           'a' or 'a:'  open for appending, creating the file if necessary
-           'w' or 'w:'  open for writing without compression
-           'w:gz'       open for writing with gzip compression
-           'w:bz2'      open for writing with bzip2 compression
-
-           'r|*'        open a stream of tar blocks with transparent compression
-           'r|'         open an uncompressed stream of tar blocks for reading
-           'r|gz'       open a gzip compressed stream of tar blocks
-           'r|bz2'      open a bzip2 compressed stream of tar blocks
-           'w|'         open an uncompressed stream for writing
-           'w|gz'       open a gzip compressed stream for writing
-           'w|bz2'      open a bzip2 compressed stream for writing
-        """
-
-        if not name and not fileobj:
-            raise ValueError("nothing to open")
-
-        if mode in ("r", "r:*"):
-            # Find out which *open() is appropriate for opening the file.
-            for comptype in cls.OPEN_METH:
-                func = getattr(cls, cls.OPEN_METH[comptype])
-                if fileobj is not None:
-                    saved_pos = fileobj.tell()
-                try:
-                    return func(name, "r", fileobj, **kwargs)
-                except (ReadError, CompressionError) as e:
-                    if fileobj is not None:
-                        fileobj.seek(saved_pos)
-                    continue
-            raise ReadError("file could not be opened successfully")
-
-        elif ":" in mode:
-            filemode, comptype = mode.split(":", 1)
-            filemode = filemode or "r"
-            comptype = comptype or "tar"
-
-            # Select the *open() function according to
-            # given compression.
-            if comptype in cls.OPEN_METH:
-                func = getattr(cls, cls.OPEN_METH[comptype])
-            else:
-                raise CompressionError("unknown compression type %r" % comptype)
-            return func(name, filemode, fileobj, **kwargs)
-
-        elif "|" in mode:
-            filemode, comptype = mode.split("|", 1)
-            filemode = filemode or "r"
-            comptype = comptype or "tar"
-
-            if filemode not in "rw":
-                raise ValueError("mode must be 'r' or 'w'")
-
-            stream = _Stream(name, filemode, comptype, fileobj, bufsize)
-            try:
-                t = cls(name, filemode, stream, **kwargs)
-            except:
-                stream.close()
-                raise
-            t._extfileobj = False
-            return t
-
-        elif mode in "aw":
-            return cls.taropen(name, mode, fileobj, **kwargs)
-
-        raise ValueError("undiscernible mode")
-
-    @classmethod
-    def taropen(cls, name, mode="r", fileobj=None, **kwargs):
-        """Open uncompressed tar archive name for reading or writing.
-        """
-        if len(mode) > 1 or mode not in "raw":
-            raise ValueError("mode must be 'r', 'a' or 'w'")
-        return cls(name, mode, fileobj, **kwargs)
-
-    @classmethod
-    def gzopen(cls, name, mode="r", fileobj=None, compresslevel=9, **kwargs):
-        """Open gzip compressed tar archive name for reading or writing.
-           Appending is not allowed.
-        """
-        if len(mode) > 1 or mode not in "rw":
-            raise ValueError("mode must be 'r' or 'w'")
-
-        try:
-            import gzip
-            gzip.GzipFile
-        except (ImportError, AttributeError):
-            raise CompressionError("gzip module is not available")
-
-        extfileobj = fileobj is not None
-        try:
-            fileobj = gzip.GzipFile(name, mode + "b", compresslevel, fileobj)
-            t = cls.taropen(name, mode, fileobj, **kwargs)
-        except IOError:
-            if not extfileobj and fileobj is not None:
-                fileobj.close()
-            if fileobj is None:
-                raise
-            raise ReadError("not a gzip file")
-        except:
-            if not extfileobj and fileobj is not None:
-                fileobj.close()
-            raise
-        t._extfileobj = extfileobj
-        return t
-
-    @classmethod
-    def bz2open(cls, name, mode="r", fileobj=None, compresslevel=9, **kwargs):
-        """Open bzip2 compressed tar archive name for reading or writing.
-           Appending is not allowed.
-        """
-        if len(mode) > 1 or mode not in "rw":
-            raise ValueError("mode must be 'r' or 'w'.")
-
-        try:
-            import bz2
-        except ImportError:
-            raise CompressionError("bz2 module is not available")
-
-        if fileobj is not None:
-            fileobj = _BZ2Proxy(fileobj, mode)
-        else:
-            fileobj = bz2.BZ2File(name, mode, compresslevel=compresslevel)
-
-        try:
-            t = cls.taropen(name, mode, fileobj, **kwargs)
-        except (IOError, EOFError):
-            fileobj.close()
-            raise ReadError("not a bzip2 file")
-        t._extfileobj = False
-        return t
-
-    # All *open() methods are registered here.
-    OPEN_METH = {
-        "tar": "taropen",   # uncompressed tar
-        "gz":  "gzopen",    # gzip compressed tar
-        "bz2": "bz2open"    # bzip2 compressed tar
-    }
-
-    #--------------------------------------------------------------------------
-    # The public methods which TarFile provides:
-
-    def close(self):
-        """Close the TarFile. In write-mode, two finishing zero blocks are
-           appended to the archive.
-        """
-        if self.closed:
-            return
-
-        if self.mode in "aw":
-            self.fileobj.write(NUL * (BLOCKSIZE * 2))
-            self.offset += (BLOCKSIZE * 2)
-            # fill up the end with zero-blocks
-            # (like option -b20 for tar does)
-            blocks, remainder = divmod(self.offset, RECORDSIZE)
-            if remainder > 0:
-                self.fileobj.write(NUL * (RECORDSIZE - remainder))
-
-        if not self._extfileobj:
-            self.fileobj.close()
-        self.closed = True
-
-    def getmember(self, name):
-        """Return a TarInfo object for member `name'. If `name' can not be
-           found in the archive, KeyError is raised. If a member occurs more
-           than once in the archive, its last occurrence is assumed to be the
-           most up-to-date version.
-        """
-        tarinfo = self._getmember(name)
-        if tarinfo is None:
-            raise KeyError("filename %r not found" % name)
-        return tarinfo
-
-    def getmembers(self):
-        """Return the members of the archive as a list of TarInfo objects. The
-           list has the same order as the members in the archive.
-        """
-        self._check()
-        if not self._loaded:    # if we want to obtain a list of
-            self._load()        # all members, we first have to
-                                # scan the whole archive.
-        return self.members
-
-    def getnames(self):
-        """Return the members of the archive as a list of their names. It has
-           the same order as the list returned by getmembers().
-        """
-        return [tarinfo.name for tarinfo in self.getmembers()]
-
-    def gettarinfo(self, name=None, arcname=None, fileobj=None):
-        """Create a TarInfo object for either the file `name' or the file
-           object `fileobj' (using os.fstat on its file descriptor). You can
-           modify some of the TarInfo's attributes before you add it using
-           addfile(). If given, `arcname' specifies an alternative name for the
-           file in the archive.
-        """
-        self._check("aw")
-
-        # When fileobj is given, replace name by
-        # fileobj's real name.
-        if fileobj is not None:
-            name = fileobj.name
-
-        # Building the name of the member in the archive.
-        # Backward slashes are converted to forward slashes,
-        # Absolute paths are turned to relative paths.
-        if arcname is None:
-            arcname = name
-        drv, arcname = os.path.splitdrive(arcname)
-        arcname = arcname.replace(os.sep, "/")
-        arcname = arcname.lstrip("/")
-
-        # Now, fill the TarInfo object with
-        # information specific for the file.
-        tarinfo = self.tarinfo()
-        tarinfo.tarfile = self
-
-        # Use os.stat or os.lstat, depending on platform
-        # and if symlinks shall be resolved.
-        if fileobj is None:
-            if hasattr(os, "lstat") and not self.dereference:
-                statres = os.lstat(name)
-            else:
-                statres = os.stat(name)
-        else:
-            statres = os.fstat(fileobj.fileno())
-        linkname = ""
-
-        stmd = statres.st_mode
-        if stat.S_ISREG(stmd):
-            inode = (statres.st_ino, statres.st_dev)
-            if not self.dereference and statres.st_nlink > 1 and \
-                    inode in self.inodes and arcname != self.inodes[inode]:
-                # Is it a hardlink to an already
-                # archived file?
-                type = LNKTYPE
-                linkname = self.inodes[inode]
-            else:
-                # The inode is added only if its valid.
-                # For win32 it is always 0.
-                type = REGTYPE
-                if inode[0]:
-                    self.inodes[inode] = arcname
-        elif stat.S_ISDIR(stmd):
-            type = DIRTYPE
-        elif stat.S_ISFIFO(stmd):
-            type = FIFOTYPE
-        elif stat.S_ISLNK(stmd):
-            type = SYMTYPE
-            linkname = os.readlink(name)
-        elif stat.S_ISCHR(stmd):
-            type = CHRTYPE
-        elif stat.S_ISBLK(stmd):
-            type = BLKTYPE
-        else:
-            return None
-
-        # Fill the TarInfo object with all
-        # information we can get.
-        tarinfo.name = arcname
-        tarinfo.mode = stmd
-        tarinfo.uid = statres.st_uid
-        tarinfo.gid = statres.st_gid
-        if type == REGTYPE:
-            tarinfo.size = statres.st_size
-        else:
-            tarinfo.size = 0
-        tarinfo.mtime = statres.st_mtime
-        tarinfo.type = type
-        tarinfo.linkname = linkname
-        if pwd:
-            try:
-                tarinfo.uname = pwd.getpwuid(tarinfo.uid)[0]
-            except KeyError:
-                pass
-        if grp:
-            try:
-                tarinfo.gname = grp.getgrgid(tarinfo.gid)[0]
-            except KeyError:
-                pass
-
-        if type in (CHRTYPE, BLKTYPE):
-            if hasattr(os, "major") and hasattr(os, "minor"):
-                tarinfo.devmajor = os.major(statres.st_rdev)
-                tarinfo.devminor = os.minor(statres.st_rdev)
-        return tarinfo
-
-    def list(self, verbose=True):
-        """Print a table of contents to sys.stdout. If `verbose' is False, only
-           the names of the members are printed. If it is True, an `ls -l'-like
-           output is produced.
-        """
-        self._check()
-
-        for tarinfo in self:
-            if verbose:
-                print(filemode(tarinfo.mode), end=' ')
-                print("%s/%s" % (tarinfo.uname or tarinfo.uid,
-                                 tarinfo.gname or tarinfo.gid), end=' ')
-                if tarinfo.ischr() or tarinfo.isblk():
-                    print("%10s" % ("%d,%d" \
-                                    % (tarinfo.devmajor, tarinfo.devminor)), end=' ')
-                else:
-                    print("%10d" % tarinfo.size, end=' ')
-                print("%d-%02d-%02d %02d:%02d:%02d" \
-                      % time.localtime(tarinfo.mtime)[:6], end=' ')
-
-            print(tarinfo.name + ("/" if tarinfo.isdir() else ""), end=' ')
-
-            if verbose:
-                if tarinfo.issym():
-                    print("->", tarinfo.linkname, end=' ')
-                if tarinfo.islnk():
-                    print("link to", tarinfo.linkname, end=' ')
-            print()
-
-    def add(self, name, arcname=None, recursive=True, exclude=None, filter=None):
-        """Add the file `name' to the archive. `name' may be any type of file
-           (directory, fifo, symbolic link, etc.). If given, `arcname'
-           specifies an alternative name for the file in the archive.
-           Directories are added recursively by default. This can be avoided by
-           setting `recursive' to False. `exclude' is a function that should
-           return True for each filename to be excluded. `filter' is a function
-           that expects a TarInfo object argument and returns the changed
-           TarInfo object, if it returns None the TarInfo object will be
-           excluded from the archive.
-        """
-        self._check("aw")
-
-        if arcname is None:
-            arcname = name
-
-        # Exclude pathnames.
-        if exclude is not None:
-            import warnings
-            warnings.warn("use the filter argument instead",
-                    DeprecationWarning, 2)
-            if exclude(name):
-                self._dbg(2, "tarfile: Excluded %r" % name)
-                return
-
-        # Skip if somebody tries to archive the archive...
-        if self.name is not None and os.path.abspath(name) == self.name:
-            self._dbg(2, "tarfile: Skipped %r" % name)
-            return
-
-        self._dbg(1, name)
-
-        # Create a TarInfo object from the file.
-        tarinfo = self.gettarinfo(name, arcname)
-
-        if tarinfo is None:
-            self._dbg(1, "tarfile: Unsupported type %r" % name)
-            return
-
-        # Change or exclude the TarInfo object.
-        if filter is not None:
-            tarinfo = filter(tarinfo)
-            if tarinfo is None:
-                self._dbg(2, "tarfile: Excluded %r" % name)
-                return
-
-        # Append the tar header and data to the archive.
-        if tarinfo.isreg():
-            f = bltn_open(name, "rb")
-            self.addfile(tarinfo, f)
-            f.close()
-
-        elif tarinfo.isdir():
-            self.addfile(tarinfo)
-            if recursive:
-                for f in os.listdir(name):
-                    self.add(os.path.join(name, f), os.path.join(arcname, f),
-                            recursive, exclude, filter=filter)
-
-        else:
-            self.addfile(tarinfo)
-
-    def addfile(self, tarinfo, fileobj=None):
-        """Add the TarInfo object `tarinfo' to the archive. If `fileobj' is
-           given, tarinfo.size bytes are read from it and added to the archive.
-           You can create TarInfo objects using gettarinfo().
-           On Windows platforms, `fileobj' should always be opened with mode
-           'rb' to avoid irritation about the file size.
-        """
-        self._check("aw")
-
-        tarinfo = copy.copy(tarinfo)
-
-        buf = tarinfo.tobuf(self.format, self.encoding, self.errors)
-        self.fileobj.write(buf)
-        self.offset += len(buf)
-
-        # If there's data to follow, append it.
-        if fileobj is not None:
-            copyfileobj(fileobj, self.fileobj, tarinfo.size)
-            blocks, remainder = divmod(tarinfo.size, BLOCKSIZE)
-            if remainder > 0:
-                self.fileobj.write(NUL * (BLOCKSIZE - remainder))
-                blocks += 1
-            self.offset += blocks * BLOCKSIZE
-
-        self.members.append(tarinfo)
-
-    def extractall(self, path=".", members=None):
-        """Extract all members from the archive to the current working
-           directory and set owner, modification time and permissions on
-           directories afterwards. `path' specifies a different directory
-           to extract to. `members' is optional and must be a subset of the
-           list returned by getmembers().
-        """
-        directories = []
-
-        if members is None:
-            members = self
-
-        for tarinfo in members:
-            if tarinfo.isdir():
-                # Extract directories with a safe mode.
-                directories.append(tarinfo)
-                tarinfo = copy.copy(tarinfo)
-                tarinfo.mode = 0o700
-            # Do not set_attrs directories, as we will do that further down
-            self.extract(tarinfo, path, set_attrs=not tarinfo.isdir())
-
-        # Reverse sort directories.
-        directories.sort(key=lambda a: a.name)
-        directories.reverse()
-
-        # Set correct owner, mtime and filemode on directories.
-        for tarinfo in directories:
-            dirpath = os.path.join(path, tarinfo.name)
-            try:
-                self.chown(tarinfo, dirpath)
-                self.utime(tarinfo, dirpath)
-                self.chmod(tarinfo, dirpath)
-            except ExtractError as e:
-                if self.errorlevel > 1:
-                    raise
-                else:
-                    self._dbg(1, "tarfile: %s" % e)
-
-    def extract(self, member, path="", set_attrs=True):
-        """Extract a member from the archive to the current working directory,
-           using its full name. Its file information is extracted as accurately
-           as possible. `member' may be a filename or a TarInfo object. You can
-           specify a different directory using `path'. File attributes (owner,
-           mtime, mode) are set unless `set_attrs' is False.
-        """
-        self._check("r")
-
-        if isinstance(member, str):
-            tarinfo = self.getmember(member)
-        else:
-            tarinfo = member
-
-        # Prepare the link target for makelink().
-        if tarinfo.islnk():
-            tarinfo._link_target = os.path.join(path, tarinfo.linkname)
-
-        try:
-            self._extract_member(tarinfo, os.path.join(path, tarinfo.name),
-                                 set_attrs=set_attrs)
-        except EnvironmentError as e:
-            if self.errorlevel > 0:
-                raise
-            else:
-                if e.filename is None:
-                    self._dbg(1, "tarfile: %s" % e.strerror)
-                else:
-                    self._dbg(1, "tarfile: %s %r" % (e.strerror, e.filename))
-        except ExtractError as e:
-            if self.errorlevel > 1:
-                raise
-            else:
-                self._dbg(1, "tarfile: %s" % e)
-
-    def extractfile(self, member):
-        """Extract a member from the archive as a file object. `member' may be
-           a filename or a TarInfo object. If `member' is a regular file, a
-           file-like object is returned. If `member' is a link, a file-like
-           object is constructed from the link's target. If `member' is none of
-           the above, None is returned.
-           The file-like object is read-only and provides the following
-           methods: read(), readline(), readlines(), seek() and tell()
-        """
-        self._check("r")
-
-        if isinstance(member, str):
-            tarinfo = self.getmember(member)
-        else:
-            tarinfo = member
-
-        if tarinfo.isreg():
-            return self.fileobject(self, tarinfo)
-
-        elif tarinfo.type not in SUPPORTED_TYPES:
-            # If a member's type is unknown, it is treated as a
-            # regular file.
-            return self.fileobject(self, tarinfo)
-
-        elif tarinfo.islnk() or tarinfo.issym():
-            if isinstance(self.fileobj, _Stream):
-                # A small but ugly workaround for the case that someone tries
-                # to extract a (sym)link as a file-object from a non-seekable
-                # stream of tar blocks.
-                raise StreamError("cannot extract (sym)link as file object")
-            else:
-                # A (sym)link's file object is its target's file object.
-                return self.extractfile(self._find_link_target(tarinfo))
-        else:
-            # If there's no data associated with the member (directory, chrdev,
-            # blkdev, etc.), return None instead of a file object.
-            return None
-
-    def _extract_member(self, tarinfo, targetpath, set_attrs=True):
-        """Extract the TarInfo object tarinfo to a physical
-           file called targetpath.
-        """
-        # Fetch the TarInfo object for the given name
-        # and build the destination pathname, replacing
-        # forward slashes to platform specific separators.
-        targetpath = targetpath.rstrip("/")
-        targetpath = targetpath.replace("/", os.sep)
-
-        # Create all upper directories.
-        upperdirs = os.path.dirname(targetpath)
-        if upperdirs and not os.path.exists(upperdirs):
-            # Create directories that are not part of the archive with
-            # default permissions.
-            os.makedirs(upperdirs)
-
-        if tarinfo.islnk() or tarinfo.issym():
-            self._dbg(1, "%s -> %s" % (tarinfo.name, tarinfo.linkname))
-        else:
-            self._dbg(1, tarinfo.name)
-
-        if tarinfo.isreg():
-            self.makefile(tarinfo, targetpath)
-        elif tarinfo.isdir():
-            self.makedir(tarinfo, targetpath)
-        elif tarinfo.isfifo():
-            self.makefifo(tarinfo, targetpath)
-        elif tarinfo.ischr() or tarinfo.isblk():
-            self.makedev(tarinfo, targetpath)
-        elif tarinfo.islnk() or tarinfo.issym():
-            self.makelink(tarinfo, targetpath)
-        elif tarinfo.type not in SUPPORTED_TYPES:
-            self.makeunknown(tarinfo, targetpath)
-        else:
-            self.makefile(tarinfo, targetpath)
-
-        if set_attrs:
-            self.chown(tarinfo, targetpath)
-            if not tarinfo.issym():
-                self.chmod(tarinfo, targetpath)
-                self.utime(tarinfo, targetpath)
-
-    #--------------------------------------------------------------------------
-    # Below are the different file methods. They are called via
-    # _extract_member() when extract() is called. They can be replaced in a
-    # subclass to implement other functionality.
-
-    def makedir(self, tarinfo, targetpath):
-        """Make a directory called targetpath.
-        """
-        try:
-            # Use a safe mode for the directory, the real mode is set
-            # later in _extract_member().
-            os.mkdir(targetpath, 0o700)
-        except EnvironmentError as e:
-            if e.errno != errno.EEXIST:
-                raise
-
-    def makefile(self, tarinfo, targetpath):
-        """Make a file called targetpath.
-        """
-        source = self.fileobj
-        source.seek(tarinfo.offset_data)
-        target = bltn_open(targetpath, "wb")
-        if tarinfo.sparse is not None:
-            for offset, size in tarinfo.sparse:
-                target.seek(offset)
-                copyfileobj(source, target, size)
-        else:
-            copyfileobj(source, target, tarinfo.size)
-        target.seek(tarinfo.size)
-        target.truncate()
-        target.close()
-
-    def makeunknown(self, tarinfo, targetpath):
-        """Make a file from a TarInfo object with an unknown type
-           at targetpath.
-        """
-        self.makefile(tarinfo, targetpath)
-        self._dbg(1, "tarfile: Unknown file type %r, " \
-                     "extracted as regular file." % tarinfo.type)
-
-    def makefifo(self, tarinfo, targetpath):
-        """Make a fifo called targetpath.
-        """
-        if hasattr(os, "mkfifo"):
-            os.mkfifo(targetpath)
-        else:
-            raise ExtractError("fifo not supported by system")
-
-    def makedev(self, tarinfo, targetpath):
-        """Make a character or block device called targetpath.
-        """
-        if not hasattr(os, "mknod") or not hasattr(os, "makedev"):
-            raise ExtractError("special devices not supported by system")
-
-        mode = tarinfo.mode
-        if tarinfo.isblk():
-            mode |= stat.S_IFBLK
-        else:
-            mode |= stat.S_IFCHR
-
-        os.mknod(targetpath, mode,
-                 os.makedev(tarinfo.devmajor, tarinfo.devminor))
-
-    def makelink(self, tarinfo, targetpath):
-        """Make a (symbolic) link called targetpath. If it cannot be created
-          (platform limitation), we try to make a copy of the referenced file
-          instead of a link.
-        """
-        try:
-            # For systems that support symbolic and hard links.
-            if tarinfo.issym():
-                os.symlink(tarinfo.linkname, targetpath)
-            else:
-                # See extract().
-                if os.path.exists(tarinfo._link_target):
-                    os.link(tarinfo._link_target, targetpath)
-                else:
-                    self._extract_member(self._find_link_target(tarinfo),
-                                         targetpath)
-        except symlink_exception:
-            if tarinfo.issym():
-                linkpath = os.path.join(os.path.dirname(tarinfo.name),
-                                        tarinfo.linkname)
-            else:
-                linkpath = tarinfo.linkname
-        else:
-            try:
-                self._extract_member(self._find_link_target(tarinfo),
-                                     targetpath)
-            except KeyError:
-                raise ExtractError("unable to resolve link inside archive")
-
-    def chown(self, tarinfo, targetpath):
-        """Set owner of targetpath according to tarinfo.
-        """
-        if pwd and hasattr(os, "geteuid") and os.geteuid() == 0:
-            # We have to be root to do so.
-            try:
-                g = grp.getgrnam(tarinfo.gname)[2]
-            except KeyError:
-                g = tarinfo.gid
-            try:
-                u = pwd.getpwnam(tarinfo.uname)[2]
-            except KeyError:
-                u = tarinfo.uid
-            try:
-                if tarinfo.issym() and hasattr(os, "lchown"):
-                    os.lchown(targetpath, u, g)
-                else:
-                    if sys.platform != "os2emx":
-                        os.chown(targetpath, u, g)
-            except EnvironmentError as e:
-                raise ExtractError("could not change owner")
-
-    def chmod(self, tarinfo, targetpath):
-        """Set file permissions of targetpath according to tarinfo.
-        """
-        if hasattr(os, 'chmod'):
-            try:
-                os.chmod(targetpath, tarinfo.mode)
-            except EnvironmentError as e:
-                raise ExtractError("could not change mode")
-
-    def utime(self, tarinfo, targetpath):
-        """Set modification time of targetpath according to tarinfo.
-        """
-        if not hasattr(os, 'utime'):
-            return
-        try:
-            os.utime(targetpath, (tarinfo.mtime, tarinfo.mtime))
-        except EnvironmentError as e:
-            raise ExtractError("could not change modification time")
-
-    #--------------------------------------------------------------------------
-    def next(self):
-        """Return the next member of the archive as a TarInfo object, when
-           TarFile is opened for reading. Return None if there is no more
-           available.
-        """
-        self._check("ra")
-        if self.firstmember is not None:
-            m = self.firstmember
-            self.firstmember = None
-            return m
-
-        # Read the next block.
-        self.fileobj.seek(self.offset)
-        tarinfo = None
-        while True:
-            try:
-                tarinfo = self.tarinfo.fromtarfile(self)
-            except EOFHeaderError as e:
-                if self.ignore_zeros:
-                    self._dbg(2, "0x%X: %s" % (self.offset, e))
-                    self.offset += BLOCKSIZE
-                    continue
-            except InvalidHeaderError as e:
-                if self.ignore_zeros:
-                    self._dbg(2, "0x%X: %s" % (self.offset, e))
-                    self.offset += BLOCKSIZE
-                    continue
-                elif self.offset == 0:
-                    raise ReadError(str(e))
-            except EmptyHeaderError:
-                if self.offset == 0:
-                    raise ReadError("empty file")
-            except TruncatedHeaderError as e:
-                if self.offset == 0:
-                    raise ReadError(str(e))
-            except SubsequentHeaderError as e:
-                raise ReadError(str(e))
-            break
-
-        if tarinfo is not None:
-            self.members.append(tarinfo)
-        else:
-            self._loaded = True
-
-        return tarinfo
-
-    #--------------------------------------------------------------------------
-    # Little helper methods:
-
-    def _getmember(self, name, tarinfo=None, normalize=False):
-        """Find an archive member by name from bottom to top.
-           If tarinfo is given, it is used as the starting point.
-        """
-        # Ensure that all members have been loaded.
-        members = self.getmembers()
-
-        # Limit the member search list up to tarinfo.
-        if tarinfo is not None:
-            members = members[:members.index(tarinfo)]
-
-        if normalize:
-            name = os.path.normpath(name)
-
-        for member in reversed(members):
-            if normalize:
-                member_name = os.path.normpath(member.name)
-            else:
-                member_name = member.name
-
-            if name == member_name:
-                return member
-
-    def _load(self):
-        """Read through the entire archive file and look for readable
-           members.
-        """
-        while True:
-            tarinfo = self.next()
-            if tarinfo is None:
-                break
-        self._loaded = True
-
-    def _check(self, mode=None):
-        """Check if TarFile is still open, and if the operation's mode
-           corresponds to TarFile's mode.
-        """
-        if self.closed:
-            raise IOError("%s is closed" % self.__class__.__name__)
-        if mode is not None and self.mode not in mode:
-            raise IOError("bad operation for mode %r" % self.mode)
-
-    def _find_link_target(self, tarinfo):
-        """Find the target member of a symlink or hardlink member in the
-           archive.
-        """
-        if tarinfo.issym():
-            # Always search the entire archive.
-            linkname = os.path.dirname(tarinfo.name) + "/" + tarinfo.linkname
-            limit = None
-        else:
-            # Search the archive before the link, because a hard link is
-            # just a reference to an already archived file.
-            linkname = tarinfo.linkname
-            limit = tarinfo
-
-        member = self._getmember(linkname, tarinfo=limit, normalize=True)
-        if member is None:
-            raise KeyError("linkname %r not found" % linkname)
-        return member
-
-    def __iter__(self):
-        """Provide an iterator object.
-        """
-        if self._loaded:
-            return iter(self.members)
-        else:
-            return TarIter(self)
-
-    def _dbg(self, level, msg):
-        """Write debugging output to sys.stderr.
-        """
-        if level <= self.debug:
-            print(msg, file=sys.stderr)
-
-    def __enter__(self):
-        self._check()
-        return self
-
-    def __exit__(self, type, value, traceback):
-        if type is None:
-            self.close()
-        else:
-            # An exception occurred. We must not call close() because
-            # it would try to write end-of-archive blocks and padding.
-            if not self._extfileobj:
-                self.fileobj.close()
-            self.closed = True
-# class TarFile
-
-class TarIter(object):
-    """Iterator Class.
-
-       for tarinfo in TarFile(...):
-           suite...
-    """
-
-    def __init__(self, tarfile):
-        """Construct a TarIter object.
-        """
-        self.tarfile = tarfile
-        self.index = 0
-    def __iter__(self):
-        """Return iterator object.
-        """
-        return self
-
-    def __next__(self):
-        """Return the next item using TarFile's next() method.
-           When all members have been read, set TarFile as _loaded.
-        """
-        # Fix for SF #1100429: Under rare circumstances it can
-        # happen that getmembers() is called during iteration,
-        # which will cause TarIter to stop prematurely.
-        if not self.tarfile._loaded:
-            tarinfo = self.tarfile.next()
-            if not tarinfo:
-                self.tarfile._loaded = True
-                raise StopIteration
-        else:
-            try:
-                tarinfo = self.tarfile.members[self.index]
-            except IndexError:
-                raise StopIteration
-        self.index += 1
-        return tarinfo
-
-    next = __next__ # for Python 2.x
-
-#--------------------
-# exported functions
-#--------------------
-def is_tarfile(name):
-    """Return True if name points to a tar archive that we
-       are able to handle, else return False.
-    """
-    try:
-        t = open(name)
-        t.close()
-        return True
-    except TarError:
-        return False
-
-bltn_open = open
-open = TarFile.open
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/compat.py b/env/Lib/site-packages/pip/_vendor/distlib/compat.py
index c316fd97..1fe3d225 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/compat.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/compat.py
@@ -22,7 +22,6 @@ if sys.version_info[0] < 3:  # pragma: no cover
     from types import FileType as file_type
     import __builtin__ as builtins
     import ConfigParser as configparser
-    from ._backport import shutil
     from urlparse import urlparse, urlunparse, urljoin, urlsplit, urlunsplit
     from urllib import (urlretrieve, quote as _quote, unquote, url2pathname,
                         pathname2url, ContentTooShortError, splittype)
@@ -48,17 +47,18 @@ if sys.version_info[0] < 3:  # pragma: no cover
     from itertools import ifilter as filter
     from itertools import ifilterfalse as filterfalse
 
-    _userprog = None
-    def splituser(host):
-        """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'."""
-        global _userprog
-        if _userprog is None:
-            import re
-            _userprog = re.compile('^(.*)@(.*)$')
+    # Leaving this around for now, in case it needs resurrecting in some way
+    # _userprog = None
+    # def splituser(host):
+        # """splituser('user[:passwd]@host[:port]') --> 'user[:passwd]', 'host[:port]'."""
+        # global _userprog
+        # if _userprog is None:
+            # import re
+            # _userprog = re.compile('^(.*)@(.*)$')
 
-        match = _userprog.match(host)
-        if match: return match.group(1, 2)
-        return None, host
+        # match = _userprog.match(host)
+        # if match: return match.group(1, 2)
+        # return None, host
 
 else:  # pragma: no cover
     from io import StringIO
@@ -68,7 +68,7 @@ else:  # pragma: no cover
     import builtins
     import configparser
     import shutil
-    from urllib.parse import (urlparse, urlunparse, urljoin, splituser, quote,
+    from urllib.parse import (urlparse, urlunparse, urljoin, quote,
                               unquote, urlsplit, urlunsplit, splittype)
     from urllib.request import (urlopen, urlretrieve, Request, url2pathname,
                                 pathname2url,
@@ -88,6 +88,7 @@ else:  # pragma: no cover
     from itertools import filterfalse
     filter = filter
 
+
 try:
     from ssl import match_hostname, CertificateError
 except ImportError: # pragma: no cover
@@ -311,10 +312,8 @@ except ImportError: # pragma: no cover
             return 'IronPython'
         return 'CPython'
 
-try:
-    import sysconfig
-except ImportError: # pragma: no cover
-    from ._backport import sysconfig
+import shutil
+import sysconfig
 
 try:
     callable = callable
@@ -616,18 +615,15 @@ except ImportError: # pragma: no cover
 try:
     from importlib.util import cache_from_source  # Python >= 3.4
 except ImportError:  # pragma: no cover
-    try:
-        from imp import cache_from_source
-    except ImportError:  # pragma: no cover
-        def cache_from_source(path, debug_override=None):
-            assert path.endswith('.py')
-            if debug_override is None:
-                debug_override = __debug__
-            if debug_override:
-                suffix = 'c'
-            else:
-                suffix = 'o'
-            return path + suffix
+    def cache_from_source(path, debug_override=None):
+        assert path.endswith('.py')
+        if debug_override is None:
+            debug_override = __debug__
+        if debug_override:
+            suffix = 'c'
+        else:
+            suffix = 'o'
+        return path + suffix
 
 try:
     from collections import OrderedDict
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/database.py b/env/Lib/site-packages/pip/_vendor/distlib/database.py
index 0a90c300..5db5d7f5 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/database.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/database.py
@@ -132,29 +132,35 @@ class DistributionPath(object):
                 r = finder.find(entry)
                 if not r or r.path in seen:
                     continue
-                if self._include_dist and entry.endswith(DISTINFO_EXT):
-                    possible_filenames = [METADATA_FILENAME,
-                                          WHEEL_METADATA_FILENAME,
-                                          LEGACY_METADATA_FILENAME]
-                    for metadata_filename in possible_filenames:
-                        metadata_path = posixpath.join(entry, metadata_filename)
-                        pydist = finder.find(metadata_path)
-                        if pydist:
-                            break
-                    else:
-                        continue
+                try:
+                    if self._include_dist and entry.endswith(DISTINFO_EXT):
+                        possible_filenames = [METADATA_FILENAME,
+                                              WHEEL_METADATA_FILENAME,
+                                              LEGACY_METADATA_FILENAME]
+                        for metadata_filename in possible_filenames:
+                            metadata_path = posixpath.join(entry, metadata_filename)
+                            pydist = finder.find(metadata_path)
+                            if pydist:
+                                break
+                        else:
+                            continue
 
-                    with contextlib.closing(pydist.as_stream()) as stream:
-                        metadata = Metadata(fileobj=stream, scheme='legacy')
-                    logger.debug('Found %s', r.path)
-                    seen.add(r.path)
-                    yield new_dist_class(r.path, metadata=metadata,
-                                         env=self)
-                elif self._include_egg and entry.endswith(('.egg-info',
-                                                          '.egg')):
-                    logger.debug('Found %s', r.path)
-                    seen.add(r.path)
-                    yield old_dist_class(r.path, self)
+                        with contextlib.closing(pydist.as_stream()) as stream:
+                            metadata = Metadata(fileobj=stream, scheme='legacy')
+                        logger.debug('Found %s', r.path)
+                        seen.add(r.path)
+                        yield new_dist_class(r.path, metadata=metadata,
+                                             env=self)
+                    elif self._include_egg and entry.endswith(('.egg-info',
+                                                              '.egg')):
+                        logger.debug('Found %s', r.path)
+                        seen.add(r.path)
+                        yield old_dist_class(r.path, self)
+                except Exception as e:
+                    msg = 'Unable to read distribution at %s, perhaps due to bad metadata: %s'
+                    logger.warning(msg, r.path, e)
+                    import warnings
+                    warnings.warn(msg % (r.path, e), stacklevel=2)
 
     def _generate_cache(self):
         """
@@ -379,8 +385,9 @@ class Distribution(object):
 
     def _get_requirements(self, req_attr):
         md = self.metadata
-        logger.debug('Getting requirements from metadata %r', md.todict())
         reqts = getattr(md, req_attr)
+        logger.debug('%s: got requirements %r from metadata: %r', self.name, req_attr,
+                     reqts)
         return set(md.get_requirements(reqts, extras=self.extras,
                                        env=self.context))
 
@@ -1308,22 +1315,26 @@ def get_required_dists(dists, dist):
 
     :param dists: a list of distributions
     :param dist: a distribution, member of *dists* for which we are interested
+                 in finding the dependencies.
     """
     if dist not in dists:
         raise DistlibException('given distribution %r is not a member '
                                'of the list' % dist.name)
     graph = make_graph(dists)
 
-    req = []  # required distributions
+    req = set()  # required distributions
     todo = graph.adjacency_list[dist]  # list of nodes we should inspect
+    seen = set(t[0] for t in todo) # already added to todo
 
     while todo:
         d = todo.pop()[0]
-        req.append(d)
-        for pred in graph.adjacency_list[d]:
-            if pred not in req:
+        req.add(d)
+        pred_list = graph.adjacency_list[d]
+        for pred in pred_list:
+            d = pred[0]
+            if d not in req and d not in seen:
+                seen.add(d)
                 todo.append(pred)
-
     return req
 
 
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/index.py b/env/Lib/site-packages/pip/_vendor/distlib/index.py
index 7a87cdcf..9b6d129e 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/index.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/index.py
@@ -12,13 +12,13 @@ import subprocess
 import tempfile
 try:
     from threading import Thread
-except ImportError:
+except ImportError:  # pragma: no cover
     from dummy_threading import Thread
 
 from . import DistlibException
 from .compat import (HTTPBasicAuthHandler, Request, HTTPPasswordMgr,
                      urlparse, build_opener, string_types)
-from .util import cached_property, zip_dir, ServerProxy
+from .util import zip_dir, ServerProxy
 
 logger = logging.getLogger(__name__)
 
@@ -67,21 +67,17 @@ class PackageIndex(object):
         Get the distutils command for interacting with PyPI configurations.
         :return: the command.
         """
-        from distutils.core import Distribution
-        from distutils.config import PyPIRCCommand
-        d = Distribution()
-        return PyPIRCCommand(d)
+        from .util import _get_pypirc_command as cmd
+        return cmd()
 
     def read_configuration(self):
         """
-        Read the PyPI access configuration as supported by distutils, getting
-        PyPI to do the actual work. This populates ``username``, ``password``,
-        ``realm`` and ``url`` attributes from the configuration.
+        Read the PyPI access configuration as supported by distutils. This populates
+        ``username``, ``password``, ``realm`` and ``url`` attributes from the
+        configuration.
         """
-        # get distutils to do the work
-        c = self._get_pypirc_command()
-        c.repository = self.url
-        cfg = c._read_pypirc()
+        from .util import _load_pypirc
+        cfg = _load_pypirc(self)
         self.username = cfg.get('username')
         self.password = cfg.get('password')
         self.realm = cfg.get('realm', 'pypi')
@@ -91,13 +87,10 @@ class PackageIndex(object):
         """
         Save the PyPI access configuration. You must have set ``username`` and
         ``password`` attributes before calling this method.
-
-        Again, distutils is used to do the actual work.
         """
         self.check_credentials()
-        # get distutils to do the work
-        c = self._get_pypirc_command()
-        c._store_pypirc(self.username, self.password)
+        from .util import _store_pypirc
+        _store_pypirc(self)
 
     def check_credentials(self):
         """
@@ -111,7 +104,7 @@ class PackageIndex(object):
         pm.add_password(self.realm, netloc, self.username, self.password)
         self.password_handler = HTTPBasicAuthHandler(pm)
 
-    def register(self, metadata):
+    def register(self, metadata):  # pragma: no cover
         """
         Register a distribution on PyPI, using the provided metadata.
 
@@ -149,8 +142,7 @@ class PackageIndex(object):
             logger.debug('%s: %s' % (name, s))
         stream.close()
 
-    def get_sign_command(self, filename, signer, sign_password,
-                         keystore=None):
+    def get_sign_command(self, filename, signer, sign_password, keystore=None):  # pragma: no cover
         """
         Return a suitable command for signing a file.
 
@@ -213,7 +205,7 @@ class PackageIndex(object):
         t2.join()
         return p.returncode, stdout, stderr
 
-    def sign_file(self, filename, signer, sign_password, keystore=None):
+    def sign_file(self, filename, signer, sign_password, keystore=None):  # pragma: no cover
         """
         Sign a file.
 
@@ -293,7 +285,7 @@ class PackageIndex(object):
         request = self.encode_request(d.items(), files)
         return self.send_request(request)
 
-    def upload_documentation(self, metadata, doc_dir):
+    def upload_documentation(self, metadata, doc_dir):  # pragma: no cover
         """
         Upload documentation to the index.
 
@@ -506,7 +498,7 @@ class PackageIndex(object):
         }
         return Request(self.url, body, headers)
 
-    def search(self, terms, operator=None):
+    def search(self, terms, operator=None):  # pragma: no cover
         if isinstance(terms, string_types):
             terms = {'name': terms}
         rpc_proxy = ServerProxy(self.url, timeout=3.0)
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/locators.py b/env/Lib/site-packages/pip/_vendor/distlib/locators.py
index 12a1d063..966ebc0e 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/locators.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/locators.py
@@ -20,14 +20,14 @@ import zlib
 
 from . import DistlibException
 from .compat import (urljoin, urlparse, urlunparse, url2pathname, pathname2url,
-                     queue, quote, unescape, string_types, build_opener,
+                     queue, quote, unescape, build_opener,
                      HTTPRedirectHandler as BaseRedirectHandler, text_type,
                      Request, HTTPError, URLError)
 from .database import Distribution, DistributionPath, make_dist
 from .metadata import Metadata, MetadataInvalidError
-from .util import (cached_property, parse_credentials, ensure_slash,
-                   split_filename, get_project_data, parse_requirement,
-                   parse_name_and_version, ServerProxy, normalize_name)
+from .util import (cached_property, ensure_slash, split_filename, get_project_data,
+                   parse_requirement, parse_name_and_version, ServerProxy,
+                   normalize_name)
 from .version import get_scheme, UnsupportedVersionError
 from .wheel import Wheel, is_compatible
 
@@ -378,13 +378,13 @@ class Locator(object):
                     continue
                 try:
                     if not matcher.match(k):
-                        logger.debug('%s did not match %r', matcher, k)
+                        pass  # logger.debug('%s did not match %r', matcher, k)
                     else:
                         if prereleases or not vcls(k).is_prerelease:
                             slist.append(k)
-                        else:
-                            logger.debug('skipping pre-release '
-                                         'version %s of %s', k, matcher.name)
+                        # else:
+                            # logger.debug('skipping pre-release '
+                                         # 'version %s of %s', k, matcher.name)
                 except Exception:  # pragma: no cover
                     logger.warning('error matching %s with %r', matcher, k)
                     pass # slist.append(k)
@@ -593,7 +593,7 @@ class SimpleScrapingLocator(Locator):
     # These are used to deal with various Content-Encoding schemes.
     decoders = {
         'deflate': zlib.decompress,
-        'gzip': lambda b: gzip.GzipFile(fileobj=BytesIO(d)).read(),
+        'gzip': lambda b: gzip.GzipFile(fileobj=BytesIO(b)).read(),
         'none': lambda b: b,
     }
 
@@ -633,7 +633,7 @@ class SimpleScrapingLocator(Locator):
         self._threads = []
         for i in range(self.num_workers):
             t = threading.Thread(target=self._fetch)
-            t.setDaemon(True)
+            t.daemon = True
             t.start()
             self._threads.append(t)
 
@@ -1053,17 +1053,15 @@ class AggregatingLocator(Locator):
 
 
 # We use a legacy scheme simply because most of the dists on PyPI use legacy
-# versions which don't conform to PEP 426 / PEP 440.
+# versions which don't conform to PEP 440.
 default_locator = AggregatingLocator(
-                    JSONLocator(),
+                    # JSONLocator(), # don't use as PEP 426 is withdrawn
                     SimpleScrapingLocator('https://pypi.org/simple/',
                                           timeout=3.0),
                     scheme='legacy')
 
 locate = default_locator.locate
 
-NAME_VERSION_RE = re.compile(r'(?P<name>[\w-]+)\s*'
-                             r'\(\s*(==\s*)?(?P<ver>[^)]+)\)$')
 
 class DependencyFinder(object):
     """
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/markers.py b/env/Lib/site-packages/pip/_vendor/distlib/markers.py
index ee1f3e23..9dc68410 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/markers.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/markers.py
@@ -13,20 +13,29 @@ Parser for the environment markers micro-language defined in PEP 508.
 # as ~= and === which aren't in Python, necessitating a different approach.
 
 import os
+import re
 import sys
 import platform
-import re
 
-from .compat import python_implementation, urlparse, string_types
+from .compat import string_types
 from .util import in_venv, parse_marker
+from .version import NormalizedVersion as NV
 
 __all__ = ['interpret']
 
+_VERSION_PATTERN = re.compile(r'((\d+(\.\d+)*\w*)|\'(\d+(\.\d+)*\w*)\'|\"(\d+(\.\d+)*\w*)\")')
+
 def _is_literal(o):
     if not isinstance(o, string_types) or not o:
         return False
     return o[0] in '\'"'
 
+def _get_versions(s):
+    result = []
+    for m in _VERSION_PATTERN.finditer(s):
+        result.append(NV(m.groups()[0]))
+    return set(result)
+
 class Evaluator(object):
     """
     This class is used to evaluate marker expessions.
@@ -71,9 +80,18 @@ class Evaluator(object):
 
             lhs = self.evaluate(elhs, context)
             rhs = self.evaluate(erhs, context)
+            if ((elhs == 'python_version' or erhs == 'python_version') and
+                op in ('<', '<=', '>', '>=', '===', '==', '!=', '~=')):
+                lhs = NV(lhs)
+                rhs = NV(rhs)
+            elif elhs == 'python_version' and op in ('in', 'not in'):
+                lhs = NV(lhs)
+                rhs = _get_versions(rhs)
             result = self.operations[op](lhs, rhs)
         return result
 
+_DIGITS = re.compile(r'\d+\.\d+')
+
 def default_context():
     def format_full_version(info):
         version = '%s.%s.%s' % (info.major, info.minor, info.micro)
@@ -89,6 +107,9 @@ def default_context():
         implementation_version = '0'
         implementation_name = ''
 
+    ppv = platform.python_version()
+    m = _DIGITS.match(ppv)
+    pv = m.group(0)
     result = {
         'implementation_name': implementation_name,
         'implementation_version': implementation_version,
@@ -99,8 +120,8 @@ def default_context():
         'platform_system': platform.system(),
         'platform_version': platform.version(),
         'platform_in_venv': str(in_venv()),
-        'python_full_version': platform.python_version(),
-        'python_version': platform.python_version()[:3],
+        'python_full_version': ppv,
+        'python_version': pv,
         'sys_platform': sys.platform,
     }
     return result
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/metadata.py b/env/Lib/site-packages/pip/_vendor/distlib/metadata.py
index 6d5e2360..c329e197 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/metadata.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/metadata.py
@@ -5,7 +5,7 @@
 #
 """Implementation of the Metadata for Python packages PEPs.
 
-Supports all metadata formats (1.0, 1.1, 1.2, 1.3/2.1 and withdrawn 2.0).
+Supports all metadata formats (1.0, 1.1, 1.2, 1.3/2.1 and 2.2).
 """
 from __future__ import unicode_literals
 
@@ -94,17 +94,23 @@ _426_MARKERS = ('Private-Version', 'Provides-Extra', 'Obsoleted-By',
 # See issue #106: Sometimes 'Requires' and 'Provides' occur wrongly in
 # the metadata. Include them in the tuple literal below to allow them
 # (for now).
+# Ditto for Obsoletes - see issue #140.
 _566_FIELDS = _426_FIELDS + ('Description-Content-Type',
-                             'Requires', 'Provides')
+                             'Requires', 'Provides', 'Obsoletes')
 
 _566_MARKERS = ('Description-Content-Type',)
 
+_643_MARKERS = ('Dynamic', 'License-File')
+
+_643_FIELDS = _566_FIELDS + _643_MARKERS
+
 _ALL_FIELDS = set()
 _ALL_FIELDS.update(_241_FIELDS)
 _ALL_FIELDS.update(_314_FIELDS)
 _ALL_FIELDS.update(_345_FIELDS)
 _ALL_FIELDS.update(_426_FIELDS)
 _ALL_FIELDS.update(_566_FIELDS)
+_ALL_FIELDS.update(_643_FIELDS)
 
 EXTRA_RE = re.compile(r'''extra\s*==\s*("([^"]+)"|'([^']+)')''')
 
@@ -117,9 +123,13 @@ def _version2fieldlist(version):
     elif version == '1.2':
         return _345_FIELDS
     elif version in ('1.3', '2.1'):
-        return _345_FIELDS + _566_FIELDS
+        # avoid adding field names if already there
+        return _345_FIELDS + tuple(f for f in _566_FIELDS if f not in _345_FIELDS)
     elif version == '2.0':
-        return _426_FIELDS
+        raise ValueError('Metadata 2.0 is withdrawn and not supported')
+        # return _426_FIELDS
+    elif version == '2.2':
+        return _643_FIELDS
     raise MetadataUnrecognizedVersionError(version)
 
 
@@ -137,7 +147,7 @@ def _best_version(fields):
             continue
         keys.append(key)
 
-    possible_versions = ['1.0', '1.1', '1.2', '1.3', '2.0', '2.1']
+    possible_versions = ['1.0', '1.1', '1.2', '1.3', '2.1', '2.2']  # 2.0 removed
 
     # first let's try to see if a field is not part of one of the version
     for key in keys:
@@ -157,9 +167,12 @@ def _best_version(fields):
             if key != 'Description':  # In 2.1, description allowed after headers
                 possible_versions.remove('2.1')
                 logger.debug('Removed 2.1 due to %s', key)
-        if key not in _426_FIELDS and '2.0' in possible_versions:
-            possible_versions.remove('2.0')
-            logger.debug('Removed 2.0 due to %s', key)
+        if key not in _643_FIELDS and '2.2' in possible_versions:
+            possible_versions.remove('2.2')
+            logger.debug('Removed 2.2 due to %s', key)
+        # if key not in _426_FIELDS and '2.0' in possible_versions:
+            # possible_versions.remove('2.0')
+            # logger.debug('Removed 2.0 due to %s', key)
 
     # possible_version contains qualified versions
     if len(possible_versions) == 1:
@@ -172,16 +185,18 @@ def _best_version(fields):
     is_1_1 = '1.1' in possible_versions and _has_marker(keys, _314_MARKERS)
     is_1_2 = '1.2' in possible_versions and _has_marker(keys, _345_MARKERS)
     is_2_1 = '2.1' in possible_versions and _has_marker(keys, _566_MARKERS)
-    is_2_0 = '2.0' in possible_versions and _has_marker(keys, _426_MARKERS)
-    if int(is_1_1) + int(is_1_2) + int(is_2_1) + int(is_2_0) > 1:
-        raise MetadataConflictError('You used incompatible 1.1/1.2/2.0/2.1 fields')
+    # is_2_0 = '2.0' in possible_versions and _has_marker(keys, _426_MARKERS)
+    is_2_2 = '2.2' in possible_versions and _has_marker(keys, _643_MARKERS)
+    if int(is_1_1) + int(is_1_2) + int(is_2_1) + int(is_2_2) > 1:
+        raise MetadataConflictError('You used incompatible 1.1/1.2/2.1/2.2 fields')
 
-    # we have the choice, 1.0, or 1.2, or 2.0
+    # we have the choice, 1.0, or 1.2, 2.1 or 2.2
     #   - 1.0 has a broken Summary field but works with all tools
     #   - 1.1 is to avoid
     #   - 1.2 fixes Summary but has little adoption
-    #   - 2.0 adds more features and is very new
-    if not is_1_1 and not is_1_2 and not is_2_1 and not is_2_0:
+    #   - 2.1 adds more features
+    #   - 2.2 is the latest
+    if not is_1_1 and not is_1_2 and not is_2_1 and not is_2_2:
         # we couldn't find any specific marker
         if PKG_INFO_PREFERRED_VERSION in possible_versions:
             return PKG_INFO_PREFERRED_VERSION
@@ -191,8 +206,10 @@ def _best_version(fields):
         return '1.2'
     if is_2_1:
         return '2.1'
+    # if is_2_2:
+        # return '2.2'
 
-    return '2.0'
+    return '2.2'
 
 # This follows the rules about transforming keys as described in
 # https://www.python.org/dev/peps/pep-0566/#id17
@@ -208,7 +225,7 @@ _LISTFIELDS = ('Platform', 'Classifier', 'Obsoletes',
                'Requires', 'Provides', 'Obsoletes-Dist',
                'Provides-Dist', 'Requires-Dist', 'Requires-External',
                'Project-URL', 'Supported-Platform', 'Setup-Requires-Dist',
-               'Provides-Extra', 'Extension')
+               'Provides-Extra', 'Extension', 'License-File')
 _LISTTUPLEFIELDS = ('Project-URL',)
 
 _ELEMENTSFIELD = ('Keywords',)
@@ -600,7 +617,7 @@ LEGACY_METADATA_FILENAME = 'METADATA'
 
 class Metadata(object):
     """
-    The metadata of a release. This implementation uses 2.0 (JSON)
+    The metadata of a release. This implementation uses 2.1
     metadata where possible. If not possible, it wraps a LegacyMetadata
     instance which handles the key-value metadata format.
     """
@@ -609,6 +626,8 @@ class Metadata(object):
 
     NAME_MATCHER = re.compile('^[0-9A-Z]([0-9A-Z_.-]*[0-9A-Z])?$', re.I)
 
+    FIELDNAME_MATCHER = re.compile('^[A-Z]([0-9A-Z-]*[0-9A-Z])?$', re.I)
+
     VERSION_MATCHER = PEP440_VERSION_RE
 
     SUMMARY_MATCHER = re.compile('.{1,2047}')
@@ -636,6 +655,7 @@ class Metadata(object):
         'name': (NAME_MATCHER, ('legacy',)),
         'version': (VERSION_MATCHER, ('legacy',)),
         'summary': (SUMMARY_MATCHER, ('legacy',)),
+        'dynamic': (FIELDNAME_MATCHER, ('legacy',)),
     }
 
     __slots__ = ('_legacy', '_data', 'scheme')
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/resources.py b/env/Lib/site-packages/pip/_vendor/distlib/resources.py
index 18840167..fef52aa1 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/resources.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/resources.py
@@ -11,13 +11,12 @@ import io
 import logging
 import os
 import pkgutil
-import shutil
 import sys
 import types
 import zipimport
 
 from . import DistlibException
-from .util import cached_property, get_cache_base, path_to_cache_dir, Cache
+from .util import cached_property, get_cache_base, Cache
 
 logger = logging.getLogger(__name__)
 
@@ -283,6 +282,7 @@ class ZipResourceFinder(ResourceFinder):
             result = False
         return result
 
+
 _finder_registry = {
     type(None): ResourceFinder,
     zipimport.zipimporter: ZipResourceFinder
@@ -296,6 +296,8 @@ try:
         import _frozen_importlib as _fi
     _finder_registry[_fi.SourceFileLoader] = ResourceFinder
     _finder_registry[_fi.FileFinder] = ResourceFinder
+    # See issue #146
+    _finder_registry[_fi.SourcelessFileLoader] = ResourceFinder
     del _fi
 except (ImportError, AttributeError):
     pass
@@ -304,6 +306,7 @@ except (ImportError, AttributeError):
 def register_finder(loader, finder_maker):
     _finder_registry[type(loader)] = finder_maker
 
+
 _finder_cache = {}
 
 
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/scripts.py b/env/Lib/site-packages/pip/_vendor/distlib/scripts.py
index 03f8f21e..d2706242 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/scripts.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/scripts.py
@@ -10,11 +10,13 @@ import os
 import re
 import struct
 import sys
+import time
+from zipfile import ZipInfo
 
 from .compat import sysconfig, detect_encoding, ZipFile
 from .resources import finder
 from .util import (FileOperator, get_export_entry, convert_path,
-                   get_executable, in_venv)
+                   get_executable, get_platform, in_venv)
 
 logger = logging.getLogger(__name__)
 
@@ -170,6 +172,11 @@ class ScriptMaker(object):
                 sysconfig.get_config_var('BINDIR'),
                'python%s%s' % (sysconfig.get_config_var('VERSION'),
                                sysconfig.get_config_var('EXE')))
+            if not os.path.isfile(executable):
+                # for Python builds from source on Windows, no Python executables with
+                # a version suffix are created, so we use python.exe
+                executable = os.path.join(sysconfig.get_config_var('BINDIR'),
+                                'python%s' % (sysconfig.get_config_var('EXE')))
         if options:
             executable = self._get_alternate_executable(executable, options)
 
@@ -244,7 +251,13 @@ class ScriptMaker(object):
                 launcher = self._get_launcher('w')
             stream = BytesIO()
             with ZipFile(stream, 'w') as zf:
-                zf.writestr('__main__.py', script_bytes)
+                source_date_epoch = os.environ.get('SOURCE_DATE_EPOCH')
+                if source_date_epoch:
+                    date_time = time.gmtime(int(source_date_epoch))[:6]
+                    zinfo = ZipInfo(filename='__main__.py', date_time=date_time)
+                    zf.writestr(zinfo, script_bytes)
+                else:
+                    zf.writestr('__main__.py', script_bytes)
             zip_data = stream.getvalue()
             script_bytes = launcher + shebang + zip_data
         for name in names:
@@ -282,6 +295,19 @@ class ScriptMaker(object):
                     self._fileop.set_executable_mode([outname])
             filenames.append(outname)
 
+    variant_separator = '-'
+
+    def get_script_filenames(self, name):
+        result = set()
+        if '' in self.variants:
+            result.add(name)
+        if 'X' in self.variants:
+            result.add('%s%s' % (name, self.version_info[0]))
+        if 'X.Y' in self.variants:
+            result.add('%s%s%s.%s' % (name, self.variant_separator,
+                                      self.version_info[0], self.version_info[1]))
+        return result
+
     def _make_script(self, entry, filenames, options=None):
         post_interp = b''
         if options:
@@ -291,15 +317,7 @@ class ScriptMaker(object):
                 post_interp = args.encode('utf-8')
         shebang = self._get_shebang('utf-8', post_interp, options=options)
         script = self._get_script_text(entry).encode('utf-8')
-        name = entry.name
-        scriptnames = set()
-        if '' in self.variants:
-            scriptnames.add(name)
-        if 'X' in self.variants:
-            scriptnames.add('%s%s' % (name, self.version_info[0]))
-        if 'X.Y' in self.variants:
-            scriptnames.add('%s-%s.%s' % (name, self.version_info[0],
-                                          self.version_info[1]))
+        scriptnames = self.get_script_filenames(entry.name)
         if options and options.get('gui', False):
             ext = 'pyw'
         else:
@@ -326,8 +344,7 @@ class ScriptMaker(object):
         else:
             first_line = f.readline()
             if not first_line:  # pragma: no cover
-                logger.warning('%s: %s is an empty file (skipping)',
-                               self.get_command_name(),  script)
+                logger.warning('%s is an empty file (skipping)', script)
                 return
 
             match = FIRST_LINE_RE.match(first_line.replace(b'\r\n', b'\n'))
@@ -375,7 +392,8 @@ class ScriptMaker(object):
                 bits = '64'
             else:
                 bits = '32'
-            name = '%s%s.exe' % (kind, bits)
+            platform_suffix = '-arm' if get_platform() == 'win-arm64' else ''
+            name = '%s%s%s.exe' % (kind, bits, platform_suffix)
             # Issue 31: don't hardcode an absolute package name, but
             # determine it relative to the current package
             distlib_package = __name__.rsplit('.', 1)[0]
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/t32.exe b/env/Lib/site-packages/pip/_vendor/distlib/t32.exe
index 8932a18e4596952373a38c60b81b7116d4ef9ee8..52154f0be32cc2bdbf98af131d477900667d0abd 100644
GIT binary patch
delta 24794
zcmZqp!rJhMb%G7!i;1=_^@V54P6#Ykh2iKpYt@qii&Zc8a;Uxp)3&O|!8E7pMuEku
z2Qv&*&w|x2Qk@PK=Y^`bgwl3kIw&(a17s!x6a=_3F!(UCGBEMJOM(h9JYZmA6yj#&
zVqmzzz`(EwBK*>NvJ|5plhNYIUW{sdIU<Y<HXw-vMusoJ6BUJd4lpw8;ACJ}@R5N*
zW}>3B*bII~1_zJ|82-S(5W_f8QA$X!B(<W1fq_BlIs*fP00RTVjmf_l<;;?F7#J8n
zFfcIaF)%RPf$4(K4h#$qdMSw|i3|)3Ddr3e3<``8tz47+n54|U1T!!&Brq~Cgn*1?
zgy?~iV68=|Ir+&93>y3l3=9XLTJtu~V@hJ2XuvUv#Yq0G3Ijv)5s}{3Ki~iV56H0L
za%6a6Da63ge83^#MGxQPKo(&p8{WxjEN1eL;$TXDgOpZ)l%5xaDxD+&R(gqN@&y)Y
zra<AzZ&_@NA6Ppw1a#K^>8$<m!h)B9!T6;0asDX>GZt_;G6cSm|NsAg7E}2D(myZC
zRTvmR^lI73F|5i$UJz~u3nK$V7Gv;>`Qno&vg#XY3otNrx_;?)eZk7W@Zoo4r|S>v
z<F(A4wLilDm;M0hf36HRCoGHcf9aPOcH)yivD)dI^Mc&1)9w3&+4n&fgQo9`|D`Yf
zm;PzK$MB*SqG3PCrf`r|7sV#Wv)S?KK*Yg9tzwf`vzcozRb^o4cKr|;A9wO_X!o1u
zH#}ikdjCr~jK6i3{&=y4n}H!Rvh_fTY*@yR$-L~ETC2cDeCY-|EK?Zd1`+FjrJlX6
zKLYj(a62-9eEwPiq&$ILu3l6Uq=Lu#Sm~A5%*Nl`K;F3uGBm#X7}UmE4yF>G=2{Mx
zGR@{%4z_aTg&Ee446O%Bq#9KltQ{Ht-~azVt01Gm+L0lPGvL1{&j$wv;{y({Am{!s
z<@hh^^T7eEy!i)HDcd(!4(3w+EJjdRas00r75U)65PKM`9;6{K4P;YMe(QmfZ2s+`
z9O2y--RHAUvNj)NvA$Ro9vqgzDdND;Tf)xr;*vN6L$A%g-Z-AfPS-!3wH(&>i?zFd
zYyazJZaq*U*8JmtiD2`Oe<eKK#}EEs3V5Nf%D@oWe3+&AIE!^GN6}4?SL^%485knt
zqT|7V8x{^W{Y9lXC_Xv5f4mSBgM@DdcfgBN(hLld-5*{vH=p|-{vs5l5fn&Ze>T4n
z2n&C)jhBHT;Kk<u|NnRYc(D=`{|6KTUMvRjKXjIUc`*$v<Ph*;!vFvOn~(5xy4HVa
z{{O#3!1^D53l}2;gY^&o7A8gphUR}D!SDPnUl|w}tUvI#yk%fu0C`Bj`Z#~f1CZb`
z{uWSa(QWGR!GR$->)ZcpSzo(v{J)m<rPKA#|7)GDKVE2nouj49!0<vAY_meZ3mIhw
zhHg`j4-O2Gk=DOU>RBygzm&2Y-v*n|?fS?1M+vK?>z7ilEQYMF|F1Qt{$c2L{edj{
z1tj_dlqRhYmogdOws!qf$^uen?fL`6_`%R^8v%;(+a-L>zyFtT2LHdF#Q<`k@omf4
zKP3XqwSWGXaQ!d+^Z$BqJ;)Nv*dHL#A7IfR|E~vUeffVa8k*o6-=uIcFf43Qa%3<*
z+UfeI+m$0YEZq2icz9>)i?9Fx{};6Zr8iI(pL#Gug4>Z{F(`Qkz7YQP|9@m;Z|j?{
z|NjSM73>40&#)}c|E3`6|Drk|CmyIT;cMOtQc+OKYJ9-qHIwmy3>|JqhJY7WfByg9
z$O}r}3<jVykX3-B8I;5`e8B3~{`~(x%cZw<&e#9{!vkK3B!lvk2!tQ-U)1D-1H<>$
z6JP)TXJBJs;BReZ0EIs&&OjlORS%1^)(0TJTnp}Oee(7H{}(6z{QrNPMI{Gph4;_@
z|GT$>6okE4|L6bzj2^JC$<P1)|8E5=p9vD(02Y-4DFz$Td_<wK7i=>l14HNBD_{Tr
z@7#I=M7G}f`u~5%3tLBqdZ<Ig!^5)}!^8h?1qEsNe^G%C4h+`EOKty)x_oe82;a%T
z!oU#NJN3iY|Nnym1Hv;v^~irwg%1u4y{#a@0Eo_v8=wN_h2alS@)r1S3bFzg;4&W^
z82)cP_x1n(?$!$+KZ^eO|Gz%+#nC_i|M#|j_zNoBSs57^{)<|CaA5GTWoBexDCdRB
z{1*-R;J}c@m@!w_f#JVszy}A03>_X&JQ@4|Me~2tH@1!p|3yIwFFfl%)Mil$umeHy
z8vqkh0crICYyJBDzx@Bm$p2eG3jT{Sd~jem6WaYIFgPr{+t%l!1H<lu$wxTV80SrX
z&8g#6!{f*h{34M9RG+jS;Gc3ZIAaD6s6t8q{{Me(wFLim_U0oJX{`rJgtIsTUN{MY
zQcdfD5?Hzl&bR}%)#Cf)L@p62VW@oR^R#ArhVJhrlKk7*KpKBd?&p$7e<%Re&S88Y
zt&^?!7*qI*grEQa2Y<hjA;Rm(ApJj!A)@j54_ikD{;3B7UL5!a4)U~SYo$^(;{$2U
zc1pqgQx0T!@PYzq(YOEqA?6(6X+Fl(e3+^EI8zpX#)Qdy+)DZzz-kh~Ch+iYX9M{`
z4dfJim?I>>nqTvQ1hpo|bLTPco_vm5Q4mzqhGjAQ7uERSz>wB#`(P4}2;-y4qC5&>
zeBb{6@4jJtp!GKY)B_m|d?07|eVy#hqi-Vt=7@g<MO=7q>laYeA7f+C{u~yZ#gXyy
zFDMNdd~jgs{$PB-__p<DkO3}WJ&(Uk-o~S1w2luJIL*hH(k$glpM!m@oKe8%$iP44
zK){RHUqFUuF~vjNTsxVES4wOFOf~~73z71jY{P31c?E2|>K9NjS+?Hz@&A7Y13xrq
z`M>=CpT!>?9G)?O*OB4Ha~4nzS7|*^T9yIwe{buX-~a!E8w~+3Or$}QJP@&f|Dpkt
zkMb&WKq6t~=gA*<<rqUI^Yirv+3<q`<m)F;7QXTWMBV|DAgjYO3iurv!oq@I7;%D(
zGYEcB`Q!ipGcQ;D`TyUV7gQ9MGJQV$(m{@aA&Vy?K){jV#YW}H@A$-c1C$vUjx&fc
zFfhDW$~Re%U(s)^BB=GkVST)m_k|c(R)T?n;q}SR+COQQ)};zB7{P)dEm{A1T|We5
zfXsiPq6)H^=k>yX|D^(9!7tXzf%pQG7b*&C`YSUq9R6R*@gk0ufg$p6_y5rDH(}kS
z9If9<g<mXDVqnM;i|aIa@r!rz9)1<35~azH_zmj|K(1_6Vqh>n&|S)5{NMUJ|I`E4
z$4f<Ds4KzUTm!16PW*rEZG6D8mIth$<bG!<N7xHf76yjM&e}g=FPcFOq8q)g0s-Ow
zOL@Xx6sdtc_#`a&1*;m!jWWkw|NQ&^|Nje4P*Lmp<VC0w1H)k(kb6@=hCtlgT+6{w
zqWiy;Ba7j`sfrP(?8pJv2&EEXFQzFnFm!)_lzjm&+!QCD6Ofa;VF(gzKEl)btyIF&
z^-qcLi%>-dP{W4ng^%K7E<pvRm$s921l5#gSTitmvUR($ShH$qI5L!ob-QtN^D1aM
zGPHUWlybcIZald}(2aMN0^Hy4xhEeNEE1Y$&%nUH{R1c#__wnMyy&x^>@8%+7&5s_
zNQ!rZJX|>|_vDR2jrAaBGn7ia`0LETkR|uR-HCxA<39rf!;5fxaQ?Vm!qR>CHM8*n
zhX8~x3qTp`N9+GmwJe@EOV&LWjtnKd!7mtH7#Jd350tKa&Hmz)90NnA!HdISs{43+
z+-s5G7Z02n7$RS+mjgM1hXE9gJkha-cQ7b8G8|r*5I*^Uu!LhmxFbUrOTdc|H<0~{
zUED#<#8SB|matA!klYJv6baTWsff74#+P=240+AE(8YbSq=*`mg4<+A5k0Bv9t;c(
zwhcy(3=Ac#FBZEoF#I<KnfO9@a;J#4ho~0=L!%!LLjwat<ZG_xV+vvaMN2+7FvP_|
zBDmX?qxpwOtyuE`fq)k;JVA|Uo<<Ld`q;zWt~|{L6axN>mQ4O5qQ`g4gMlG3_Ao@K
zVzPy(qWE+aA#fx0%$YN1Cg+HrVoL-yEn+7-&J~{QFUBqPQyP}!{n;59Uh04<F;JTA
z_L^KG7G%QV#lX;gqWOqKr|%Ez)1~4sYNSDds0E6tLTLtuZibiZ7#J8VeL0E+!R73W
zXz9tn#8i!VK^l)(A1;wO&T!@o1H)^<fEO=*|NkFpeYk}4IK$n$piU4+x9^Yc8?CoX
zd0((dPYx89luz*lWdn)U10{mN|3U7^0ri%S@N|E8&GX`n)Z|WaIWf)e|Noza1XS}I
zf&Zlfy}ln_gihWo9>f&DJ6TY|fLBNg<VaAl@FJacvY&(+(~O|WWfJ*J%K|4qmx$t=
z&BVYE8Suh4V6vB_6jOxf<TOcpuJk~V)jThjNlacZslh%0l;;mfOui?nqQV80@|1v^
zJC7NZj9wg-02e0`FA^uKNtrRuog6Ers<i>6RaAn3!T5G(>=WYy-L)Lnzd;4U;Zlhg
zTg2gJa57I`BPA`g|L6bzk)5%BzPa-_l;(%OU}c<qQ%V+;lzvF5*DJU=GQ4KpQK9X~
z@XbM`p+w|`62gRXCI*IP-zWbqW1o~NhrgIC1<K~2;wAWhDNp!|-T-j%5+3$K6kN7r
z6fddbVCQqZC;_<v5~hJW{{LrSNV9b1C}lA|FnOM|He=1?Q_|8p-L4$12TDa>q=~_O
zup89gKk+~IaJPd1BJD1IqBogKTa{^7^khSAF{XWflRdR>*B^}nbwPap#2cTDelg=C
zJPyPDn?BJ4m0=S=jjU1*P~p|{!GU2hNVNMHI8TISG42y*VK@+$#q?s{KTvCdC+xrI
zj1LYB0slp(fN~DR?Z`&89w=ds{r}*9sl@+Mk^iNWYjl((0=r!WS`U<pyr>g_`{DBc
z|Nkfdm6qZUMTo5eiK)q~F`gw1SN9%d?}`5}QyCc;!opv0{{8>I`$J@B=?}|zmRjb{
zc$O^2;IJ3Xk&{_vZ9tLdENjm6NoaD7tfed{4m({rx|t6?WBcY}z|v4snZ=aF@W1rO
zi)|5;FUcA+HAYNkm-92Y07^O0LZGB&>B_-B^#C})8HM1E2>bj0fAfj|uQfnbg3Oo6
zt#ZmHK|;_-OawIzAOX?s$`KacdY~fGnw7!Lk)b%S`^3SYtlb})pUL;y^eVVbwm5Dg
z2kJ?6vv<m{86Sv#E%w4!5M&Lg=6Mk+$iOhU>$t2aSaWdq!Gk|oyFY?8w<@?z-gDdx
zs=1km?Z5GX*P<_u3&1s>7hqtREO0`?eX{@qL$d<Iiy3gaW>8vbJy5{`aaNJki+-q@
z61bWdCx8F{|N1J#!8{<h=ARJv`Tz=<HUS2P?ph8|pP04#d-F5-gU{HQO<F<0d))O2
zXe`J0wq+bgsc9D1i)I^8r5pPP#Fxxiz|X+Y>&6rCUv$po3nz3`Kw5fTEI<OFg16iC
z$qRP@28P4Nx4UaOvbbKjS~D<ARyZk|4N`dU0b8#NBS>upxGc?*$Pf^8WO#9aACmiw
z|995j$>M$?ZVjo2IGRuVf0+mxh~a*56eI>7&$-e3-+{l^nvsE_+hi}u*w%0SEjt+)
z7&=QIbhGSLaGSi~q?~LGNWJlG=g!za&2=0MrP3%)zkO209OT|_ZY+!?(!u{lK@Ms@
z=J2|?yY@zR>4Pk;7tU6oc1?5b9fs0p$J|&LoB950gY27Zc1l6Y-waf_b-F%iJy4R^
z%L8^sCu1`!gWKeSQ{Ys)?vxsD6CVS^;VkYKt(FW7k(0Y470izFf?^k3pvwFNr@)tc
zKrNJ7fw1mU9_!yFGS;6<C0;B*DEs>3|NqH6^6`x3lXK){7^Nn6${X-L;ei`t`D1c^
zl)~g^@&ZB2;i50QLG{XX9?%Ge3?$=P|1Q(&wr~y(%c$vaV0bYRlnIYWH2?Tl>iHs%
zhk>ElLa8+NMG6lCL#M^-kZy@^kiy9x3bNc5P+9dCdXozj#CXNQ)+m8&$oW3mB3g0s
z76mD$^W2j!C`j`&{P_Q$(Uqq;Re&Kf>;>oKUkZjUzd_k4;6-a7sMpkdgs1t(fBvZl
zdmaDB#U9S$$*=$=f$7|6dDWI1?!`&p{{NqxuPDXj{&sS=qGo+LH#DENz5V|m+VpI;
zRd9D?U<m6rEiiIq02R2e%fnm0mFiiVW*9j#l%&5<NMvAG{6^1_;e}NKsKr*v`C?T(
zh*9bd(bW2_#1Y&gv<8(4#qpq0_Qz|DfEO7cruFeMscyEkW}6Bw+fu>s|D_xOFQ!el
zRZ`)N0J*<`i-94F{l%imc}fy|;vf#V`J4Oo|NqHTlyuck$1yPU7BFTpg}v~90WNnt
z*^U2OA1@VuagY<_Q&4m2#kR>WluU*BxEL4?hl9Y2W>B|-{RR7E17&HxAWm2lW5t*M
z|0hQ(8!-w^?opOY{mcO}0i3ElzWo2sef+h{H#eT<5{s}Gwnm^p`SD_EJOe}6i{MZH
z{|CIV097_e1X>SNvNoUp|5~WqO{Vog33tGY_s{<SZ%&h8h-^;dVF0!H!0}T7^50F4
z$^0s!+LZ{K&V2@_-`Bj~+;|*Hc)?m+pS*a=!N71h>_zjd$^I%T@)usgV+hna2oHOa
z_Wl3=NYE%&z(NJL$?KZs>aD;3|DVO!{o{oZNGj6$c!^Bd3pEfs0MeIlJy6O8X@__J
zc+F(|KkP*ls9$*uRF<-U3oS?q7J1CYfQ6y;e+f_ci+$`243VG$p2_$?JSd$BWXu5h
z<0Lx+Lw77k^Y4G9(l6TB85o*f6&PM*vx5Q<RAPfloE8QKhSu8^9M-a+QoBg%MLbBI
z0>cXzxUv^BKmGsz`cn7dgFje%Z9ql&gcb>w6QG2;rbU|N6B`4=<oq2{;YsWa42Qd8
zIf7p(fIM^<+)Zk>{h;T_z*NHeVum&-hjP4ls0nMee^dh%EU|~PL^5`O+<S+Ofx-Bj
zrKy9vBSR^7SXdTg*niO_lMkr));EcPQ!huB%!}Cn|Nlq6P*;Hp2)ytC3#2813dKJ!
zBDFyhl^j{pFJ5afFhu?rT>xqq*tk0~yjTs&7B4{A;u$1caAa}3I0{nrB0dhPjq}A8
zkU$pWi*AtftdEtj2fV0X2ohTe%3X_dj2syP{+lL%x=^MuMve?GcpgC#x$6VV(kG>C
z0WUN)7#LmzXfQCm*6VhC)6LP%+39;HAn?V;7?6h#cc;GScD>W-`k=Y?2?IzyKS;g4
z1_J}MC)e%z;Kf;128P2g?j|xYyqx;4{{Me)Xg0plU}j)g%wXWi(8>Ep-;tqH^aqHP
z{Q@FQKY&QvH~NkYX+5G61|W);2TaMn01L7{0aL0Ez?AMCeMg2l{j358jtt$d42xO7
zG|OTR14o8lSB}LZAb#tEKmY$L9%l{EcVu8>U}RVbl3mQA@5peR^@pA#11Af^f#a-y
zCa+dg@$=AkWXNKC!Q#ch5D6M2X#ovA?fK}y@L#myg9AgeEl2@FDMuFLiwB+z43QZi
z%_vPWL=%0X!em)>6aF{MpwtS^?vC&O|KFUTUdPC^J$>>64MT@8NVvBiDCKTG#?^S5
zfq{kLwPO}X#*L2-3}G+Kk);Jd(o77mm9p3~-hibg9!(C^R8=|72)97y?f?I;WilGT
z-5G&iR~}GrBH+c{w8^tHP4#bplISKzPy-!QcR$Hud~sG6(p&&dO+2s$_xSjGPcbks
zfO>ZSG}Y=)>VPYE{+1~aK}UxFCL6+DlsyIw)+_{d?z&kvd~@JwF5w9XdvO*l?Dl$M
z_m9rnC$E#UEM63V(p@(%NM$F>M(e{Re&DJdrWMkEn*;90gT+dP|C?-h@$BCJ|B(w_
z+{GOkI%PJzmhNWR08t5Q27uhQOUp#yE(0jL)`I+TR~uAk&(LuZag+gNgHpB~Ka?FA
z4mTg*IQ&9y@&_Fg=8OxDlZ|yJ3C+I!|9`h1Pq!Nf^Lb+)ix=IuCtues6q0}nhk=Ey
zUU1x=9HpnEWC5zDN)$3c^o!;cP+y6q^*{-KcPK{|W6*z53-`(M^c;kmZb1x%=`Ol8
z`GcM-(+B6t=K2x*L8%N3J3;NVZfA}cDXEj^>FY5~xjFfqeu~oi6i`iSeB1b>@g?K`
z|DT0+zX=Wt&teG5nC9ZZ5cr~Q(c};VP38AbK~+IR3Mlur9w@1KvGMNz|IG&!tUrJ&
zPyQDR?@nG|pui|I`JlmcCdQP>QHE8jXK()h|AOoH|Not>bAJE-Z#nnQ@BjZxwO)Mx
z_5VL~#L4H`<e!GqnIZ!>PcjN%X8M{m`HAU7CZoj3<z}r+3JH_{nWZz$i=UisewlH?
zVrvT~rjK!(ZLJ&`8G|R+TNg8Jjh_6)I-0R*a)3=BQ`@=8i*1Z}`98o+Prg0*k&S`9
z-x*M^XTmEF2Zk$d4h(GW4h+fe4h$RI9T@hwJ1{VNI52Q~Ixu80fXApo*=`MZexUUL
z|I~wvRVD}8$}<*EF0@q@1P!137X^)nv>qrmYPQ`odAV%~W8-8QyJE%-lPB2uG47ju
z-%f|=RP1D4dpV}sn8~{K%1jY4lY{J+aAlnYIU|cF<Hsb2aGf3CBv;Dc_>V!wk)eb=
z?8UxQpfm>>{^@kj=r#p2N}q)N7u_<s*+Ez4<Ej7uJ7qPD92uJb{VSC_&I)3JBK5!M
zfyrkaB;*kMJs%txUf*v1_oq~-+x0`Y1Iuw%jmb=o{W?d$mh!iRF)}dpy1obq|1Y`$
zDrC;cz>vWR5_gsf3wZHRdGcOISH@YBnVp^~f=uRb4FNR*PyFxp{SzMt>P#jc1N%oL
zLqcdWmvgZK)JKBdZW*=^KLxy)b{y2nj>`z{w%sy$uCtDYg^?pew=>6L8!*kY*ult=
z!T3O@>yzdmthEAZ-9F9&X`MW-I+H&-J4--K6kZ4l3%Hqgk4^S*F>zmh3{;E7zJSH{
zYnJBJ2MnNs|N4vn{|`6Y>VUFNsZiG67h(VY|BpP*3K9SXnDGHf%^DomZMtRhahF*v
zAd4oSbE%ws&(+zD?dbpi|F?k}+AmImI?s{aZCgOoXNOC~EhS2Y1718m0#{%UR`7q@
z22lI<EJFOyk;&<9^5F}Q{QuwGc7}n0VSfVy1B3SQfERsWp$kx616a!eknYkWpgK^X
zyX^`C1B0!GrXxd%wB-zt%^*8n!x$L;Zv#oa@HsO1uA8!k`jP+tBQ4|qln8aZvsfQ4
z;kJ}0We<2E01|FKF7V%%qx5*#3&tapHQXbZEQBUExmSdNI{1hGi=O!4z;K9#q5FT>
zf71eO&>+AW&=B8;)^DZK|4ltW^|B~vSfKj@T)_p9f@5)q7v^X?f~OV50{)u@KvYf+
z@Q_rw0;-;P!KS_3z|X*t#gP#q1Zpun`Tsw|=PRfNyD_=f!+~+j<Z~XWj4qQ+JWbhs
zpav9pib_5J8Q{nAzmx4XXV{A=2mk+%H2xO;U-Zu8d7i5E4Ir~p9{>Lj9yI1}`2p$&
zxv8`s05vY$L5jQGbRaxS2+st<(}wVDAUs(J&jG^Yhwxk=JVpr51H$`!;Q#-~ZnqfQ
z4IGXPB}VK4FCKwJvUp!`@PitQpjpnkjMo1pQsMtaLFuRUKq-IYe@Ma)f3fwz<Pxti
zrq~0M&v@z9-vEUkXatq>g~?ygghBk_ux`^Qpvt}Ds{=#$|7#gFAbPP2C_t`d6o5J4
zh`5%K0p@^%>RPicNCiW;DJVV`gTlW=tl1W%kfDUP*%qXTp@gONK&i??P?RnP$t=85
z|G|ObI4ek}eT)M`rzuDoSTiIkEC$6IsGHStkO4Gg3eptt|61z-{uXe$UJ9ztO+nhb
zO+hK>|20S=fx7lT#5|BLkPOICi$OO0zXrDB#WQXZP?cDc+-(a=R2d9$4xn+_$=p7A
zl3;b$|6gc5P$Heh5cWdn52#-MFZy6|kdFnE`2NW~J|;}zCnq2B2@wPZV(Wnt(F}=i
z-~p&7lhu8_q!ds7{~z|^ax|#JvJXsdjs&siL{9GZHS#q86#^xa86f(FlPkC}0h&qX
z_%8|)ihRN3$-t0N^U;AJBjuw5!;6KWrZ8w!J0vVTW9eK6h8MLl3=BJBJ~}Y$OPI{%
zC#_=wGBG}`L^=b+dT|3X3SPpK#Q+{$5(SAGABa7irI4{=a-g52O^1;q17zlXaf^{7
zLzk<-BG3?Zb1e@8f9nEph-<hzGIX1QLg)Xr?i-!47g}$ZWc)W(ai6@*&zuJ&3lawl
zy!2DiZ20KF&{+GV=c5Bdv0%6BlWx$I0@MEs&8|;aUOzkT`d|WB!GkH2&HS|(J0>Uk
ze-!=*YB@LmVB~LM2Mv)hzjzQcIW<7Leu9xBL->n_mq3LNPwN5x)*TEC4B)A$eTR%3
z8N!0o7N0T!6%nBMy4}B-Kv7vLpK<2D14D4wi<K~aB|OFl0zlw}z;RH7yf$E9aENUF
zVN<3R_Trua14A#1D=4zNPiUXZV!rq@<H&yp2JM@{1_3Wpqd~12k=6sHdo%X@cVO5j
z!VDhjyAcHv=V?7qy7d26mVf{MhlRg55;fUAP*lP(5-jyPE*Jz}R)W^&eEBcxFgYjC
z+O!lD%K^Qu9RL3R4+#4&`T~^sV3pRK?chp_`9)bYC>Q@=ED_COevuhH`A(pL$PNof
z2IzR|e^U_WzvzU?3PGBTCX>B_R5?JSN1dh&Zj;M{G(ba*3xk~HKz+X2?ENZkjtp52
zSqd-CFhZM1f#BgCreIedkdm53ui3g~8QdlZ2Wv9=Os)+Umj{{F?fRn|H1Fg3r;DM(
zjRo8?g^ibO4ps(PawAwz7&Q0a{R6b@!>RRuiCy@AQJ=|@A-arnCcB3yv4hP2FZyP3
zL5Pg9{7%q9lE~KorRtWf2P_;J%H+fTi+%ykX}7&#W?-;pJurEFh?y7;sox>0nn@81
z4BbB>L1yS!y7H9ZHpnwn!+9TAHE4?Kf2oe8s{n50AjdE_pZMSXq4~%E(!J0D1A&Ya
zledH_1cByyYD2oeF9bEzEoC;8xWd}?`~fe*&Ot{3nE$&zY5p%#qXAY1Z<K%d-~j3{
zfcpk7IJbhDQ7-P2)xyF!KkWbiKQiEjc>LtnumtJ${h(HCGiZS3`;AEH1E94Vpx(Yn
z#*0beN(LY|@b@;uIvTw!8!RnK;<_2Y-HWh*uoogbK&6xMC8y5NKcG%PP`EEQ$i3h$
ziR_NatHNy<PfUIuuEaQJGFOBO<A=%m5z<U|H%<15aFqp(8G=Vh1cV(KUi4o1|KIq(
zduQzv<J*?9DwEem*fD;e{5C>G9nu#m6%T*GvkBC~IdmD+!T}BVbjCh;&E0ADnmzo*
z$BmOMB7GT4CbvbZnpl8UfO~ko`@q92FDHPiNBA(Ir1j@g(HDXUWoi2+-;ZqOZM+0B
z8m#f!-pTn<27)edk(ceDMv2Mf4N+p+`%XJByx0qB{z1k7-CuBn^1X#pY2*vWOaK3O
zTD%Sbj{)vGJ^5plw9fU5|NnzV2vuL4z4-rsr^IWS)&rH&$JiJ^1Be1Ic3cEm3my{W
z-8<PLI+*dt<eq4^pjYXj6(c?>9NH(EAF?wals?IQF!JS<bOr`+*F7+-yObyFMai!J
z|2tiIy4`ppS2UH1zqow?WEyxh#*aq<G$NzV$iT3|p@jFvfypW{P8v5iLc1y@JTK0I
z*$&npN_qd6^1NuW09Od5>|rlXWlZji(PO$7F?nB%kt8T{!l!>&6iP(0n1X`?U!<l_
z=8RQh%8!_=8*9khdLCpmIQVYunw%YLA+b3fG_}au?Z(l`_P<Qxe;G&Ei>*8U|DU`&
zR!z4XlzKp8Sq5P*>LKiZB`V=zFN${j|9|iYYZ!QF$dTbi5=aMMTw{Iux&Qw`Bl$k(
zKo)_$c;f%dT2=;zV9+9m8V+kyQ06a^e_?wL6wWV{;R;_=?1ZEQKUM~YZqVRYIBXul
zk)fOY;4`)^9|M+e2N_F6UNAs3KRXMv<#k5mFVIvBUwn|rw6kE7Yrv9Vzh2xixg=gy
z(+eyDN|!H!z)TL%g0mC<U*@rZ)<R}6fM!}aUZ|%`J`}%<@z3PUgst3vz?}{7_}pa8
zM0=+Cq{&%{U5xK1e@*oDSeghb)CIa-pJ>N^xcDOAe<^7A;6oMz()x~0*DtLHN=+c+
zdjT(|fVxc0zHk0_yMC~C<pH$?=dYODm9z`RCjaCRCYOZCOOrh%KueRdSmUgZm5RT3
zc>?C&7au3HrKrUifHLOq6aW9ihx~S&fJDGtxKdF1+J-*jHxa6=46f|O>CG4;eqxj7
zrSM64LDlMm)q(=__4eQwH@5%(KlxaSvf!`da7QtLRZhOpB08Brm8)I>lw=?sm$2?q
zk=AeEo_8W>47ybK#hT;)|3lVLFm3+-zx&v0kLFqdh7vK$Ql28gu>Yk3pi$}vwxAH^
zd42qUDGwxeKnr<6W9%TcyDdw3iuqn7flN}0?BwYF_<B>8SVUaxVbCl#)0s1qccrRv
z{cr`(uD`q<KlxQ^z~p_!3X^y45S987z`*d|m8042e<@$Hy;doI_vsDxFCGOjFid{2
z!+P@6G;75}OaA|V@&71jIAF@(|NmRRm1@8Ea1`WSP$;}`-8lJUnktj~`pFXMN}!t0
zCS3(YC8c*TEos~QCS8<?<+vUL!{l{)B-NyR85p{lojd0q`1}8V3#g&`=l}oi-V1;K
z|L@&;=kNdjFMjwiFl=_o(q?3Gh?!iNJ%NcwdopuQ5mUX^<no;RjAE0+bB!1$Og20q
zzIkEp6Go;Pnw#76Wf@tfxG^wHUQwXSXf(Ozu;k?T1wt(5AfeTVH74s8$}=U0P4+9)
zW9bHssW%jAF~&{~JR&*yNTC=@oGSyv<a>p(OtLd4|1Au3W1bFbYD}=Jb6~KoabU=;
zabP%I<G>(Z>%gE?>%fpv>%cIh&Viv>^$#dW;W5h*_F~pbNPSl-@WOF&PmxqT!$$`O
za039eHWrkIK{Z$FffAm87lyk)YES%sEe+1)-N-}Sy`V`?g}?BsHUN~sm3JW}@CTq$
zLV@AM(Vd`pfR!+yu{Pu(ZIu^0q3Y(r)xG$<1S5q@uqdtk|9^67v9h2GLZJ^>FDM=J
zt=akiKV*PA3#4#Qv8ANZ-v9rbT{)PV?fyrW@`I9&K$d;?;TKYq`AVu3nWq2$|H6I;
zD9wO|kicoiU<b&p;55^^c=F1U^-MBTHb<38F)?o5Tw1Qk$fTt(c}B$~rZl<9I+d+V
zA+nP<SEevsm6<GAHHC5e<aJd>j1x9LtP)^iQjyvGxrUFCQEf6)T`c2?$q9AtOfMxS
zudGvIjG26<E`#aw#>r;&3QW7YCr8w$g!FcTBDB|&VRN?w!{$y0hNqnl3=Ulm3_V>A
z3^TeM818jBFkJ0+fK*q_Zv=w7V+C4om$Dllc*zEuMXBXrD3y9~at+-5ax*3iG>AGb
zM~M8H{{R1u|NsBjzdX#qz!1J4#I(L&Ci<coq2|W)|Nme1gE|hSBA`VWYTc958j|^b
zyMc1IMC*Z4nHS$zPrlw@st^KN3KPcPIuTSfLu_BW8g4t&^vODna$-#gk?YgIWk-B>
zDaYi4LZOqlHX3MyhU`HrD*kk{g<Bsk3Fx*3Ewl>`&iWq^9Q^+}XleW562~m2fETkS
z3p6P)t#X@e(xk?_t>gdy$k(sC|A%#(zL}ifWaJ`n3ADT~GO|+^H0joQyOb3)<C5BK
z3YunnZ5sB1@&Et-Y0Y-Fk-Zg+B}!RL;V<r91U0xiL5s5;!@>hzv`oI+B;f~A|3a+e
z|NmxH5R;)<nc+AqXhIJ%xDy#2A9wgacxLa#hjx%EkbMjw%bvhGDT}83|9=KF{vpaS
z*|}NQ{>ueeyO}razbFeRyB&{@jyoJ27XD(UJSbdwUO(%Gty=4L<5|&MBDaF0MCyMT
z$BX3l$^5PUir2v_)nX5^Fl5Ni0F8Hm2JelbV@+W%z8=|J-|Ea*4;qDHC}n*iwf{dT
zY(SGK;l`lSPy$r9fMUwVwuI3=>_ru5xo2+)8)Fw+%Yo8YSuF11FSyQw-5J?w3yPN3
z|0SopO+h9Ezcvng;VH<#&;Sa)2vG1b2EVuiYBxuAvbP>6u@4Ilc;P3*z%bddUDy?*
z<%M`FC~QDXhGunaAqcYK#m5$qDi9Mj1Q$=7JhMHLN!E4pm-fd@7A})-b|^B5x=jAl
z;i(PsVkzs38GE3M9QR3BfqIf1vNE8x|Drq}9T*mZrjt5ND<&6ox-#*fnY_JIMHw^|
z)CryzGCuGc)K!R&i-u2U@C1kb7v-4zuTz~-V6s}598<&T$!=W=I$TYl5ysL#!O&=P
z{qvd=$_CBlfei@T;UM71u+L%gjxITlupJ&Cj>qI3U7?x^pqMWGV_f><zo^Vd2L|I0
z|3x2w27f>N7nK0>K`ZP2i;7G(>$aR+-fhqH%6amRZYMF{MWAL;GvEIg28&=dZ(HwV
zfu1vB*$ZJ(ehXnzOL``M>d|D3m@L!lW8yjS|NrLG|2x^N50@&wxVQk^#^{uLv1I`$
zYl7BVzF4{7|Nm}=mkFSK0InR}wknh7^k#t<B|#=HAtn1iSUbpi0jQ_I57yM_`r~C9
z3j@Rd(g(186s0cRX1Hnxs2SZK!d`rx|Nnm^SQ}_fbnCa$wJ-L}2RVrswES~H^W@e(
zN#VP_|NnQhbzf+HAb;=|Yq!W$1-Ho?`{Y11^~FBj#M@6m3AFhLkM-|T$rsl1|Nn2a
z0QIO!0{)x5_&DwV|Cj$k{fN{X3|Wl5t~WrUeHWl(52aFR&9yhAN`<?R&kO>|Jb|=V
ztPhtQ0yihkUer9<9N*8$sC&T#lqUta50#t=4-fxu_F}&Y1B3FR<|6{uhxuFj{{8=-
z#oX)q1Z0TL`N>l!1d0X0bnv%${r~?TqRV#jp9$(5FQ<S)k9+Q9?TIqhlOS_mAY%^w
z{r~@%>p!N~c3>+iATqCK9d~{5e)oQcEavF$!`jCKdR=V67G+Itnh0*VESsnR3XT&K
z%|R67Bvr<U$?B8jJybqAFjyZ(v|d@}fP?Y`C@6ojc7qn(I5I$1y|6SW{QGbAqNVHq
z|HzjMfB*mAZPtAbw3G;>XmZ~qNyFJ~|No!K63Hk4)#)c^gL;#o&g6maQVG~PS>YEM
zvtbEvU)$sxlM<M^W>2=7tRw{L-t@XKLTyp#{{Me+-sGgo=O@o(pCIhW0Gg`GpR$)r
zV}%0)sNML+ZnD`_HKvf#$#GMSnG9A;o;<Y)M2S!HvphE)ltMr)2hgAw(jp_F7n|Wy
zFF2b2|9^e28`-Oq=S?%#f8Fr^f8=h^DmzfeNH6TgEsy|c3yxCQi*pUA{i1yhlcvjS
z&4sA=U!oWGVj_h7uS6;AMJt->(uPUX#U{s3=hO;;r~>QofUv<jY|wP*G)$f}U4<#a
zaPp4nW=vj3Cx4i(@4D6;G@t{Y^k^yqwE?>SgZ7jB-_D>18W{tPiFUSw*v-dTn*VDQ
zJ&TV!4Bmdye1g&Vq$R7$<dhj_m<|?CHkz5tXfS!&Of#nRDU;95G-WiH%reW2X?xLT
zn_1e7j0Tf4W_yW69sK{l8*L4zY4PL}vn?2ZOlF*uExF*p|Nq^8tbdne9A^hD@@ziN
z@meb2MMcr%);Zp`0v{b1I$eK+zfdRzXXh_3#7qDG?{@tW*_-+#J}$c3_mA<}7rSyH
z{s8X}19c8S4T)#@lX>SRFd9tGo9kc}w;$6PmW3EgNpG~?F4@(~Vjqyj5d4Dc<m4xF
zl}u_rfSnNh;#D!s<~MMgdvmbZyfbgI)jXH_pSl14gKE@|V4CN}OE4|);vtw8d2tg=
zOT4%UqRn2M0#RiOFAjle6|krNmubA%1m^3!SOumHUMvFBCNE}zX_*(3z_i7SE--EL
zqA3?t0y+GzFLQWN4i<BHkq@RlUZjI*pBM39I^ab(m=1a252hntxP$4K7xrK};e|Pv
zPI;jZrZZlsgXx?X@?g5)g*ccldBG2+D_*dJ>6#b+bN>IYZ$9Gie;a6~=*7nz&>RzJ
zZOMygU}gtsIOaB(*#lx;05d`3JTH!dnV?4di(O#m43L8LVCEbUa|xIU8ftzq6U<x!
z672&sSAdw!VCJ5B5W51*22V-lf|*A^qDf%p2@o?J%mhtpz3|C_1l%^zeAWv)umouQ
z_=Pc;3EFM;LIcbM?G}9@3uc1$qP-9TGoOIWV+S)|FfcIGzxb04^7b2$@JBEcJmd8Y
z%mi&beQ_Ji`~p&N0n7wV1id&4X8r+*?gBFz7#SE|tOqke8zx^Y0W&#3qBFChZsq~;
zy1^0xAZ9~$J;-tq5W5sCECFI>ftfNOW;~b)+SvLc1k6+ciF$&W8X%?}m<d|V{lXZ`
zGysWefSD#BrYx8VT2l2w2+XtriL!&44vYy53@`p<fgIri68;EgdVrYEvY?Lk0r75t
zB?3UqvtVWjh<OOii~upWgPAcP<{B^)wDb1G!mP<R7AktxWr1h5SgcuX^guJu0WWeO
zA{^GN4p5OOh=_qTYX(%r11wTzVr`lO772S{mNnUVkxIP)Si()fn$-g=5%A()CfEWI
zYgQkq$Qy`=gf(jbROA*!M8=vm1S)a@BBEf;8UYpA1`$!QW{rW0EP;qvShE&DMJ7c<
zglw!?OQ1px5D^D!)(WUd9z?{&nzaTh5(5$Oux4$5ig<xV%6zO%Tfib=FDx=AJ1)-V
zY43v7p?6Cs?^vwG6xcQS$>M7!kbw~4@UZ6R{LRn!t^dWvm$JUB)L~%wew>+sfuU67
z;7g|FN6gJXIf^ttFa57F^}~+I@0N(kvFvbQ_^;B-u+xEI!he<CmK_cZ6GV16FgWaR
zU`W|9S!t;{(}x|Cy_c$hsKTW(svmYZF!XvdJm2BKaAk)B!<iip3`cf2Fzngkz_4Y9
z1H+mf4h&0nOy0EALj<I<`#;EJj-3t+B0C)zG<HtrTb9DxvkTNK{eJVmO0UhX$@R-5
z#U|_oy8<LJVZlxZh9f&27~brhyl$C1Q_rr+=a*@KsGrLWR6#0wJsBK!IWTzaa$pG9
z<-icJ%Yh+bmjgq_E(eB!T@DP*yC(ZB_YeW8?EXJzmjlC+T@DOeb~!Md*fn|8@|ipv
zKy4J0w*UWMEL}9&e}#g{T}=jt7rt%({~yjU*bV9`fvV8O2G))YkYSK+SB}Ld){YE|
zEkJ|~h;W#^c!ixPi1}X>G*JecU%LP@x1)9Pw-s74kqbc$&(7K#t^Z3!Ks_l?p4bO6
zWTDAqo0aNz7g|6K74WcuYQg{iuXpYP8MY8aycXLBvS=ZQc+IuX!P=2wA&7vkZVmuV
z11(%B#cQ(s|9?x@C!k@*`x_>oSee2kHh;3-Dm|ux^^@aP>DZaKfQC0fy+n`)Jgnif
zNg%Edf*S~0c>wZ6_<vK#<Q{lx@5CxarfKSvU$0WC_g@X___iJ>73*~tus&R57XaFN
zYzY-D(LeZ~DWKP6$A3|9z=6#u<><Br@%~>2?fqj3`+t403TRr<l>;<b1no+NWwB%_
zyjZ#lWIAYeAE6(txb<5pYnDVroYLWDH3s7Yai9gaA3%Zppb0djw&?$V(5_ujlkm^v
ziE`o`f13XPKm6kQqRD4hOMwOmpRZP`H=heq^@gF@Ho)2uv=QP(X>G<9PEbQh1Jv8P
z(R!P|1yta6+kz*+S8zHq1pmJdnr;3CnzaB=F$es=mN5e)u^42?|LY)r3z#1Q>Oz9~
z8DM?{jK4Smyv5w8L?9yoBm>s8I0h7#Afns%1!RWR`e2E>B`-*EiG2WQ!a8B{t~FND
zAaku<UzBKqXTD36{$J>HebaiNL~>!oWd601i~*B1*Qzij#!mKME5&o70ahl+<xDPJ
z>&8^pFnRA<OCD>u_{8kVOzWDN*3?gKU#D6RTEQ86cp-@D<OPwjhhG%d!_(t2Q0Wd@
zqYoZo0FUT$gQh3M68`^>j6DpR_h|hFnz7(`Q6CFh7jfXVZ}@A2)^DYZZeb`J(sV!}
z3|eRa+o$Ca_QH6H@Bjbc4gbym9+aI9d!f7p)Zh732eKbDeh=y=#~yz1unx4f0@kIR
zSO@A?v%P-w;v|ZAW!>b8^{Px$>L$-$FUxdLY4X1H%2J%$LDdrvXrM6~I)S?5i4+6F
z3xUbM*IQ}x*Ma7UUVN<u*$B>opwbqUNxRvgvlHF_f_r5^D`OKj7}syC1$T*GOhagR
zo$>$wOIbDshHowwED9z3pt*L?f`M`oa7QrgMb}fXC;3}uGBGf8Gk<eoXKCPX>0x4E
zc)>U8|Nm}>9OILg9wNQ13Qzz4=bv&gpqu%>348a)|Dq<Ke*Q`8gZwQCObiUxA4>#y
zEPCxhs#*e=z#B^^D{ahUJUe;fMoq@R$-6fyGwM#hztM<MV6xCA4aOIftv5w5zL-2^
zQzFxD`N`imX*2c7PgdD{m+{49rY$!aUrfHU<vgRn<TYCj#6eThpkZ6)tr}1N|F^zZ
zfBH4ge^HmopSL<FK;=ZcTS0QoOI@D+|Ig6bYVq{{e~6;sZR#@H%Rxa1>TSK)U;h7p
zr@?Fc|64&SUmPx<JZ+l_Z#h_j45%ekUq1QxHu=;O!JzhbmOzGph$F*`wsNG=U*~d2
zIBS44flLL(38*27Jo@`W2C9q^uIxov5|+W=*0lfsC#P>$7F=EicjfvrkQJc8-+2CV
zQ0WL--F!9;w9Y$AAj1IUq)laTCkelZfolahWg+TJi_i;Oxb%xjiU0q<zJ;`=ntz9c
z+rd=OXgFwX4*NG3HWtPb!{8S#AhCe|q81-PXG)ZELsEFB>l4t5u_p|mCB!9?FCK$B
zNxn}yIbIwqot(QvhTp6V=G-qJ114LhDKk|snH-m9K3RFEwc>%`|Nme7Edh^A!)7zy
zm4N&WPT<Z7lk0b?GP%Z~&1QVqxq#`?_05xZNiZ?4n!I|C4AbA=lTYqZV7mQ#^Xomj
zj7-Yhlcn}eWPCSy&Axob)X6gYA2R)(I{E*8L&gc44G;WeWUSw;eMp{>sp{)wpTqi0
z5=$o69@b)#{W^K&VNWJc*2!NE>oFBBo~&|2hsAmE|NoQM6^c#HIwGd*^5y^k=Dnb)
zk^dzut^e!qH}75W_y2!}65;<_L5vs79+MXzNjAIg3Q8`$o(xgv9T>vTIxuvebzpdU
z)`7wBoCAaHIR}R3a}Eq!&pR-HCWYX5vi?!GdYy>>|C`VMkF-8sD){1J1}H2*X{!5p
z_x0Ca|3PEbe**uP{s{Ol3YyOV4ICdY6^6t{>wyx^fER}|Kx4+|aSc`d1ud5d{R2AX
zAxk790F-vNWI%?}V()au)<5V5ZQ%S@D)S-(B&@*j!WZF)!`+u(f|C>SHYf+EI#sy3
z7gfRk|G&Nn-UbEUvgODC-oAD48Cy3$|2`i>mga|yCC36@tPDp=X$CBeB{GwXkIC{L
zPKSB>#p(3PbC1a>sb&2Ce;8C{J_YH3v~T{iKG1W7EH`~2&_DU^F|)~!PVHl}`RKr~
z_{ZdBryZrO(_l5s#6a+veAxd|2~Z#Xfy-p3Ga8~B=YdPy7avkV_JKEsK24o$e@2ey
zXzKs}SxTVY)Y5^IGtc-k3QXR9MwZcK^3^j6OwZ;{{(i>Nc+O-<1EAYgru9G_cfkKr
zi5DGUvDR-TQlO(yKthmdLmu#fEDn>C&#Li(2GU=vga?4Ub7;rp>1WjhK|%+AFnzxP
z+A(-co3&u_xwASVtUaK*Br>wI^iS)zQjRRn7i{g5`OewZUrPqL7o0`3{UI~dp#E-f
zw?uen>>ulUC8=4q!7m&gL5;b{Nb7$kq1N|H0*w!(S(Y>LPdU)(`ePx;Mr+m*(8e9E
z7iRze|6dFiIaXQ$-d<o?%2Q%&eXK<P#r2*4|3miheBAN>f9rwD@E6>PU{;CW3%}&a
z*Ul;E9RZE7Ed~v5TOTXA)oEY}o;N5J&SH775-bHVyJUZ-LAPwdWR>#<j6#z`&ueH*
z+5Z23B=g~b7nNObw?=_ZC@KB(q5>)x{z5o%^3wB~8X1szZ~kWAFaKY-CxL<h6lLKr
z>K#CfI7@$&@PXQQg_FOX*B1lX_#(dx9KWDektx`VldUi4v4f?wyCxT0kdpwhU)}^Q
ziwX-13wtpcw27ni&x?bTmtBx&l%9O-LK)Mm@00B=N->@LJ~`^5kwOAw-zI4Fa;NK`
z)&r&DFPalTP64$6UQ{GZUUSiy>F>kI4=?J;L)C)zw;SJn*#@dkgcCrEI#^4&Uwn(7
ztanM(=kmAz|G`79;H85u|Ns97B@1?c(2AS?qA8$LOm0XY_<qA<W~b{1<wKpJUz&gX
zFV%c8JsxB!XiWLV{CH3@0o8!>FUd1ye4BjWk`8Fh^xdV6cFl1hW#E)@!xNMlB4Q7B
z^QKrkGIVl)h8n?bCFq)v2kyvgLL^_f$4$O_S(-^JZt}0oE*cK@hy@@fU^aXK$jhVP
zRs(1Oh~c-%X;<`_T%Jvye#J-%G(w8J07NtxGy)y?;?$SPkFRJkoq0N$|EfCEo%+od
zS2-9Hx~_rJR|!X!*o&TP|NlpRV_g8=vm=<rm?6r*;E=`qqSh50p;^o?3hTggPoR-E
z(3G6$izU%;pZ;_M=ZRQQfq~e7A2WHuHBrXrleb+{W^|c+>zaz4@P_~Yp&P`eTY}Ob
zc*MO#9<+Ho{Kc$5uwAVON?E#(zvcn0kqdtD-xa*@G%h;!@MPQTm9n7G=*1iKKzs2)
zBxwAV2Q=`?4%$aG`SNvV<`o|tCM(`}Ue6-N$RH%f$e<#|$Y3PK$lxQ!$Pg#S$WSK6
z$j~Ro$goO`kztP*Bf}*zMurz+j0`N|j0{rZj0`&Bj0`s7j0^$dj0_3lj0^?hj0_Fp
zj0}C^j10@f85#D8GcvfzFfy3PFfypfFfwq-FfvF;Ffyn}FftfOFfw>ZFft@aFxE2^
zNiZ_>NiZ_3kziyvAi>CRL4uLtfdnJN7YRlN4oOA^14%{(CrL(z2uVhU6iG&gB1uMu
zI!Q)`X_AZ#>m(T&c1SWZ9Fb&XxF*TS@JN!8;e#Y2!#_zz1`a7k1{o<v1|2Cz1}7;-
zh7c)6h6E`_h9W6OhAt^ahDlP442z_~85!0|F)|#GVq~}_#mMkQijjd!nvp?4nvuau
znvuavnvo$vnvtPOnvtPHnvr3KG$X?@X-0-^(u@ozq!}6RNHa40kY;2E0u3R7&QB9(
zWVj{H$na-!;B8^$P9+D1`w<Qd!TTH-=H7B(h@XKtk?p`U2L>x;hlz@kvaqw?m>3us
zd>I%R9`G|VJowGP0NOtku=(KaXi1LbqSVBa%>2B`245v6YkW0G%}vbC%u81&E=kGE
zQ^?HANG-}NNleN~RY*(B%t=jQK*;BpmS9uBz<{JCwWtW2n#n7_M$0AV=am%Y=O|<(
z=B4DM7AX{`mXv_3hFG+j>02MOjDdh7187(zDA*-<p>ib0>g{h`HfFm%ZFUG3oxJ9!
z4c7%n28IvL3=9S<CMt?e7WgH>oG#}unfsS4bD}(i*3g8|fm#qcMITJ-=Nm%840MDC
z=t#K}|Nn!|v|xboO^hM(Ah`k~hspfEB$@5az<QZCnS*JjFBX%ve#<e1SWV{oEycFl
z+JRxeHAsZ{rUOL5m5|9<zvY;hML@V(F_TyQmg5hNb%0xw66-K|{clM=@py!oa{T0f
zzonRVB!kRiYR&?g!Oxq6aL>(buzQ#$<bqX%RDvn44v<17on@0({gz_8z1)G}-Et6<
zJ7Bj1L&$Eh_R0T$OETN;g*a!|KCr&!r@&OhX^?iU2{#=WR)B^xK^|vdU^pYr2tK~=
zizsNK93sdg!N}nAaiXHwXfCHwF5mk<QNMsCIJLwBoI5=8((;RP!8w(I;TKDIVrGe3
zeo=5{UV2Wde^ORza*1oj)MUn9#bhS;)RN$m#G;bY0+6O~hE|YBNNR3DKw?QoIK$NU
zjHbTrAd`bjQXqyiFnnfoPc3oF%t;NYEJ$V01<5++=N0GYq&k-r<v>&wG5CVTON)w9
z^GaMYi&B$I@{20N8K(O(GH#u2$HeG2eG3z#g8BiLkkq2w%)G>s)PSP=<kaF~(AkXc
zsU^-3tx&<~-As&{)0vnUHMU=2Vw7Us&d0)-#kjqLl~IL>D*?1z9(4Aj`*to4#&5j!
zCQlp~h{2Hb$-n?wq6WeSdX5Yl)`W3A6qx8aGU!-iU^a;0_Es^*PR4W=aG7Mlz|g?Q
zz`#(!z|a6X?Q#MGLj!0Uegy;QtQd$xSilrJ11RepU|?tfmBcp~7#cuj+6M-P29P`l
zBSQl#<mk%=HU<U;3r2<pb_NE9fa$psjN*nFjOfNOGNdsuFf?Eh2U#;?`dkS{ah45?
z3=Gp3NHB`99DuVfz*!IAtPgM&0~1V#0Gy=&V=);pO^=gg6svb&VqgeJVq|#1#K7<b
z<b05eQyCdRGZ`>`LK-8(3J!!kM?ND%1}lPJP{PQtLKVT6n8nDjLIA-(u!@l(g9X9Y
zSkK6i!2srqg9CKJdPW8gX0QO5KV#GOUy_V|zV#f;CJYP=VGO|x@eE-Mt_(p8!3>@Z
z{tSK$@eG~}ehh95{$LGzS>FF+0Pm}1WB|n>BLjrC2g`ysw6cKX49W#lX-ps;!3-q~
zMGTn?c?{_cZVZ_WISi=`o(y>mX$<)c4D}37U_}ND77PXqmJ9|ACJafSWBnMs7(^Ku
z8JrpN8FCp47!n!s7%Cb37!nzB8B)Q92Qy@XWkAL$F!(SeGL$mpF(fl&Fr+dRF(@#E
zG8BVZAjNSE(hQ7n%Uu{!8HyQ_!H%jgU?^e8WXNa81F2&mWT-1c1w$%BGD9gt2}2@7
z64);wjYbTdNEU>FEiOhf*N{Pv0fY^}G$_Ow7z`LV7#QopK~VzMkjIe7kb~sM5(Z-i
zBL+Q&RIsHC3|S1y42%pu45<w1V3nY-DPX7s`y-tpg8_7sET)(Og9d{$gC>IlR?pSr
z3Nj0j>lpl@hJ#`c<TzOTft(772y{m}FbFU(G6XObG2}C(FqASRGn62Ci2>aa^=R?N
zz+eUrN>l^T0~8dLAdDQGE)1Z=7RHdsPy~-@crs&PU{C=al*kamPy|j(#SA$Ni3}wS
ze2BQ`WZA&7-6NebgOL?<hT@aytXYh@^_z|N8lNz}X#B|dpRvA4kBO~mq3H!vMKc>S
z4>Mo0WV0NzBC~F@>1Hd;)|qWKyJ7auOw?S*+{wJiyw`lX`DXK@=2y&bnLjY+w2-q<
zwa~UOu&}dmvGBDBwn(r@v&gonx9GK)Wbw@6r-g>)B+I#$`z-HR{<n;<O0(*<+GlmV
z-s+syW2=8wLe`$vxz@GThpfL^Tif{AB-#|&Ot#r>bJr%@w$pZ*?KWFuyGM4l_RaQF
z?HLpx<te{`xPgv=xj}>>qmhA;nUSkei&2-+5~IyV2aL`b-7$J>^vUR-5x23vv7@oS
zaf)%C@f73Z#@CGR8#9|2nTVP$w+OPVKW2H>^1bCZ%SNl2R`;zwT3xihZT-Sp%tppW
z-A2d8*Cxa!(I(yIhi#4>kA0o}MEgbd$L&G+7c_6pWFTswYv60Jz~F?zLxaBtT880<
zNrn>)=NT?Hd~W#D(9|f(DBY;v=%CR_BX;A(CTC18m<E_dm}Q!kn)RAJH|w(ytG5ic
zjI}JaoM(B#@`q)bRkzg)tEE;Ot@c_Swz_I{*Xo6pzO{+9opptEt#ylam-T;ZRvT^`
zK^t)!SsN7_Z5tySOB)9pcN;&OFq=4=G@BxuYMTa|Hk%1HGi{dGY_QpCbJXUP%>|ol
zHg9Y`+c4SgxBF-(V6SgK$$qQ-b^Ay5ps9KX$Z5(F1{wxI2FV5m2IU6r1~U!j8GJI}
zGc+`GF)TFfGkj#Y$LNUB9i#6?e#WK7jmAAD?@Sm>_nIy<+iG^f?5(ANb(PIQo3}Rn
zwomLpRTTpRXkI+hFxD{9Fx4>AFxRlqu+*@{aDw4A!#jr046BWH7@aq=uQv%W=`xva
zve0C`$qti4Cf`gLO}R}~O!Z71O;b(hm|iq}Vj5yrXtv8t)7-;+ulY&yJLd1qIV}V&
zBrOaqJS|c!@+?X$YAu>9CR*&Ucxds-g3U6>a-ro*OIs@jYdz~_)(5OFT65W0**Mzx
z+63Fg+oam$*_7DS+H~6V+f28qpKG(yX1&cGn`1U-Y_8e-u;H~ewk@`;v|Vhw(ssS=
zQQNz=%yzYQ3+z_eJ+gacXKZh2?{6PsA7h_npJ|_OUuIup-(ufwKf!*6{X+Y-_M7at
z+wZkMXn)-PjQu71>-Nv=|9~ox1O^7sngJ#QE(1`al`&8;&@?bGus3k2H}EnDHYhfz
zG?-`*U>If?Z<uD-VffdO)kwlf*+|34%E-mY(<s#_->B7Sg3&6Ytwwu|&Kg}ddSWDN
ztZwXU9AcbjTxz_)*vTZ+B;914$uW})Ca+CCoBT9kH?=nPFpV|sGhJ=^-Bi`g$1Kt;
z-mKGXz1dc?`(`TU+U5@C?dJ6p&G(pJG5=&PX5nTLVbNx>(qg^EO^Zhs?<`a;^(?I{
zi!Ey`J1mb{p0m7V`Pov$O4iE7D$pv-D#gm)I>|cMdV=+RYc(5P8*>{^n*?ysPPdt7
zv)$&j%|)AAHg9bNZ3AtW+8(uKv)8vjZO>4^06r?*z|h>#)hNd3Q@xS0@d}eT(+pD?
zGi|d)X6wyb%=^ssEOIR7Ssb%qusUItZQW_T-kRS=&c@Ql&mPqB@nB$Ja51=HC~f3!
zlwss!vcznK*&4GAW?Rg5nC&q;V0O&xuNjxQmbr_0nfW~P4vS*TZp-zSJ8b^gn%h^|
zFS9=ZijoNo3^kyoA{z~5OcYF1Of*b%Obkp+Oe{>2O>NBl%=Vi7GUGJ&F%LISG%qr*
zHJ@pI)f`l!?X)~$$za80<!u#am0(q9Rbypi<7*RY6K#`VlV)?t=7!A|8yVXS+Y;Mm
z+YZ~6w(D%K*nYQVu@kV9uv4(pu?w|}wPRSoz>vehz`$kDRd4XsfWuJT(9+PyFwStE
z;XcF3CR<J3nTVR2n%bL&nO2+5Gxau$Fpo9QH}5rHXujNB#-h=p*Mikj-crLd)3V2M
zndNcImzG9W)mA#zM%EVA9@fFutu~)+`0T>%KG+?wXV}2N09w0ZWe{ud&ETQQXA@Ra
zaZ^oGf73+MV$=Fo)9I!wO?R7~HN9{8(UjRt)J)xMmH8d>FXq3^nJqXhcq{}gEG^<K
zYAsqUIxKoDCRj|dm|-!;Vu8ggiw_oGEPh!0u}HGawd}C$x13@*!*Y)0Ud!i}l2!^<
zDpnd+I#vc&CRP?!Hdbv`JysK}rdZ9eGPcgLF0d}OZno~Q?ya|;WWC7xqV;ufGSaq5
zwaKz6v?;TxwP~`MVDr)Dmkon$hwXIR<+kf=x7n)MY1^6DIoqY#W!n|lwc9<iW3?Bs
z7qeHh*S5E@cd_@f53!H3PqELkFR`z+@38N+pJu<nezpBGdxirH3=yD~jDeKFJj11i
zs|^{A*o}mZ>b;DTj6NC#7=JbvHeoi^F>N*dY<AXsuEjZvCl;!fE|w21g{`cuwp!h{
z`fp`wZEt<bI@hM#W}}U$t*&jbEdv9?1qOx$1_p*~gCxVxMrOuI#?8iQrkBjGncp(M
zXa30infWX8cjoyPH5OAXHe0;65Vu@txzK8v)pqNv*2y+qSvLD@&e=?`oo2hpcD3z3
z+rPG)b`o|fcIWNX?5*vy?ECE*9xyO~8dSXoQw#(Q#SM!L=NrB?+-7vj_@Z&J=`7O)
zrt3_1o8B_rV7AR{x7k6nOJ-u`pu_b+xg^6d$FRV##IVA!#js=g-9kp|$Sd|Y>=^_Y
z!GV!s&|$E`;Do^o0}ewCLleUQ!vezzh8qme7+x^^U?^Z@U=(0fU{qr?!)S@o0iy>-
o48}ah8pa;R8O9yPON>_-A2B{*{KA;SM8m|xBx8GF5o0_%0Qgg$%>V!Z

delta 23300
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
X;|InJCJH7x+ZUEG#<Ne}@WucD$>4P9

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/t64.exe b/env/Lib/site-packages/pip/_vendor/distlib/t64.exe
index 325b8057c08cf7113d4fd889991fa5638d443793..e8bebdba6d8f242244bf397ab067965d47c5093e 100644
GIT binary patch
delta 29243
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
E0ItXz`~Uy|

delta 28003
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
Q91A5DYHZhC#CVw*0ORfgx&QzG

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/util.py b/env/Lib/site-packages/pip/_vendor/distlib/util.py
index 01324eae..dd01849d 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/util.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/util.py
@@ -1,5 +1,5 @@
 #
-# Copyright (C) 2012-2017 The Python Software Foundation.
+# Copyright (C) 2012-2021 The Python Software Foundation.
 # See LICENSE.txt and CONTRIBUTORS.txt.
 #
 import codecs
@@ -215,6 +215,10 @@ def parse_requirement(req):
                         if not ver_remaining or ver_remaining[0] != ',':
                             break
                         ver_remaining = ver_remaining[1:].lstrip()
+                        # Some packages have a trailing comma which would break things
+                        # See issue #148
+                        if not ver_remaining:
+                            break
                         m = COMPARE_OP.match(ver_remaining)
                         if not m:
                             raise SyntaxError('invalid constraint: %s' % ver_remaining)
@@ -309,7 +313,9 @@ def get_executable():
 #    else:
 #        result = sys.executable
 #    return result
-    result = os.path.normcase(sys.executable)
+    # Avoid normcasing: see issue #143
+    # result = os.path.normcase(sys.executable)
+    result = sys.executable
     if not isinstance(result, text_type):
         result = fsdecode(result)
     return result
@@ -1426,29 +1432,19 @@ if ssl:
                 self.sock = sock
                 self._tunnel()
 
-            if not hasattr(ssl, 'SSLContext'):
-                # For 2.x
-                if self.ca_certs:
-                    cert_reqs = ssl.CERT_REQUIRED
-                else:
-                    cert_reqs = ssl.CERT_NONE
-                self.sock = ssl.wrap_socket(sock, self.key_file, self.cert_file,
-                                            cert_reqs=cert_reqs,
-                                            ssl_version=ssl.PROTOCOL_SSLv23,
-                                            ca_certs=self.ca_certs)
-            else:  # pragma: no cover
-                context = ssl.SSLContext(ssl.PROTOCOL_SSLv23)
-                if hasattr(ssl, 'OP_NO_SSLv2'):
-                    context.options |= ssl.OP_NO_SSLv2
-                if self.cert_file:
-                    context.load_cert_chain(self.cert_file, self.key_file)
-                kwargs = {}
-                if self.ca_certs:
-                    context.verify_mode = ssl.CERT_REQUIRED
-                    context.load_verify_locations(cafile=self.ca_certs)
-                    if getattr(ssl, 'HAS_SNI', False):
-                        kwargs['server_hostname'] = self.host
-                self.sock = context.wrap_socket(sock, **kwargs)
+            context = ssl.SSLContext(ssl.PROTOCOL_SSLv23)
+            if hasattr(ssl, 'OP_NO_SSLv2'):
+                context.options |= ssl.OP_NO_SSLv2
+            if self.cert_file:
+                context.load_cert_chain(self.cert_file, self.key_file)
+            kwargs = {}
+            if self.ca_certs:
+                context.verify_mode = ssl.CERT_REQUIRED
+                context.load_verify_locations(cafile=self.ca_certs)
+                if getattr(ssl, 'HAS_SNI', False):
+                    kwargs['server_hostname'] = self.host
+
+            self.sock = context.wrap_socket(sock, **kwargs)
             if self.ca_certs and self.check_domain:
                 try:
                     match_hostname(self.sock.getpeercert(), self.host)
@@ -1507,25 +1503,6 @@ if ssl:
 #
 # XML-RPC with timeouts
 #
-
-_ver_info = sys.version_info[:2]
-
-if _ver_info == (2, 6):
-    class HTTP(httplib.HTTP):
-        def __init__(self, host='', port=None, **kwargs):
-            if port == 0:   # 0 means use port 0, not the default port
-                port = None
-            self._setup(self._connection_class(host, port, **kwargs))
-
-
-    if ssl:
-        class HTTPS(httplib.HTTPS):
-            def __init__(self, host='', port=None, **kwargs):
-                if port == 0:   # 0 means use port 0, not the default port
-                    port = None
-                self._setup(self._connection_class(host, port, **kwargs))
-
-
 class Transport(xmlrpclib.Transport):
     def __init__(self, timeout, use_datetime=0):
         self.timeout = timeout
@@ -1533,14 +1510,10 @@ class Transport(xmlrpclib.Transport):
 
     def make_connection(self, host):
         h, eh, x509 = self.get_host_info(host)
-        if _ver_info == (2, 6):
-            result = HTTP(h, timeout=self.timeout)
-        else:
-            if not self._connection or host != self._connection[0]:
-                self._extra_headers = eh
-                self._connection = host, httplib.HTTPConnection(h)
-            result = self._connection[1]
-        return result
+        if not self._connection or host != self._connection[0]:
+            self._extra_headers = eh
+            self._connection = host, httplib.HTTPConnection(h)
+        return self._connection[1]
 
 if ssl:
     class SafeTransport(xmlrpclib.SafeTransport):
@@ -1553,15 +1526,11 @@ if ssl:
             if not kwargs:
                 kwargs = {}
             kwargs['timeout'] = self.timeout
-            if _ver_info == (2, 6):
-                result = HTTPS(host, None, **kwargs)
-            else:
-                if not self._connection or host != self._connection[0]:
-                    self._extra_headers = eh
-                    self._connection = host, httplib.HTTPSConnection(h, None,
-                                                                     **kwargs)
-                result = self._connection[1]
-            return result
+            if not self._connection or host != self._connection[0]:
+                self._extra_headers = eh
+                self._connection = host, httplib.HTTPSConnection(h, None,
+                                                                 **kwargs)
+            return self._connection[1]
 
 
 class ServerProxy(xmlrpclib.ServerProxy):
@@ -1570,7 +1539,8 @@ class ServerProxy(xmlrpclib.ServerProxy):
         # The above classes only come into play if a timeout
         # is specified
         if timeout is not None:
-            scheme, _ = splittype(uri)
+            # scheme = splittype(uri)  # deprecated as of Python 3.8
+            scheme = urlparse(uri)[0]
             use_datetime = kwargs.get('use_datetime', 0)
             if scheme == 'https':
                 tcls = SafeTransport
@@ -1759,3 +1729,204 @@ def normalize_name(name):
     """Normalize a python package name a la PEP 503"""
     # https://www.python.org/dev/peps/pep-0503/#normalized-names
     return re.sub('[-_.]+', '-', name).lower()
+
+# def _get_pypirc_command():
+    # """
+    # Get the distutils command for interacting with PyPI configurations.
+    # :return: the command.
+    # """
+    # from distutils.core import Distribution
+    # from distutils.config import PyPIRCCommand
+    # d = Distribution()
+    # return PyPIRCCommand(d)
+
+class PyPIRCFile(object):
+
+    DEFAULT_REPOSITORY = 'https://upload.pypi.org/legacy/'
+    DEFAULT_REALM = 'pypi'
+
+    def __init__(self, fn=None, url=None):
+        if fn is None:
+            fn = os.path.join(os.path.expanduser('~'), '.pypirc')
+        self.filename = fn
+        self.url = url
+
+    def read(self):
+        result = {}
+
+        if os.path.exists(self.filename):
+            repository = self.url or self.DEFAULT_REPOSITORY
+
+            config = configparser.RawConfigParser()
+            config.read(self.filename)
+            sections = config.sections()
+            if 'distutils' in sections:
+                # let's get the list of servers
+                index_servers = config.get('distutils', 'index-servers')
+                _servers = [server.strip() for server in
+                            index_servers.split('\n')
+                            if server.strip() != '']
+                if _servers == []:
+                    # nothing set, let's try to get the default pypi
+                    if 'pypi' in sections:
+                        _servers = ['pypi']
+                else:
+                    for server in _servers:
+                        result = {'server': server}
+                        result['username'] = config.get(server, 'username')
+
+                        # optional params
+                        for key, default in (('repository', self.DEFAULT_REPOSITORY),
+                                             ('realm', self.DEFAULT_REALM),
+                                             ('password', None)):
+                            if config.has_option(server, key):
+                                result[key] = config.get(server, key)
+                            else:
+                                result[key] = default
+
+                        # work around people having "repository" for the "pypi"
+                        # section of their config set to the HTTP (rather than
+                        # HTTPS) URL
+                        if (server == 'pypi' and
+                            repository in (self.DEFAULT_REPOSITORY, 'pypi')):
+                            result['repository'] = self.DEFAULT_REPOSITORY
+                        elif (result['server'] != repository and
+                              result['repository'] != repository):
+                            result = {}
+            elif 'server-login' in sections:
+                # old format
+                server = 'server-login'
+                if config.has_option(server, 'repository'):
+                    repository = config.get(server, 'repository')
+                else:
+                    repository = self.DEFAULT_REPOSITORY
+                result = {
+                    'username': config.get(server, 'username'),
+                    'password': config.get(server, 'password'),
+                    'repository': repository,
+                    'server': server,
+                    'realm': self.DEFAULT_REALM
+                }
+        return result
+
+    def update(self, username, password):
+        # import pdb; pdb.set_trace()
+        config = configparser.RawConfigParser()
+        fn = self.filename
+        config.read(fn)
+        if not config.has_section('pypi'):
+            config.add_section('pypi')
+        config.set('pypi', 'username', username)
+        config.set('pypi', 'password', password)
+        with open(fn, 'w') as f:
+            config.write(f)
+
+def _load_pypirc(index):
+    """
+    Read the PyPI access configuration as supported by distutils.
+    """
+    return PyPIRCFile(url=index.url).read()
+
+def _store_pypirc(index):
+    PyPIRCFile().update(index.username, index.password)
+
+#
+# get_platform()/get_host_platform() copied from Python 3.10.a0 source, with some minor
+# tweaks
+#
+
+def get_host_platform():
+    """Return a string that identifies the current platform.  This is used mainly to
+    distinguish platform-specific build directories and platform-specific built
+    distributions.  Typically includes the OS name and version and the
+    architecture (as supplied by 'os.uname()'), although the exact information
+    included depends on the OS; eg. on Linux, the kernel version isn't
+    particularly important.
+
+    Examples of returned values:
+       linux-i586
+       linux-alpha (?)
+       solaris-2.6-sun4u
+
+    Windows will return one of:
+       win-amd64 (64bit Windows on AMD64 (aka x86_64, Intel64, EM64T, etc)
+       win32 (all others - specifically, sys.platform is returned)
+
+    For other non-POSIX platforms, currently just returns 'sys.platform'.
+
+    """
+    if os.name == 'nt':
+        if 'amd64' in sys.version.lower():
+            return 'win-amd64'
+        if '(arm)' in sys.version.lower():
+            return 'win-arm32'
+        if '(arm64)' in sys.version.lower():
+            return 'win-arm64'
+        return sys.platform
+
+    # Set for cross builds explicitly
+    if "_PYTHON_HOST_PLATFORM" in os.environ:
+        return os.environ["_PYTHON_HOST_PLATFORM"]
+
+    if os.name != 'posix' or not hasattr(os, 'uname'):
+        # XXX what about the architecture? NT is Intel or Alpha,
+        # Mac OS is M68k or PPC, etc.
+        return sys.platform
+
+    # Try to distinguish various flavours of Unix
+
+    (osname, host, release, version, machine) = os.uname()
+
+    # Convert the OS name to lowercase, remove '/' characters, and translate
+    # spaces (for "Power Macintosh")
+    osname = osname.lower().replace('/', '')
+    machine = machine.replace(' ', '_').replace('/', '-')
+
+    if osname[:5] == 'linux':
+        # At least on Linux/Intel, 'machine' is the processor --
+        # i386, etc.
+        # XXX what about Alpha, SPARC, etc?
+        return  "%s-%s" % (osname, machine)
+
+    elif osname[:5] == 'sunos':
+        if release[0] >= '5':           # SunOS 5 == Solaris 2
+            osname = 'solaris'
+            release = '%d.%s' % (int(release[0]) - 3, release[2:])
+            # We can't use 'platform.architecture()[0]' because a
+            # bootstrap problem. We use a dict to get an error
+            # if some suspicious happens.
+            bitness = {2147483647:'32bit', 9223372036854775807:'64bit'}
+            machine += '.%s' % bitness[sys.maxsize]
+        # fall through to standard osname-release-machine representation
+    elif osname[:3] == 'aix':
+        from _aix_support import aix_platform
+        return aix_platform()
+    elif osname[:6] == 'cygwin':
+        osname = 'cygwin'
+        rel_re = re.compile (r'[\d.]+', re.ASCII)
+        m = rel_re.match(release)
+        if m:
+            release = m.group()
+    elif osname[:6] == 'darwin':
+        import _osx_support, distutils.sysconfig
+        osname, release, machine = _osx_support.get_platform_osx(
+                                        distutils.sysconfig.get_config_vars(),
+                                        osname, release, machine)
+
+    return '%s-%s-%s' % (osname, release, machine)
+
+
+_TARGET_TO_PLAT = {
+    'x86' : 'win32',
+    'x64' : 'win-amd64',
+    'arm' : 'win-arm32',
+}
+
+
+def get_platform():
+    if os.name != 'nt':
+        return get_host_platform()
+    cross_compilation_target = os.environ.get('VSCMD_ARG_TGT_ARCH')
+    if cross_compilation_target not in _TARGET_TO_PLAT:
+        return get_host_platform()
+    return _TARGET_TO_PLAT[cross_compilation_target]
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/version.py b/env/Lib/site-packages/pip/_vendor/distlib/version.py
index 3eebe18e..c7c8bb6f 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/version.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/version.py
@@ -194,7 +194,7 @@ def _pep_440_key(s):
     if not groups[0]:
         epoch = 0
     else:
-        epoch = int(groups[0])
+        epoch = int(groups[0][:-1])
     pre = groups[4:6]
     post = groups[7:9]
     dev = groups[10:12]
@@ -710,6 +710,9 @@ class VersionScheme(object):
         """
         Used for processing some metadata fields
         """
+        # See issue #140. Be tolerant of a single trailing comma.
+        if s.endswith(','):
+            s = s[:-1]
         return self.is_valid_matcher('dummy_name (%s)' % s)
 
     def suggest(self, s):
diff --git a/env/Lib/site-packages/pip/_vendor/distlib/w32.exe b/env/Lib/site-packages/pip/_vendor/distlib/w32.exe
index e6439e9e45897365d5ac6a85a46864c158a225fd..4ee2d3a31b59e8b50f433ecdf0be9e496e8cc3b8 100644
GIT binary patch
delta 25715
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

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

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/w64.exe b/env/Lib/site-packages/pip/_vendor/distlib/w64.exe
index 46139dbf9400b7bc0b64e6756ce17b4eb5fd7436..5763076d2878093971a0ef9870e1cde7f556b18b 100644
GIT binary patch
delta 30933
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

delta 29256
zcmZpe!`9HlHo=DR#Y9`@`U~P7Q>K)u9fx6di+#tZmZ=@@f8Be0E12#%{v1s2I6k*b
z?f6{2t;Z*V)vF&r4HoZ!s^0^pcZ2Dm%;XG^nG8@6;L5;|(#FP6s{S_yD#Y-CK}nc_
zn~95o;R*u-!#ap?i}_?JMm^?UW~RyBjHbF3a*PZ%Aejk_3`+tS7#JED8Ln`F1fci>
zBSQ)!1B1h71_qhQ2XE`JeqdlY!8B1(N=UCHwW5T9f#Jwy1_lNJ1_p*Jlew7W%-)$Z
zFfe>zU|_IdU|_fbH3dpJFfcgir6iUlGB7Z7I503U7%(z0h=8<Dj$@KC16$m{$iTqE
zz`&rw2-O6kz*>uni;@`_AP$|t$iNT;GGg*NCMiA#W{|Cn3=Av`3=B=1uQ6#cPBh?{
z#G=gfP=2y1i&mhiA_Id*FYmWM3=IE8Egmp1cy!<J=w@B!%gEr-dZ1LtqxE))mq)MY
z-#;L!)Bi<zKx#T!TcHZLJ-Sc-7j3`K!0=kxr<e8JpUDeY{Fy}MCx2wo3M>r-8?FU5
zJm)^h1d!pEe9#P+gc<GtQq#%05vl-U`0jg9!-GJEt4^NCDxvw?kdeWo`<F-eN8{T*
z-6wr|o&NCeyWrV<^2J;c1_qz*6CSMxN@TlPFHgS28tk_IH^?2L2OJq0JbHaCT#cXj
zbf#LoNZ?^$aO^(QdcdPsbjoiA2L34rUsU}2|KFqA*TS{eMTN=u(u*JRAXocZya<<>
zoXsX9cTpZ>JV?Gqg>fGXBglm7p513%x{tk(m7KhkO({{dn}NY2`M;<3Uk~QrFWVUy
z7<Mx-2(WaYesNp~Vwhv^J_d#lzgz!%bboN<_xR&#e4zXKi%6)^F5QPcyRUn6pL?-h
z0;K+&NB0G=yBxdEc=U>1`!!jEUCwJ-7uXh$?sFd6|2&v~zo_JAU;sO)+w}w32gV1O
zUEg?U|LDH{;;9_O)jr+FJi9^8ePJyDayiJnsgozLi!sicyqsOmW-^Alm*OyW&c7Hy
zNy4N12LIH9FK+(%|KG1SM*F|7_1z*V{_U&|lNmXrnGzHy%W*hxPT~RuxbAev$>|*C
zO3QwNcp)ko9=$#)5icIgfqVtxcKfJAbl-UKO?dJF4omjvp9~Byyu>GQiq!An1u2P9
z3HW~BL;8S+@==fGBL?wtv4_u`Ipfh8qr&0QS)w8k?$P|l!K3?@NB7VFqEBxzFnBa8
zGaPqOF<@d~VAu!BCqCT=Ji1T#bf5O<zTR1)qS2h9qQLN9)bKU~L-&o=1EoCwMOkk%
zFf{*Q<9E5|(Osev(S6vXJEmSGz@zzyL;T@09?fqwT2Gb=b@PUKFfz2BEa5P|^k1~=
z76Zc$kog|XM>GzD93<e;S)(Em>e0JKrQ!Sk{~nER8aP2-U{#l5WbiOP;?db!zyT8Y
zX?)4}<bTnITMP_7y{-=&cTQjc3E%MObx{e}#R=w|uJ`D4QBn9W>V1oWq4hwCU}KF+
z07zXa`%aLpubGTbdi08_{$OBu(evy7|3=>r3<k*N!OZzDy7ML|=tZS|FfeqVcoF~W
z|9|64pjaqy>2=C@;q1@Au=Csh|NoD>s1#%{fQo<*APx1sp`dVkF$I(vdPV<!2kTb)
z_5c6QumAu5|1WwPq^dXcgh%&@7x@rHKOl<!{`~)c=NGV|We`OdK#IH|iatXW-T3+c
zzeg|c!hiq&?*e(~xa%4QMv(23Z-TrL<F69o(;1`U0Sc4?SL2hQ;BfG0PEoO70Fed^
z%_%Ax46eopJi4zNpFHlOq5v}Gzv$f?pztbn{V!?^vb#A&#Q>Dy3noYL$<$xG0W#aS
zz@t~R>^mqs95+7sBIn2d|J^Ps86MpsDiI#tr#o4r+!z`Di_W<LiWMJ~g#V&Hq0ETp
zQ~&>q7Q=WRy&)<A|3#ZY{9e%-h{s-njPn7B3*TU1KqS^26@kg;_(iz$zJrYY`Cqj6
z*5tSRYT^rp!48)6=oK{rN%eYj{1*+lHCanQHcRq51B2rZP?7J^ef~v1q^$Dj6;=EW
z(&N*898_Ex`~Zbyxdi`qzO>epC4!FK*It+iGcbVDN$Y`9W=NS~3i0p@Mv(I6V@y!x
zJRs$)!jm@&h-JPN0vTJ%<<WeYDb2-Fx%4^zc5aaT6|h7JN198gGDs3sFe&{0{~uy9
z6Uf=E2YkAZdvt#Q6%4)K|Nl>GwpS|EOl!7Qf+*ts4lZ1Mx{tre`##w~P&CpQ>^XjL
zazFoKA~(qH5{0zpdO4*MNrXldkjAM8K^j%R|Nqawog3s!RgklEA<mKnIqNmQWA`=w
z?I&JH2u+?R7%g;P6qe~Guz`}*`Kyz;h2+&|u`n<ge{<<g;{a7{oIbs}A3j5>mJFuX
z!j9cnKt`krP7V|jkBhKmWN_R8D&Ilbb=Oq}hBQlCXG=zg?h7THKE0+EmW&LqxqW&~
z4J{cNJeprIdGz)cFf%ZuId+<a9b>(q!N?HsLizju|J~<2dPS|iA(x#uzD_<SWX#3?
zje!9aVza+aW){{o5xL61(0vYE88L#CC;tFRMt%MNKdrN*CcvY&MkOH4vP31IM1p@i
zzhn267hwXE6NDwiKYRs;?hBc(|NnzR0_+WSfyw>C(&F!+a<9H1$$jOYd{9`k{@GWs
zqkOs_fGk?_<^O-5?iv+`?sLAa|2=v|zk{?+J@}&g%m4qo!7<g#8~ufW0bD&@d9jBB
z6lbM1KE15H=Ae4DH-V9XVHYUGUZ{ZTtzNLee^LEw3=F-&!fB3{Au4jETAsZ=Dhj<(
z?_O9%Gl4wp(JQ*|GuR=%-A6pS!Jd}<0`j!ENAh8h-l-sCJ$ic^SQr?5ds$rmi$1?P
zd9g^e_cK;-(Pj<tg-7=f2mYzYy3f66`~3gEPiKybg->URih)lrZ{Sx@Za?hNec7Y?
zyiaG1iiS^Tii*OEKyFZGJpaP;$7D}YS?x1t&YVe0<Ckv%H>^CYc@u>g8A=5`4jvRp
z`+o5M|5B#UhdmCS6nJ@4a&oVzDeo**28QDdVhjunFVs~hpBGh4*Z^uvb>9G$Rso<C
z#`_`+tVV)?f#LQ3G#5*~Ql%HpU?Gq;k6uwo?)FhpcyUIRfnmY~;{&hdeY#J$f<gk^
z0;mPol|MYXPrqQ3n;ar$$ah_ZfnhgDd#A*UWR=O2#Z;J<s!ZM~W+v-<1(ep;Ujzqc
z38+lbz5?>$iT|QO7bo+Gt0v6804|hvaxgG3ywp<%aUg6ZH4xh&*rWN4!V6z5ur818
z8!y<v%+oI>fqi!R#XC)q)ae)ZpmdQsnD5biL?Qa6tNP@L;tlmi0gMa`-8V}lJbHQ6
z0~i@zWa)!aN(l$3p(q9tn5qYkxk;Bm6mRk+28I`P|NsAQJy06u(aUSE$H4I7l`cq5
z)*P(F*5VQa!)rc|Ze~!cj_LmekLJT19@h7Z-g-3Kp7v*CU?`FI=;b}+&&crNuZSMl
zHhx#*1I8yEdjpvMi>~sYyhOq(qz@Ft&9>i^7#SG(TNoJ`7>=_(0&y4^7+gA3uPZS!
zwBF`#1$7EMx_LGHLG{3_^B@m?07a>RN9zIpmc`&Ai<b#3TXTN0k))=hrv?Lqhb4O{
z)9Ys**8hs)J-Ye-i`sy7-guz{lI&#vf7zp(cY`0uOeKhnM>p>bFkk5W<T;Xt(ej{(
z>*Zy*$iVPo`(IG8E-C{N;spsU`TPI>1lQIlCH&whdr_dwz~I{Yq*U!V>qSLIQ1!_G
zkqB1?wb;(TIQ$1xMxXyLy6o&^4XIep>-r1~-KSp^=uYmFQd2I_XJi01WqzCm1y`x~
zi|Gm=pWgT{+IALP+uJKlzAhyv&ujn|1|?@{OBWS~644hSAeF5LO1NKmDNGiTR%g1Y
zKG{}U&hDTrBSVQ;cf$z=28LGFW=TedQjQk|)(i|Doy;EHtVI%x3?7!w93|2o-Od8t
z9bjd=F(74}FDi{D&y>#M1vP=8dFq+mWC58%q3c!*4E)>qLA9*{|MnX%j$2KhEE6vm
zrOU`rTJGC=prp#9^<=5ki%2<mZhR&?SwMDjeWMPjmvORG;l+9#28Nw-pp5FO#lW!h
zKZq3#YJzn0#^^9I_;eo!g~ZEKAfJ8!`BcY}HD8C3p@a{V?^=~XAymTqdi9GmS&${5
zO#31l&h+R$_FCvgyfOpB3pco+@qx)@8w4i1DL9xWae^wNqaK~E46erCe7j$Gbbs>b
zz6o-+*o(6=h};}0!@%$|pOJy##eSQ~yA|}M^lTUye3Bou9w@bcQ3X<{#lXPODe)pt
zW-^PSEt9^?WM@TJTMZiq1`q8Ap!&hUqxFA@=5h8jXBZe>3%_^;N=4m2K$(XBIK$n$
zpa$}Bf!EBQ-TypV|Cb89SSvmGsG_#BhBerSLf}gL8pzLOJfH^hYn~UW(hLl{A=Y~I
z`hRG&1esFG`eNd*|NlWvWnTsl<FhaPzfLw*GGjXbYjU<y5K}b!<o!yXyctrUzyg(2
zFTP4n7FBj;^01j4rQF1n<2L!8a-s1>R|W>x?qfdPB`O)7-PgKLyjbi4atD74s042Q
z@xLUy`+$e`i<f2pL0z)*FL-PwH>tR@gHptcMG})QsFXTHTQM-aP?LaLv{{^i;k7=<
z2c-fG3==>ta|NI7bH3e2JwV-_GcWw0LDGHt#cKfuhRLm}*~$@Oj12tSPx5bP@p!EU
zZaDe$`lvX7lAM7{_rd?7$B#@FR#TL7HNNfJeZi;ulyB>SQt=nM;&5wsi7_xtKBsX+
zCQ1x0_FR;Kq4~uBmr<Yy{p7^JFnOJ(IMZjh$;UO7m?j%cey!=tv_*8Xl~y2=uG{2Z
zEhDC%u9FXHX)#UIpZr!U%yOj&+$b{<uu-q2Ui{zz`KtT$3-*8i|969{g<4()22kTG
zM#TbD496dyERkj*nPCR11^$;xywF3Kvs;*fVRETK8Iz^S<hKUWOfn{uxeRCUei8yT
zjNKSLdU<!dPF`=Qsk}#sfuY$#iNCc6lvUOVfl}Se1`vA@s0Z82o9{aLx1l9Z0z_S@
z$%`<d$qq)MGWJ3sM=OEqJMI@oU=BC|>=$HUm|SR-taCsRqyQw=eB%G>tmX&rjo)@U
zN;o$EU@YZ)A@}?L|L(ucA3za!%zu)xF`u9v1A|NVad7fbbeimF>|@UkH{!(<0Z72;
zw%#t`YW~ew!rJ_ssr2p(4^9S#2`=4-yRU(o&hJ2BbpymY!O6fd`HZn@eU>dFD6`9c
z761(+eB^Iw1{LeAw@ZyZEM?CLFfx>szHko#m0YYGf{Y9=n1ewnvy$_LQ4okx8t&08
zyB(yr^>&H3N9(r|H&CniCuq0>6f4{wttU&2U%UkIt&f*UdUSKAHQQ9$mhwZg7}E>u
z$wekXDi4Gh7$z9s?mq0%`i+0;fz|`1!Y}slBT57heg=lgFHCf`wF5y>l)$(P)U);M
zKJ((!yZ`?^I@v&lmB@=keo&x-i={CB$quG!vUY+D4Bdxci-I$NtMN%tWq8T><O?o7
z28IcfdsJm6&o@;RxWb39DuIuIVe$o29i|z4lmD5j_!RMh%mhW$i~qa~4BW?GyM1$%
zXfCmO(cuFMy3^f1UdVw$sQdJbZ&u(M!y6Jvtj*{DzZUlB_SOJ}0@sV2x0CbCY|LNr
z!VN43C)w9(-y9_zO4yncB^X|Rc%jDzP1>gaVM%*48w11Shi1Z)ODqIbICe8IIPUh1
z0<{ZlKcD>nKh4Eb_VvmC|4UemZ@)J5NM@BfHF<@FNqvnBIEs{-ZIALYGBB31zEG24
zVAv@GO1^s}Vdej&7ytjikQIX|ods3;TbhAkCuq>_#YDK$<shZ^#2FYSys)tXX{hAd
zDGf61)oV~+*kTtroiti9GQ3EMWN>5f=w!9!Wn_4f5CK&TYHq#Q_xk_;7rvoTAy7yE
z#p>7p|AWh$7n(0Y&7TtX?h`Mjfz+)GnY_?azTV~;C@4T<0j;-7L6YhqNvqfY|G$>%
z{?WWgWdo?KTFTLV;)Uev|Nqat(0~2^{{&EJFh^wvC`C6OS-`-+5Dy+UX?~;eVtyp3
z4mhImGU(s`|Dd519~BOd#y1@xwY|KmyrAYu|4vZ+vI_7qiZOuNJrSUOc5jGEf(K~0
z<^}J{$)Q&I^%r;;!LkZI-99P-KHV;$?sJGrg7L{0yH_wUyjJq)Zczc7+sQhI7t}w1
za+?oucyzLAf`qzRn?O`2>t}9IHf&J=jd6H%vVP%VWH`=xikp#vlZD~Han>W;koJv7
zH|s=DceB$)B{svOo3$6pDfllsYX<{EC#wk$Bc$j1!YPu00n~A;+5t*0ytj9On#QR+
z7#Nyu`FI!^7)rSy0WTE^l1SOkz_1Hsmq+)B|Dt9)CMQ_$G~Z+fYFNs7^zyDWV`O+C
z15PU?eBc2KkM6VoMJJgtGIV>hIPL%qK6rLt^<+N(Vj9=v02>YVknIc%FQ#)%uD5w7
z*vo4Am4V?fq;cKN>R~$BO-`|1)s&Ipg-19z>HJgywNwt2s`LhMfW{zXIY5%y5Xn1G
zN%kF5pklQQJoIz?3rM2~qet^01CQo|93KBqmvDM?v#wWRWO)4y9ATpSzc4Vk_IfaT
zcAxO+6`iWY$l%$1z~kT#*5-%uo|B)+S=-HbXJBZs)!_j7ll6sU1SsBl%|P}wAJKUE
z@Y(<WXCSTyHCK9hWk8l%-z>88=w)5-ondmkyrxMC7Xt(Tu51Z@P~8)K*rV6m0L=3E
zuljQf0|Q+Dt>&L1wZhE@1zs3&P2M9fDR~?udj>TA*bD0YS)VF0_2^|4{LV1>oxHZr
zWzbkz^FafT|EdjJ7#KjBdHHu0N$@ux6nMD}B-!f)l1$#hz%V(}R*|VmY;upSJHIX)
zypY+&%D}Msk*zDEz{4$|ffUd{xJUQp7n9>Ao7)?PtpE$Mf)alB=@)#@K=}_m_`$`$
z>%GuxKaXC~sbD3b%nPcIUO$B^5#ZnTUhuWHN3UoXSP47SloL-U@3XfToE{6x<ovBS
z|Nj5~pOux1aWbDnu>5*Z`DXmTvqnY1+SbW{k%7PW4M<<|caLsXA%)2e4jSeStYDoj
zplt2YEqYTPlr2O)b)SF1_6O8Empv{Iiba;s-y9^GOL#oGFLa-Ok^N`#eFw4BWKd<(
zeZnL8zehJ~A4q2>&ks-u9O}`0&|udBeo#W+wgF^8shmeQZ#GCtH_y)(VvoQ^M}v%R
zR{72FTE(NA)fXcB1ElxAX#NIJ4_ekjesYwf5mO7x<UU6+R*z2JLXOF?YRZ9Y-Z3yh
z#yB6afchRkx<7T_Z2tMbg!M&c00U^Su7CkF=vZQW$#KUNP|0be0;<nqR0=$LT?IUP
zeFY%HeVr~U0slp(uAh8SO_WJ${^S>G7EHJ1O;%Djwfedal%czS{1<(^4wR*RR6PER
zURVeAjzH`GQl94D|4Z1rPrqpK2PNZPkV`y_&%7|bJ$a(Kj6w4o4M;xSCC<Wdz_HhZ
z@x`2fpwhc<Edv8s%%l5+NAnR4kN>LC>lhd&2X=@}*4JPcyu`-H;MjfB6I88#`Y-x>
z?PPb2R92r}-iaS3uXOa#(`E-Xv<{SVdi1g`{>Z@an#H5}fB?v(!=SO_7u-nl?H?!0
zJBcYhXG3U7hG`M$lz4HD4HPP(-XAB2J84gDb5dfOHfQoGrzEBYA13oTEAZcA0hOaX
zCp<d&|BE)RnQZGE?k(|wfuZ}mN4K^|>)R6P=4uYc5>asJB)<j}4rgCf-~Im|G%oJZ
zd|1Ha|GCmD9=)=!--G15!O4TW*_yGG?Z4>z)syc#s|zdxNim=F=;k@$@n3bp>d9g*
zN}AQ+B2)au8Xg9QUO(9vE?lr`H0ma(ZT{PX`M*!EuJ8NFi7q01=e<Fu-vG5u_+MmA
zZg$ZU;$IDpC~;6mD!=pp{|mjz`&~o@V($F^Kf$A$x8OY}ab8+A`H728z#LF&V!rLs
zY;&KXRPe>uf8cz_(d!}j;_hvbZ9Mlqx?@zp<xITCf7P5-pgQf1#*1hcki8ujK)I^*
zWC_dvi?118G=)u0a22)p2Px`gJpc+p(3m}VXqI;;h}+4#3qtLNP<vPy8Nd~0H}6W2
z$bZ$Ym6Nx)20K3e{r^9-b6WKK|NqwxKE0}jAQj!bS}cqVFF}oEpI%ixh>$u9Bg5+&
zpI%il2%n#Yak7V-D%0u1lk?qd&1Nuz@;2{8W=4knp!%b;1~k@OwE~pUUU)YDWh`Yk
zKJfAn0|SF^>)TQ;$6jCN7k_R}e&iO*_x2D2L-)l_9~Fge)~AOi`?@PL?Kw2L$h}sx
zmWh$!utz5^3XLejyLoe%KsCJD^2rh&stWDPL4!WvDUNR5MQ=gH?Eezp|Dw~EGcYvs
zPIx;x)<cQu?SaXS9{Nmk-cH`+;l#A#+vIN^R`pw!GB9-WZhOPP0LqZ_mVv?@9N!+j
z9*nzAFflN^D0GJjmKb;QcE17fF8mj*0;@gUdZ0wi_|l6H;4D}N5^MJ6_}|I=n*GI+
z>;L~7-|jyDUo;LR4(epWA{$zVzL>n;Q-I0y`s9P2+Vw8iK}o{f160znzA%IEA|N~s
z2rmP|lY;OHAUqxjuL8pRcMW7pH>isP5qJv`0JWYxdRe9SGcb5qpD1B{arN5&|ND6v
z7#O<GznJ>#|NqI^UQ&X`UxR$-qhbJ3!}em%waL@GbhuxAVPGhc^5|u4{5<)rmvX%W
z*hqLc4O%t6xO(aT{})fbgA#d3f=4g!MsS!sUjk~+oO}hEoBChk0S;40i>22UWEm*5
zOANbtm%jq>F8mjrwgi;JO5}_$f$|s+sOk}&wFHzizyZ61adN)5ii{yx^9hgc8~;UB
zL9(5!a>}5F94o)_<n`WW3imHUawKRl?7yhzVo-8?;L**yUkQ|OEEi8^^-*JT4W6v)
zqr~*nWpbd8l*e5caB)^*<8kmmvq!JY4{#&Oc`>Mk!fFF<cAWb!Y7FKxdw^#+)W958
zaj@jQ*G$H@U&vpayxGT%v-=3BaJOwaGTF*kpEDW4ivjZlCcj`{*bkb6_vq&SFY3E!
za;5J^CZi3Lb^NTErmmTs>F3I{?f&EqeromqLO|ih$lp@R2r96cU%U+gg-$7Nvu)OW
z2GHnV3?l<W<9|^0;%@=9-#mJC8-Ft}IPMW)29?3ASJr~U^(<(V{o>>Q|BX+!9^h{k
zVFbzPc7YUvrv}nGO<VsmFnD%f{V!THpMk-#w?^f8>jB|XEuUW2q_qqTph1VTFD5+x
z|9|oUe-Y)BkN^Ll@$5ePLfC|X!Q=k{kLDjXW$qvWCKHg+tm11Y&-a&Q@(7;1&tI&b
z2c+Dmm-WmVkR4Y%y3f9t3h943`hez$!6MBN5h;&e(TFvmhK_&&sAM_&A}N4@;pI{W
z1_ng`4>W74@M7zS|NqaR3obwwgs9`|1&Ki?^J?c!P7H9+)%FLu6O`0@LsT3<<LTW8
zz^ea?2FwQqS&xbX6R0(C=7quO$>#!eq;Ca*<Dx`-C#VJX;xxp$vdy+0cPEPmnj77i
z2Tmx7{~@VJ^S|i6c?=9TY{gO@-MrraLDspb7&z_(Enol*)6JMSxh~L%(Pr|-Kn=;;
z{}>p012}xTkN+1<p9?mjRJYmo{lCed0^^lW3xYg<+oQKuz_Hhx&5?imVVBNW9-q!w
zmbA~SJ$h|#J)T?=lqlPO8{}f}94)vC`Pl8r0vi1Z_%CWRck-v80H#|4lU;(XnIc0c
zHwNo68cl8p7MXlFSb^zp(B!AVi<nA}PwoscW!m>_@_`UT%kHNP3?)vWg%i>r{&Sa#
zdGxY+JOqUeDA>TIi0m0qal@MQ6y)`Ga8Iq9HRS1JtxzSVJ*Ox8g(}IpocaI1S=IG7
z0|P_z?|-GL$63vOGk`~V|BG&zHMuWTPL2mIP&bQ#;q{f~-+xL)Ji1*}6ppig_%-=d
zs3lY4jmfNGT1>G|CL4yi7@VI8$_4x_&p<U~Z-|NlsFYm<6+8+S^pgR#(HKEvR+YSy
zmxk?NivKw|K3tY>0S_o9LUI{=dS(ASn%otBm}&jt$^H?kOcTr}Z;Mc5N_C!mGeV`_
z|1JZ=hyR?Vf*##{Adh)kpDAH|A$tNeTrm$M@Zmr6w>Hq&FB5<3F9rsNZ>-*rKv}Z&
zEojmnT(q8hu@l^nb!O>gZ3a!OI&*Zg)`1y3ovf80#&w@w)-Ox`|L+V@QE2|fS}W?2
ze2Ra&i}&Q3$PoE84?u3<0J(v8!2<>ch#S0)gWMq7|6ua_NHJmeJ0S5pC7=%13%TR}
z|G&68St80zv=)@fOGS2q3eXpv|Nj3!&YCVVIXNnl>Bxi0`=aJBsXdq+6P?Ob{dDr-
zXe|%tqoA1V)&K?AZg2~{TLLt+)OxZ+tl1LOeo;hHp$kzV08-6~B>wlvWYZX>`kP0<
zhIueDFzg3cMcU_I9EFI1=2Sei&%f9P;eyr&y;ucdM}X|>W&LpvQb$QO?*z@5fvnyL
z9;xXDDR@x}Qrue|v5yTL&#Zev$}QbLln8lr^MmR<u4Z;ihEmoSp+_d)jgeroJ~H`x
zj2x5nk;&q*j!a)3Opb~*VES}-a!;%w)BA^$_s7aI=^UPXFV>i8@!`qBaqdjdPEU@B
zvt;_uG<kZQ$z=I7LvaPr1YPU@QqdRB9>H5q#g8VZrzJ76Pd=44jrYOB|Nnh@!6T0w
zgC^&uYbvaI`2Rn6<Po%N=Ea<c|NnPNysmpO`5|aNgf}B-^0ssft00J?QsWmM5C8vn
z=~Q^F*?OQ-;}|<b^N)X}vM-Dtf~<p%LaKr};DM}74<>75%xCJ{HTh&l4pVmDWb;h>
z$wiqpLjSlK7`nYBJd!_rJJ?hz{=)A5q%0{WrTdd*vK)1cLG^a?0Rs=~8zp=%R3W?s
z59=GH+}-D1)TV&)R4F(a$)-&1%ra!+N}jwYOGWq14+e(jhw`8vw@3EL2oGkSL$BFA
zdU;juGBA8|<WMLPH@?(;&ZXCh=|ySOWZrBIrv9YO=GnH4yeIB}+z)ng=$*-pIp(5o
z5*Zj?vwL(q3V3uff<`ixK_i)Gb9B8vae#`~|0Omc(WhX}zY={A=LV>o+<o4o*K{3t
zI{Ajj!QZSe4sn16RBt#oKbH5+z8&GiEOYNQyHBs|ty_~_a_4bZ-TwdI_<yIxi@@8H
z-{wjx9|BDRH_rg|Sh_#>bpP<_<()kJ|9{Ve|5=-#$$NMA{8X5%nJ2?3e)~U2*N0n^
z{qnK{G(gP;@Jx#Ii}G6_&wvLfd%#Rkhx+9MRtAP{Uk~F;F1=2SFaC#u3K!lz(?C7Z
z8{XY5KNaE_8GJfp3>?6m$(;Gdj0%%&^A#8sCdcKA`GBMynQwXgKjhk*@WZ9U#lX_B
z;V)yU9$0xCBSV*uft91xi4xh?+a;16TrgpXhM$hiw?KNVAnreqFUoYjee(5u6`qY#
z|NnPke&pTV@<U-Vd%+||g~_uD<gH(~fg_pgzi44An3ZN(d#5DPr<e8Sl>h(1s^b_L
zzPT81c$7#r)JAZX$h&kXdw2KzP?-FsK+Et{FarZf*r%7ZdCLF)CH$ZuXRVm>|G!Iz
zvd90!KGwM}_?vkC|NsA59&FlV|H1^x1V=`Ok|+GzxSja-wJ?Hs-~r;Y>yu9uDlsZd
zeqAUd4hjg5|A#wV3@w{~F_#K<F+*&XD^g@y88q3kNX>9-GbqMEvq+-<MGrKChiVzG
z|Nq~7`v1#Qj0_Cchr44Rc=WQ$PX7Pj3+(Y3MROSyCYu#2X#2H*z03Ds^hy(m#os!O
zfq}uY_6~nbF9RsfSWPBD17LDvv4RZ9IUO#BoL#Or!S0A-WB@r0;-|gEx=Q~77#Mbe
z+HgL-tlK93|DR?VdZR?_H4jW|(ZtC-B~pwElhsR%lhwBT|KI%kpCiA^o$kZ0Bmaw@
zYy>5C)>7#g$FG1=6?hc&4wwlV$$9Dc_y7OqAGxJ0-S=N_?LP71;g$dYU+Vn*|KIq)
zYpEBTuYl8N4_G}|tK^l*drKT`<F0_Z9Gwy`OyN>5_c1Uq7~gI^$=@-Tfq}u=cG)`y
z2L9%WAWwHc_v!xbdGH^rPp|FdcayD4wWPjZ1{G8<E?fq=3Y2kQhj*WUaW$TSVRC(`
zeEmGIIM~X~V3p0M|978%;hX>-rI&gElJAswQI1f?a{2%N<`e%x9o-1fy0iq)sG4KE
zW1M5GV+?d%8fXSl^o0{x6UfdN=P!XZy=LxqlmU-GfJS&@R5&JoEmd;*d+Gmw*t&tv
zOQ6}i*EXQ}Qy~xQ%SF6Cpnlf17aF<@46jf7bRROl^y1H#|NlW#8%I5?e;4z-*n4Sm
zWSRWrBXP=>AL|(yc118SF!W}f=sx?xNfFe{`sUGn0o3K^08M&jgW7<dtPeolK2`=$
z>3X)4_uQMw3i0|(3*Sr*j2CBWc{4dH-dZR44b&`9>$VL#vz*Z_st?lI+X2$+(aFwy
zwNq5~&E$*mE<)Eqovr5M9M+d>I$pDN%N~C{Sv^5ppsgO1K1*CZlHYsu@=ka?IVnMp
zX+hoONeRkK)~_dTPq1K0teyNZL6qrI-DHkLeWstalPwdCIT~Jph92VTCYL0tPHrrd
z4DpKwb((&Frbic_2Sq0++CY<4K`!0rK?^mnf%`Y?bqoyMKbn91FXi|zT2#Zp@S4f^
zK<j}L&h8U0R-ga>|MeLU(5l139=)P(UQRxLOl&esxrLF=`Tzf$6&PNyz)gPH51K7M
zSy60lTm6!Op*Y*4`@T>2d(VS^S$%p<b6!r)E0<!q62-tUxu;ytY~DGTi(YI#2Q~_l
zlANN!DM|XpT!`q4QiMXLbCVyGn=l20Y!<7~VPvY?IoYMsUAcA5|Nk#`ocaIX)%cP}
zr|S-n*4w2zFP5JHnGa4(CTAumw1`bUQW?ioHg&Q}l`>P{)Xkn%K8#$O!4u`DUvz6s
zo?q>vlnUm4ZvD^SC;9*Xe-{fe{uY7%|NrxE<MZeZo$%sk@MPAS9479d$;CCtn8Z&`
zwyy19S{ShTXl)ZCOQa|R!({JzB_`?Jlk@8(m;_5Ech*~S+yjr-Unrh@s$Q03Bbc+g
zc=G#tMJ5TA$wCben7Vu?e`#34^kwnpS&cK9bXDhoT26CR3_wke#v`D?KX_(|i#`0}
z>p{4`nhs7*Xi=UVpQ0(?1DZtZ4i*4SFrIiJ<~DgoN<Qb=xBvflpLoF(Fj*kg#QDSF
z|Nkc#-*#+1|GzUvMZsFO{w)Ioe=n$Y=9B!`qnj1f-t}s>dB9MT;ngkj;G2^~b4gtH
z=@<Ds!5wK<{kxOfQ=Q~q-(g_z>K1v_efq_Wo&W#;Km4-b|9|M@kN=^`&r>ZXH@9f<
z-rf&)XU6`?yIPc)isw(h-;&ME<PS>TrRpzC_fHOOjgdTlmVu!ZG<Z=e_2TqCxTc7G
zlTWoSVoKRJIj>Dc;#wAHiSUos10@w6-RHq`hc9;VFfdGB)g~`AKMQ1Hi4|yI*1`DF
z3u(W}x7*A(chC9%zx(LxYiB0^OOs~x=$3u3cd}Kxox}_9VyPb<ovd+t!Tqd~Js#b%
zU3(`_Xjc_q4U+6+2Q4(H0GA|JL2EvbPCnBvEoBH&-hKMT-PxdJS*l8V85n#z)sM6K
zzMRb1VJzmc`~Uwl9^Jf4_AoHK=!U47v1hVZhXT{OtjReY`YNuVwZz?^)<lV*4|pOU
zWVpH*s7H0r1Js2H&YHZxLskJa*~tM~6RhBo{ImP~3mec76lfhmq(?Wa{56Kj0_O68
zyzUH;DI$;V8!s3@Dy$Ee$aSB8@x={f;EDgD*%_dKDdqYvYMB9E1;GRwj(VZt25QvY
z_vk+FaquTAsQu*8E4uzF!{i2YF&4Mo|Nl>(Wv)~IZ5KFKzBsoF6epmf<7FcxgQr@{
zx?W{qD30~${_WBI*#lgEsG416U}%0W?~(mK!n2#@3;#YJ3y$W8j3wsXr(eu-V_=v7
z68+|4!NFL<4O&1Bn#%t1n(sv(-2CSA|GQ7Wka7pD0(h+@{h}1=0$;d_7q@nT>jh9{
z0$SIs;20AhcX;yc4r!*anUjBX1TqQlo$TEy#blg5IlWVvY14ttJ)MUb#b-TX0Cfns
zFM#rvY|azV$PBAU`Q+4YO(r>?$rHMr^hBR9fYr2}2di1Xoq@slKd2~?2Gs&v7#J9A
zY)hE_9|w&|y%L$!BdK~Elta5g=}31wBpn^_=$1{~&cM)M%}^2mQn*HBvR#juL=Q+M
zBvBP35>=7%<eVM}86J@4?$a+0Oa+Z@tNz)>04lZB8IH5+J)X?iAu)MJkC>d^R!G{a
z+6Eesgs98~seH-s|Ns9<>7tYGa&b)N?2Tgb^qQR7dz&f8bFx!kx4G0qh_AXq-Sl2t
zox`AE70|*)<C7lU*N?Hv9RV+uUXuh$F|udD8zOA;woGQ}4`*RzVqlmY->=8Fc{2lp
z<Nwpf2V6R37jK?CyWfQAWa8wD{h`85iJ)xxqV+&YAgI#QW@KQPY&k(g!#xq4@VG%s
z3GPq)|KGFw3pja;gVc8)d(92zaVAdgoS?&Wdfw#i6J(vY%wu49T?Wd-2LDB$Cx9Fj
zqhj!1^hyG#(Rahs`1XHM1tj(skdj^>6$_Vch~(^q$>I~WmF(s*FnE5y?9(Z00~(L%
zj!|&{wK(DrpJ`S#Jj1}iaClO>gn>f0?Zkr&490Igx<5KLpZO1R>6FQ!s0WQlmTI*A
zFHr%_jOu_IHnwR8CqGC`*O+(!u0YF@_5A?`hB75ku3Z|>z~It5{{=GxgNwE7^#hah
zlOlC>zyp+E)AT`$nY1ifGa)+8{TG!7>zD`C5qMzo*Q5m9VoV)(_Ji#>_g{2U9LNrs
zjwAagHznKGcW?Ute?o6OGo(P5y~Dszo9dDL*`u5F<7rSTviSf`h&&&_3mybsST6*%
zD*u<T{XgDWqoUIMTcpO&qnq^zNO3pM2gno|TP!H-dDlY(KfZ|S1NCKO=bvU^@N8E3
z%<%v4>wd@pt~k%e|NlXA^q?^AE>ZCS?`=4IW^(kzcqS(I$$KWcNF=NSHC3Cr|GzL>
zhiJAPT02={(krICwUb#UhbW)1WMJrI2DLyGU;J4EQ-5g<sNeyuIDK(^&E)FIrc4RZ
zlQ&Hcmf!}pYdT#Ycz|?Rc_efD^qOuz#=tQ7;}lUNj(`6}nIgem17}df;NR;1|GO<-
z&IS*Mo%k=B76ne4-VkjCP;E*eZM!2t+PZJN__Z1o&%O`-i(UXNe7Ie@^2PGilV?v+
z<vC&sO7I{H*^W&<GbJ(J9n@QNJppow<O{Xc|Nl2yfEM7C_;z!@aDV^*|I7EFa*o@h
zH}nc*)-J8H_R0(2^PoZUQt`Cr+AC6}0v^esC%U;`+;#x<3I3NH>E;Hna(VIU*5;n6
zT#S04wYQ)e=?qN5RTUJwKmPN#OoSPK!f^+9RPx=~$w#JHvQK{d|NjfSm6KVfD<}lq
z1jjmmi|9X4H!U~fWglqRA8Luw&B-p))x{fCz-1VJ%V)5O5C`O_Om3R4%_OZmdHwXw
zO#ebAr_9h1Z3u%{UTXSZbWR8;$X?uCK6&X3MV34x28PL}W|%UWE}P6aQ-x1@IU>fF
zFPm&UGgsQ+AY>>Z`(%ViH_M@h6b_Dm-TW_HjTsmw@1EIYw|gb1seYh@YbUtrwrA!4
z|KC_umohLgm54wBaF-|pgM(wQ2h)rC#sB|9hGO@&fYyMVIkUNZRyea&-Xc)K0qg(0
z5LBq1_z&(w_;eri=;oE!$iQHH2_)e0UsXB~JaM!Wv>54SP~&8dd6(*M^+Lx`T~s_A
zyI=TpfAZ;m`C`g)P|wQ4QZ{%aD0}?iZ@mgCsC#)oXM&pDqTsn&P}R=gG8sIKC3-3o
zr0~RlQ9(aw&{lyYK<hHDgG72oXMk0l^XO##w*h3x3tt8Xk9v@T?GObCa0So63Qm9&
zfaIq`<Q3rZ=fLtSVDjaDpep``M<?si4PeVllstMxZ)Sj8bnd@s15BMi$ed2r85<ZF
zUJH11v-WRbFaobnW^LO5GC{T-q}}>>Ns^EC{gPO4e_;w(GjA?Pru)Nx(H7syTnjvT
z89{vO^Cc$#MfH3qCoB+Af3co{!NdA|iSU0>UXY&F1K=^r{};d;^LTfz2l@H4&*a$)
zl$iP}C+}Zi$mcU3kz#JloBVHq2h+EClRXxC^R1kRkTIP%dEvqeCgpjPr57nG%>Y##
ziruUe<}omI@^*oE!Y^LWg{Ogvxs&4-=`d+^P3~D#!6e}|nQgJJ^xpsfp({-tK!x)f
z_)60^b(8ZJ8#7gVPF}oNmFbGt<Wq~?n0mY>3oWr_+%q{~i44=5+R1rKOqhOoPF}La
z&g7RT14H)*k6v%Yiqh^X&=4Qe64R=x|Npy>d35`7fR>nAluqVbt~1$bsSwkKs>xwX
zXD}UWoBUy^1=AO|$y&=iq<2A`2AV5uy<M{LI5Tt+?Ahwcz00&2cTe8AOxnuB4OEVm
zi28K<Cb)q1hFx|9RYg19K%F@h=QLG73Tem!SBK)se9P^ac2rFETV7JXuN+j;c?-PQ
z3SmgRSOZ}wyjTojXuOyOVHmua2xf4<=mgW=4lf!Y438J(5Jtd@JP0G=MJj}m@FE7n
z$aoP9VOYHIf-nkRIF{FgZLfG?0Tu#JTE5VMut5v1UMN7=6F>_sL?G-LAT|et4Vu$@
z@uv)ANcRem_y-6ZwCLo;69^kLQ2*ivgna;{<_v@l8n=H@e*nS(O|-w*0%3zTw7ysY
zVLt$Am;+(I0I?@P*r3g?FIph%A0Y7x2pcr3@gfJp2CYSUkpN+Xhsi@AY|x<k3l9jp
z9<<x*g$;zG0UAp;fUv=%;wlif1xQ>1!gc_$c_3`i;Q9*&2pcr0{^Cn1I3x-{YF<Ft
z6(IH<2phER_QeGVy8|SCq!b+f-JpH8FLppAW`HEtK-d`|_5uid1&BQb!rlO4cR<*n
z8OIkj5cUC(cmafc0>n;%urGkv5fJtQ5ZedBzQI_}!0^HW!g&CaFoCdNfY=%k_6HDK
z2EzUUVhcdn44|ob76_XI#QsqN_Pqdz{RYC80I?rH*a{%_6$o1c#6D5-|9`zlcQ<H@
z<%>NK2@8<K1_&E8`S)T8gzW(mp8;V9fY?0{b_9ss0AVM9*d-8l28f*jVHbedF%WhI
zh#df7H!v|U)W2|na5_K|77+FX5L*Yro&jPjK-ddFY!L{11&GZ7VQ&Dj{}h9LzXQbn
z0Ahpou^c{g#-sIQNg8-F3~1$BH>Za+@7>7^3?-~DP8I+E@8;3%&Ea9qdl@3M1EjIr
zTfoDb_asDQ8AK$)!<zR$L}Us?B*DX)_bWuCsd&;Fh58l<ClVs9;9<>M1rc$Fh-i3N
z^A<ovOd%o$9@e~R5D{gFh=qqWZwy345F+B>Va*!^5&2&P@}akfhc&MUMC2_*B*Vj+
zH>@5abQ>a6;9<?{0}(k15vlO7=5>OIYzK>g3mXq>UQ>wRB8VWU)bX(9)qn{0LIgp@
zkB2p{G(@lhBnS;%=z^5ilO>bo*7Ec5Pe#;HvnNfqUaQS?ZPMn9wGB*@V|E!bZQiiC
zf0r^NQ(5)oExVnS8}t7Ef3c+xHg2^5)Y;T|vA7RjaT)YYzPLwhvcVo<zq?-l|MRzk
zrocVAPru;b4XR*7EqWOk9IcO)Xf*%$SEB5be88udcZ(OOw{^m?`GGvBbMKpdAi|fq
z<s@h{`!$zO_aV@7FR#fH_h?9fguXdhG?eJPc+(5Fv$A*c#XaRr2Y4oX?UiAAz%w~x
z?+>nk9#FgC^b3twle6}@GI91y-nh@4$wF=Nt9{3q7`i8K+Mmv}S!lELfiy<TcF<~+
zPS*{f_A0wa_l@rFuQ`spsJMW38+mrKdvx>q)`B_`$2lDN_x<rm{stPd`!DKYHhI@U
z2RFW2P@8}OwB)}xv;njs|AJ$~pY&3x*8inq9^JgpYC!T2K&^0?e1o-aDTgEfuD2W>
z{||#gC+OK^heOYqekxAZJUorbG;Q+1!wO9H&XXS>wq{zCFj?WqEv78~&3}$~GxBD(
zz&-x0d2+}x72X^C(8jIc3*DB<t;giGdyE(uI$cyOKuvt%|Ds<F!1XR@aMY;f|Nqw~
z;e(^a^Cq7^=4-U288U9t(+n~jJZ>@xGHz04ZOc55fuT4LWnlEn+{u2&rC4G>3*>W-
z%Ui3$^}Voy807&O89f1VTKD1CGB1=M;xB$R!K`@E-t_;!$K<@7QfdmJVd0J;j-ifW
zj^Ut9+!vny|G&dPnt|cPw?&YaMK`NT{^Y!kx|(yF{{L6Bcu@v62Haj|ZUT?5ygUe6
zzt{cSr~9!-FYB{8laFllt>66jKWKbr4?8FT_*+ha2F80?8|Q$A16dw8esf{xXy9+z
z3@U-9bb=epy&)<w9^D<FYS*KeHGB>OgJq<MS2xcC&u$)m{wat5i_QjzCVxvU69Yr*
z?GjFhmT&wmpc3=HXoUd-gJO+JglG5NP8XFJ*U1w$DKUMUJ$cI}BPKoW$uBl(C~x5c
zcbNEFHh~(}{|~>Gfpif-`y)a7US3S*nryt;UfxX~G=%V=^#Fg1A4nx=oi}LrwE}}j
zFRSG2$rCqAGWF?AUbESp>FBJ<Pd6(v8R<>t*b>KNCN()@iz1V-)a33h8cbhjPTsmj
zRnklcG?w=A4QS72jEc|8*N}kNK6CQtEp1HtGbhJxQ(~H}GkN~jJxsncz`UK>lN-04
zW6IQ?9JpPZNoV@xy6uwU3$;K2S;Ea+qT=CV{jYw<YmWb-DVmelZ8w!Nt%1j^R}E-F
z=H-r`pf#SNnv?%-mkE>yYvpg*{OAAw?iv*j<J+&7bf12qQS<-*%L?#zFc*~ok6zyN
zX`qbDau6Ij4kg@<4YdqX{4GX5|NnonyBcH#crU?)>d9F<q?s0nPHx}fXjD)QNx&Xp
z1>gjX7}?)H6=P(7!&LCdz63i1!(@q_a%PXJKn8>Kz4%@QHVTq{+t{Ha`wt<aFLojn
zx>ZenP%bC<pLI?H$i+8zf{q(`as9;P&&S;r%;4%?JGGvy(6i><Fol7kSj{6Dbauds
zDU+j4$n$=$gxlIuIl1kGJd<<U<mD&iETfl!3QOIV3I+zBURB*G;3QLG3Yu4TSO)4C
z|0~e|ag0Igy3czgLuQv%mQ4;kDLYyEB)9gjr66VhA$s0|IZ!<hmV)XexSoqkCkLL?
z&|VH!^1s9oWb7<3=U<5mh|`OzzHaH{B`5Wm_=G24IqAUkX2xW(Q=#ThLHm-rK?`h*
z&%EFW0$BiBUEH0cQUN;20X*Uf8fFenVPG&m;L&`N(ZiBgpkwl)Q<+S<;gfk!S1_Gc
zp4@)gmT}GGqo=)?9F->vo>66D3Y%<k#)D}`=wypCW|Ip##l&v4o~%f>=2f4-z)&3T
zk^Ix6S66-l!{im(vP}09Cm+{VQ#1#S33R)BW$@^fVK+YTTI_{sDLj<DO8@_#%%@|*
z*U!LEoavE#)1z0nyq{rmfQ|~2e&XaZ9Sx;6Wl&_g{AKWH=3xfST#CJDE`b{WYEMl*
zprfQ&R02*VFTCJ#uYFrjRv23I9_eFXDAx2yzUa}*yQhy~GPkaxs0LIu16=is-r~uQ
zx`qiseGClEkL5kGZ%24{n>+(AMs2P!=3yu`>GkJ)vAOL3{|OMjlt-_Ru>f=>d9)$}
z!}lA~mz00~cQNMK37XP<(O&xhf9wAee(!FcXCA#ik^=ulRTL**($!!-)ypvXudX!9
z69oo_$qK0=lMVDl<;6kD50tWZAA7kCv}O48i?^kq*_Qtvy{yT-43kszeCk1s=LyZ#
zJPf6Z9=+Z$%k30Eg+M8{OK%3FOJ|OX#%t#P&QM1rmHhwj+WNLM1*HDJD6;|s!#8IR
z#u6R~|F=8?!)p(Z=5t_0_Q#w#7(F_TeR^3}^)N7aYs-A_*s-`<Z`X@O-FhD1Ur*N8
z*JjS@VVE4NFRwTOG?3Zpq5|3oTvF_j3|fO^(!;>u*~xODnN_uiVe(x4G#1C=|Nkem
z8z@Rhbo!`pfNB-crfQGmpUwaOl?uH0Rxo+NPI1x9ZU%<pT95Ag9^K!eQvp%klh5pw
zsz3DS|9|MHzXS(kiFWt-7uJ73>G{Ne(Jpzgzq$U4HpqgCQ_#xE*4rhbFJ=~iin|v@
z1+a7iDLmvrmCxbV!Y?A>5-*<RgDWf4$$&E+-A6n+BRD)dCv&C?PQG+Tj7ea^<X2~;
zn7;H+W;?6EbV_cr#@YDD%zTgq;7adX-v9qEK?}Hix)ps}pYXRlW?*30Wy=6ss(9wb
z5--s3=L_(b=~JLdbL$8EEe9Durzm7Fd32jr<bx`gzmEJ<j(b>}7UfTVa8^U}0BC#x
zw9p<jB2>!J>%sZrqc6zouAqZwN~Ars--D)p47n#8o|CitnFku9`37s?vEIyMU}*hc
z;t6U)xxDb+1X}II%9GE)@Pd6KXyCB2@`c$35Tm5vMQYyU-gBn5ZF|6q^1&t@C^_uW
zso~LWS^(yLD^-B(r%r?@iUNxsD47RQ<efM9|2ZS3>+2>PpEqE7nmal5ye88!pUD%>
zyGWPhf+h?=>s(%Z1!-<QP*VN6$fMgdI(PE>^MUbGAcFiY9-vcElF$2es+{oY%sIi~
z+o|W#$@(&ffx*QxN2Q{q6tvY(Z{7d@`#?i&9=$wl-Pc}tf!eW<UA>_odA@c3|AUWC
zIPcLb!uBFMcJllSN}BnS;H1LWeER<j<s49~fp+nNiqlAMPzL#5!VS{w<30J+1zD~v
z@VeA9FI2rJ3trS_s_~v|cQJqR%k{EpPQL&Dzs~Y#y;REnBF^jo|JN}d&A%R$J9~8V
zUao|lg4252gWu%_cptS7XqUex===xplwE1QCF}J{2JnFT=@)Mcz~Qg$(fs>C*<Mhy
z^LD}i|1S<@P0raMt-Ul06xTQYi%t;-kB|Ch{r}&|{QByP9+*TmM8YI%@}>=@Qm$Db
zZ-G`886S9U>&d_V2B_c0@nYlg$&4Gdm<)R+>u!{oe3DCi@{x<e5}8jSDH1dx7~s<D
z&SZS4``nA*r<31blr-8R#=zjXA5?wzhI4p;4q!O`U-UY7iV>8COATLSWx_0b5uf@0
zfA{1Z9;wM8msIPWpF!$59*-Fw+BZB}Z`Vn`zWqWq6SR(vwUqnC?+lPe(7HyC=JWp@
zyRUSgdodY2f5a&U8Z12O(R~86u2ox%f#G#%Wh`j(R`=EJb1(9qfJR|K!_^_69g*i=
z1cDZ1fW|Rzh=R&q59$9N-|t&`{6Fu}{QrNc>WfKmn_eu>fCgomC}@%Zq=3JL??0&5
zbifmAy5N(^hL`1-t~N~$ynI%*EFI)XaK2_v|Nnmni1nJQn{`_`14AbxsKPv=ad`6l
zE1q&3>Hp!&NT#HLmyx7+bcZ^4^!h${v3WAvRb!#&9smEo*pvn`5tQa$EKi&4ebs=c
zH0}TY-gu=>i5JXiliRNrGR+W~{OhVT(`BK_;@9MaU$_7N|6*I}|Npx|3->xDUO1&r
z_PA!CkOnG7J(}NGcy#mDq=NbxKmV2Tyzm6IAG>+8QYWWeQD?FgncRCtVsh;@af1yL
z|Nrj}2CwBi)Kn_@;zJ6^A)tm;v$ur8j{pA|7+!(~hrS(hDB*o^DP{7JYmPdPqd{Q}
zTjO^X!h^5z(|rX>wvaV`XJ1Y>yl%v_^Tp)U>nggl>mUR32Y;}ltns^?gt5j?<-z1_
z*L9ezUQB*+-9}4c>Hq)W33-oR4@Qsf4=<iOfnp52S6|PgH;fTH<9XsmNXTTb8!}8v
zNs}{f7}T%P0j;z-xr>2;!NCQzE%d+WPC?KbV%ATfxya@t9*`5OJi2)wf(3s5FX8cM
z{`s$j?Z4=KP)`W7_vOE8hyVk_f7LKBnIHfj%m<x*a>gMPTvv6!^62&rc+nLNTEftL
zL?QMtL}oJoO<|d;6f{u-53u@#7e3LG*WZ+oHA2@0Qm_-WNA87o%H;JoMJM08$<CCx
zV)D6Ll98X1(M(eSo5rgZ0_w8%@PqaQBe?)1+gzK#P{Lt+^2Ii6dUt|y+KbuAlkINF
z=~QD=@xsy;VJFzzU}AFZEfX_oY#MfgikKG+*rY(gH2Ll1m$ziOJ!(PCHjz^=zDG_L
zysgMICuy?pZ3CuPRg>#)i!%LxGuiH@q^v~}!fJS6LmE%ANt5kvNh)wNFfhFMn}|hO
zx39yC32!E^zwK7vpa|MB#K6!8r58Zybx`^Ql)eU~UqI<UP+CX{qF)b6dqL?KC|v}l
zJD~IuD7_0p*E5`hFc|JZ>32|?K^bDO0F>5%(pFIVj5<Vq50qX9rKiAXsJazUdIyv~
z0;Mm2>3Rl+M_>j6!xt#c20a#03QB`^v4ZwShd}umP`U<6PlM8{p!5zXeE~|pfYJi0
z5C<zjX$uft51PXQF&G#a!k}~tl+J_Fbx?W=lwJU(*Ffn*Q2GLtz6YgWLFq40nn4ZX
z03j%?q{heqvY$Z@D&PR6{h)LLl&*r(Q=s%JD187*--6Pwpfm$C3Z$U45|lQ8(l$`q
zN1f3g6tWC)P=P!s-2|oYL20le1_p*4XcUD(=?dlPj$VuslP}!nlX+vs02-WUQ1OM(
zFQOszolXV^kSY<LEe{|fXRIM2AbkR2u;V;I%_3h028Ihlj0_ikO`dgMkJG?~5p3jz
z%@^;BbJjcjf#?Ud#y~E5@EgJhRR|z{1C$Tyz<~G$P(J7k01*GeFNk_U5Ql+*p#aJk
zg7Ouhd|@d6z)y&J&<s2S14BJS08~H{s(=B?2kqtt2~GF`(EvJ80K`{-@<C$^ApV8#
z5P3Ne2XsCtlrInEANU55SAg;ZpnOFzKZJoH;R{4T1z3QA!2!yzgz^=j{3<A)0m=t$
zjsgk&_zckxIyMKyzwvpq)vGjt$q#-xL>8B%WacTPlosS<CMT9;=I1G-C1&QNrhwFe
zaB)dWerXAA1;r&PsYOLt<R^Fjj^E7jr-oUef9<T`){_QK+dM6I@YK1kn>^)ziNO;K
z2GCRngOeNsL#iAD!w1lu69WT7mK*~^9TK0BjfsKHh{<580i%i#NE0YC2`e%%C@L{9
za6O!w#%RYRkvw%7qgOplwn3YLVWu_%gC1xR5Ca2)AU_KOzX>}7zY%u<OwC_C1_pM0
z1_sc!9*{Q~CAb(QQg|37Lbw?uOt=^%f<!I|9S|sBWMO1rNn&6S6k%f!N#S4+F=1yA
zF%p2Av(|`#VUH2m9B`gy5R~L%kUYZ8AX&o2Aeq9+AZfzEAQ>cj0c0^KtsgXIV2Chb
zU`T>GF3p62p&E(L$i>3IWx~e5WyDs1&EdyQ85k~t#(|;wIeA$bcum9^cp0akV`5|z
z1K9%#qV;AB3?b$W47CqI^z>Iuj6r5Fxli^C3_^|!46~tTNa}Gi$fg`&kTp5XAj`Oq
zf$soM0e1icgG4d|!vogoLClPLUV@?=45B3*45BIQ45B7%45CJYU_XKEvUX!&sB~js
z*akI^6BKAp3=A;)e!4L*{B?uuefsM*{T?%;6g;vfdN44^donOwf$9}R@;^vFD9qBl
z7#Iq?7#Kc5)wFssFs$)nU=Vr)iaG`cL17jKVH0)+VIzKU#DMhh_%JY7`XKap`!Fyx
z`M~usGE8q^VU&OeNtZ7JLx3LxgD%uabT1tDXJGi{&%hAy2t-f6#lk4ZB#}J*7Yn0Y
zJt&w8SQ!|gNi_iC1$J;0g1i6<qNXqghMQpw3`J1$CFMC71WW`N1d4bra2?<%U{7ER
z0GR_iS{Ppv0-5z9ih*HDG~6s*20>^Zfms$D&%lrw&%n?NwTw}Sg+a)KmqBO}cfj-q
zjEtc9!RcvijA2GF9T)N$7?=te7*@b^$Z#{rlt?hhgorc9n20gRFbXk<J`lbjcwqWI
z4n{F}M!Z<Uz`$Gz(l?!pol%Jm<b?|?)8*J0rPM%XgJR-U69a=@GXujxsM#Bv7#Q4}
z85ll-`O}Tq8P$V8nWluBK{ADlK{5oMX$}YqvM~sna4`rP@gCqV;7R})2?_!BP6h_;
zP6me6pb-lO1_nkE4hE4FE(VbhP6iPZ4hE4Rf$8Dwj8@YhvNDQ0K=L*hgG2}?gM<kO
zgM<+zZwvCXG4Q8wGVq&lFz^Q<$_BA13=CaU5ZPn;1a?LpxR*E1VPLp2hk=3T@$_@-
zj9MHZFMBXBFihv*U{nC52`vsrGZ3A`!DuyIgp*NZx&tSp3`iu7lTk_(<_FIM3=Fjg
zKtTu6Jd=Y_9;9R!2cs0+s@@X}4Es-jluYm9WRwEQFXLpCX9q=h5tG6624+T)=?RRC
z8gL!&&NDFZUtnMeeLQ^@BcogZ$TCnIfX<&YxyZm!01dD$AT^g57$!jZxB~j|B?bod
z%ZPxUeutCMS6q~hLDWQmL39&e0dE3N03#<O17{Kg!*mBOMqPezpt3XYo3Mck-02lu
zj51=NKr&!qV30IoVNhV?WRxtBFpx-|zKV-cPDWCjok6O^gi*@Gm{E$+fDu;m6mT*y
zOh3WJC_9~#n^E2rWW)q^1_p46?8LyZLk^S@AO(O2sA2Mffgu6fItGb$C^Iswm|n=u
zC_d4EWwgCL+TI@0?d>K$#xl`kjP9u=&ZR{~sd*&<Mfu68#l;L9(*^k%MPwLq8QoL!
zQi~ExQl0bjit}?)olA;xT+34PN*JcA^E38NzsAq#W@*Rllb@L4lbKYMSXAlAz+lZ1
zoLYjU!6Pv*B`39r;SGZev_+T-5t?2pz$iPNO^~rluz<-uwIsNtC^IiTq_QA2oMHM#
zAx2@rEQoMoQAufmXI@%<`1C{}M$zeq1Q{prs<H%?<b>vxXXd52R!pxKWHg-KCB&$~
z|Bk^mFF8LYH6TATuOzi-`b8ne&(rS-Gs?)<fE)&~+Bv^8uY`f&7s&H&nK`K-OQ-)7
zW<0BSfF(F5HMM}DpTW5(HL)ZWBpc3fhsh%~u^>3JDwSdSTM<TO-YFonf=g1s#!crH
zWpw7f1y&Q3>X?(0pFG`Pl+kti0ZB#$A%_G=*8^05fUrZtb|Epwb<C4L{AbzzM3Qk2
zvroW6NMo8BG^m3lF*)G9*LFWS#z!pm1xyg@bD(qvlum)t2~au)N=HEH04VJNr5&KO
z0hCsN(jrir14^?%X$A;g&+vy4;(#Ae`U{l)0HxnR=@(G?36y>SrSCxL8&LWJls*8Z
zw?OGNP#R|b5-^{cfnm<{L={GH#)j#IDvaWa5ny2kh7c(20i_L~w8Hd86-IGO2`E<p
zN^?MI1}Oc50phC<Q2GUwzA^o!3Zpz{2b5be-BOiN-_ZifHGt9@P+9>>OF(G>D9r(-
z8KCrs=@V5M#U*$AholpjaVwzw8PhkaGK$+KK)D`J+5k$cKxr8$%>kt!{DT;G0z^-@
z^J0{q9PmD1dW0I|0hR|&jNrbur~nJZqZ2qFw7_&nbw+U(7B+}HD5<TP-k`zgz{vnr
z$uvDuoiQGi_&Egi7#J8p7-Sr%ZoM%5qXuI*<CW>2nvCI`6+93#Gp4W9WQ>@6;kH1%
z00YBm0S1OAvWyI81Q-~m3o<ZVkY!|;A;`e+Uyy-egDfKhgAfCQqX+|ojvOO{iwFaQ
zt|$Y;0a-={15pNs*`f>#7P5>Cb3kIE3=9Qwj0^`v85rJ)GcX9qF*1A*XJGgv$-wYK
zmJv)>$TBc^$T2d2=q6bPhI){O1+okb`(+sz9E2Ge4#+Yv%#~wca1mx?SRlv1@L7(5
zp+T6DK}4Q`!B-x_4v=SHNQ1H)<QW(aL)k~<85q9HGca@rGcx>;XJ9Z?U|`@8Wn?f>
zU|@I*Wj|41U?^5%V3;Dz$goC<p`PKA62#CeN(>Bw$_xw<(u@ou$_xyl$`J7gWd??y
zQ1%~X1_mKj28JUb2dOeJtWkyd7(^$jK|-rRje#LsgMs0WFe5{b1_Q%(4F(1l5k`gs
z8Vn4NG#D5JL>L*KXfQBHYcnuNh}1JO$Y?V#9M)!FFc4v6IHJwK@KBq9VGc-<HUoo~
z4#Yt|It&clx)95FbQu^9=`k=okYr>yqQ}4>qtC#QAi@Zy%?ubAOe7c?EI?~h3>g?&
zL>L)53>g@f8A8llVaUJ`WyHXcBE!fKW5mF4t=@=%VTlMM!wt~#cVmbTrWi9YOfz9%
zI3vQyFvEm_f!P!i5-g?+40WcEAZ;*ZV0dQAz#t*Y$ne6HfuYfyfx$+Uk)g$$fnl0C
z#Gy0H85kZ}FfgQuGJ?C253Lv&azq&!-dHg(oUw+OSr1}-wuWf<V$Hx1ZUd2suwh{6
zgtC9wFfd%TXJF_MWn{Qv&%mJX$iT2fl##*0k%6JviGkq^$YLi3hOJHzb9Oi}FsM5-
zFr1NOWYBPCU~qGW_<n*j1H%Sqh#C-m!I_~RoMJCHGcbs`KrA+JVPFVxVPN<m%E*x5
z!oX1B!ocuDl#!vqg@K{bg@NIZC?mrJ7Y2rjE({C|VvGz^To@Q6Tp1Wx#2CT!e9&Dt
zGK>s6Tp1WZd&eZi7#SA0F)%!FgM=K2W_M>`a1mo<;Bc>JU{H03xG2J%fuYNjfgweV
zkzt7^1H*Msh=ZPZGB9w0de3r<3_M;83<td!7^a9ZG92+@VDRvU7z(0uydmmA^n4!%
zh7%x*eHa)NeIep1z6=cMP<Dnd14EG?1H+$sF-C?GKL&<wKZqlG{1_OH_(2Q>(SM+9
z5N+fS5kKJ1z`z*5z@Q_}$Y2n_z|b4Sz~Cd!$S@&@f#Grx#GETZ3=CSq5VlS*1H-Xk
zh~5*y3=AP5kOT;#>s`Va7z)H089?;EFb0Mh;*1Oo;S3BD!WkH1WEjCTYZL>+9&ttn
zjwl9(XVDA{H^dnkUPLo62*f}vaEN7K*ck^&ynEsp7=+^?J{E~*VCalzVBnBoWax=!
zU`R}0V9=0YWJpP1VDL%==ahN|pF{?RDM<_rJ(7%IdQ%c4v200VU=UA+7zFCKm?lFk
zvq)xOn3~MMFhiD+;X*P4gIo#&Lx2P$gF*@e!`f5^h6o8ph6AY#46D)@7z!j98P=pR
zF#Jo0IF2EMfk8Q+fuTf#kwGP&fx*6@o`Io9f|0?YfPo>c0AfK#0RzMP0*HnW1q=*_
ziWwO8NH8)SDP~}ZDuIZ{lrS(@mohNikYHr6DP>?NE`>O>q?Cc-Xek3ji8Ld_iBblJ
zq%sBu11Uy^lrjc}eT@tZERu{22O1d|ESn(a*wi;MFmyCQG=u1pW(EcgNk)c-W(I~8
zEes49l8j*5rWNA2h*ky$*)|4-8c9Y5g*FC;&~`}3MYJ<8+-+w77c39j85rhtK;j!j
z$9FO?ERkenNa$o>nBEDoYepvn!_7`;`G2RAf#FLh!~zg~q#I%oh_>y48065yz);W&
z$<rX(z8_KoI`lIzm`wmxGK>rs6BrnDCPIp55Pg3l0|So~Bg2b{3=C<L7#Jj^7#T7q
zF)+M_vfoT%sAnjg43Q|A%)szxG9<V_^s*@o3?5R93@fHEFa*qDU?`Ac1k*}$85kx=
zF*2ykWnc)K3rQ<2a~T+p%!PR1!CVFgk%bHlJER!FwC_TQc)>yj28l%s3<snb!L-5>
z28JV2^^6Q4#?mE_U|F$*fuVdUgk7<efnmo|h-MJow1R=*ffOS{%L)btsg(>29MX&o
zGAkJvs#Y;DNJuj>)U0A)__d0G!9kjl;m;}thF9wt7y_gj8Q!d8V2D@`sYgI`(guil
z$_568qxBmgmOa?Oz%XGW14Du|Bg2A?3=HX;7#K3785tTjF))~JW?(3gW@NC~%)n5$
z8KS;nGXulL&5(q4Witaq<`ziE<!oVKu-?zW&>_vpV6&fr;o^Qs^j+D{z_9%Q1H&3=
zMur^+7#Ji@FfiPZW@M-bF}|N*VE7}=$nfI?1B3TThy^|;85mZdg!q09h<%!YK|_X-
z0kq%G@+<>`iwq-!%UK47&a;qmqUS6F!(}M@%2@`6#&eJ~)N+o2LGL^RLxl_@gTZ+Q
zh9&1AW`bzX3k>xP9WsmzB^MYNYA!J_?2usu)4`V+7=FkwGK5@aVEA<zlEVL7W?<NU
zoq<6?mXTq{bp{6G8<3Wd#|;Js>6?)3By*F2VG)$Q<R$}y4d_TKSw=9;b%%i=MV66)
z=MDpd^&N;KZ0>*tobNF(<bax4_ZS#N?m-e1h|ayoz)&O0$WU;Pf#Lss28I@png<LF
zr4Jy5PsIZUhRqKc7*@zKGHiLkz;NvW#8A*EJl8`8h6&<~3?LdbgbreZXwXo32k0)O
zhmg_h3H9QP;9+dg5Hm;uM1zKuK^j0bXgC<e2GOA5T@V{YgNAWIY!J=+2x1v%C>J#L
z3K9p=&QNjCcq?ek6eJF!K|`7#Hi%9GjaGs<AR08f2x5cimr%{15k{WJ5DP$b=wk*3
zkV8Q<Xe11z9z=IT)qqCBKtqZkaS(k3EDr9ZZExsilw*_y9bv}6z{~*Ja;U+;(7*?p
zPhwzb0L>M3OxHDI6i-~hzyR9fz_5dXp#h}q0s{l+;uD4!3=E*dVL_wd4WJX8Bp4YQ
zKvU`lj0~W&2td6}@D*<$1*xFvNi5=^R(Znoy=IK!ETA1O(+`+2im-t8v_M#(O)L-=
zXxj>e1=^?rVS%=$Kv*{z85qE<deDv&u+0pR`{h8EbFwfnfOed4Ok!ks!NkDu1mbCi
z4^tQ!Kznsye2Hm{3@bPg@(1QIGGwqK_!>(X8CIww_!mwxGOQ3l@GEXH$}?oJAOs%V
zV+2)la0@-|Z+Eg_^z+?5qk}PnvEIeg&pp7=1w=(eKp9Yq9{hT+&2+R7&Axhw*Qx0M
z&}D|8mgs{;FBW}R^kb30Vu{5aizh5zv1Z4b6Kig)d9mil8jiIRYc<wdto4|#+Qlf&
z4Z7D5v};UZfx&eDF2<+235zlo-B<)OfnhPnVvs2ci!~NoEOuDzu{dCH#Nvd-8H)=R
OPgp!-dtx`^d?o;n1Xor7

diff --git a/env/Lib/site-packages/pip/_vendor/distlib/wheel.py b/env/Lib/site-packages/pip/_vendor/distlib/wheel.py
index 1e2c7a02..028c2d99 100644
--- a/env/Lib/site-packages/pip/_vendor/distlib/wheel.py
+++ b/env/Lib/site-packages/pip/_vendor/distlib/wheel.py
@@ -1,6 +1,6 @@
 # -*- coding: utf-8 -*-
 #
-# Copyright (C) 2013-2017 Vinay Sajip.
+# Copyright (C) 2013-2020 Vinay Sajip.
 # Licensed to the Python Software Foundation under a contributor agreement.
 # See LICENSE.txt and CONTRIBUTORS.txt.
 #
@@ -9,10 +9,8 @@ from __future__ import unicode_literals
 import base64
 import codecs
 import datetime
-import distutils.util
 from email import message_from_file
 import hashlib
-import imp
 import json
 import logging
 import os
@@ -29,7 +27,8 @@ from .database import InstalledDistribution
 from .metadata import (Metadata, METADATA_FILENAME, WHEEL_METADATA_FILENAME,
                        LEGACY_METADATA_FILENAME)
 from .util import (FileOperator, convert_path, CSVReader, CSVWriter, Cache,
-                   cached_property, get_cache_base, read_exports, tempdir)
+                   cached_property, get_cache_base, read_exports, tempdir,
+                   get_platform)
 from .version import NormalizedVersion, UnsupportedVersionError
 
 logger = logging.getLogger(__name__)
@@ -51,20 +50,28 @@ if not VER_SUFFIX:   # pragma: no cover
 PYVER = 'py' + VER_SUFFIX
 IMPVER = IMP_PREFIX + VER_SUFFIX
 
-ARCH = distutils.util.get_platform().replace('-', '_').replace('.', '_')
+ARCH = get_platform().replace('-', '_').replace('.', '_')
 
 ABI = sysconfig.get_config_var('SOABI')
 if ABI and ABI.startswith('cpython-'):
-    ABI = ABI.replace('cpython-', 'cp')
+    ABI = ABI.replace('cpython-', 'cp').split('-')[0]
 else:
     def _derive_abi():
         parts = ['cp', VER_SUFFIX]
         if sysconfig.get_config_var('Py_DEBUG'):
             parts.append('d')
-        if sysconfig.get_config_var('WITH_PYMALLOC'):
-            parts.append('m')
-        if sysconfig.get_config_var('Py_UNICODE_SIZE') == 4:
-            parts.append('u')
+        if IMP_PREFIX == 'cp':
+            vi = sys.version_info[:2]
+            if vi < (3, 8):
+                wpm = sysconfig.get_config_var('WITH_PYMALLOC')
+                if wpm is None:
+                    wpm = True
+                if wpm:
+                    parts.append('m')
+                if vi < (3, 3):
+                    us = sysconfig.get_config_var('Py_UNICODE_SIZE')
+                    if us == 4 or (us is None and sys.maxunicode == 0x10FFFF):
+                        parts.append('u')
         return ''.join(parts)
     ABI = _derive_abi()
     del _derive_abi
@@ -95,6 +102,29 @@ if os.sep == '/':
 else:
     to_posix = lambda o: o.replace(os.sep, '/')
 
+if sys.version_info[0] < 3:
+    import imp
+else:
+    imp = None
+    import importlib.machinery
+    import importlib.util
+
+def _get_suffixes():
+    if imp:
+        return [s[0] for s in imp.get_suffixes()]
+    else:
+        return importlib.machinery.EXTENSION_SUFFIXES
+
+def _load_dynamic(name, path):
+    # https://docs.python.org/3/library/importlib.html#importing-a-source-file-directly
+    if imp:
+        return imp.load_dynamic(name, path)
+    else:
+        spec = importlib.util.spec_from_file_location(name, path)
+        module = importlib.util.module_from_spec(spec)
+        sys.modules[name] = module
+        spec.loader.exec_module(module)
+        return module
 
 class Mounter(object):
     def __init__(self):
@@ -124,7 +154,7 @@ class Mounter(object):
         else:
             if fullname not in self.libs:
                 raise ImportError('unable to find extension for %s' % fullname)
-            result = imp.load_dynamic(fullname, self.libs[fullname])
+            result = _load_dynamic(fullname, self.libs[fullname])
             result.__loader__ = self
             parts = fullname.rsplit('.', 1)
             if len(parts) > 1:
@@ -301,10 +331,9 @@ class Wheel(object):
         result = base64.urlsafe_b64encode(result).rstrip(b'=').decode('ascii')
         return hash_kind, result
 
-    def write_record(self, records, record_path, base):
+    def write_record(self, records, record_path, archive_record_path):
         records = list(records) # make a copy, as mutated
-        p = to_posix(os.path.relpath(record_path, base))
-        records.append((p, '', ''))
+        records.append((archive_record_path, '', ''))
         with CSVWriter(record_path) as writer:
             for row in records:
                 writer.writerow(row)
@@ -321,8 +350,8 @@ class Wheel(object):
             records.append((ap, digest, size))
 
         p = os.path.join(distinfo, 'RECORD')
-        self.write_record(records, p, libdir)
         ap = to_posix(os.path.join(info_dir, 'RECORD'))
+        self.write_record(records, p, ap)
         archive_paths.append((ap, p))
 
     def build_zip(self, pathname, archive_paths):
@@ -576,6 +605,13 @@ class Wheel(object):
                     if not is_script:
                         with zf.open(arcname) as bf:
                             fileop.copy_stream(bf, outfile)
+                        # Issue #147: permission bits aren't preserved. Using
+                        # zf.extract(zinfo, libdir) should have worked, but didn't,
+                        # see https://www.thetopsites.net/article/53834422.shtml
+                        # So ... manually preserve permission bits as given in zinfo
+                        if os.name == 'posix':
+                            # just set the normal permission bits
+                            os.chmod(outfile, (zinfo.external_attr >> 16) & 0x1FF)
                         outfiles.append(outfile)
                         # Double check the digest of the written file
                         if not dry_run and row[1]:
@@ -938,6 +974,16 @@ class Wheel(object):
                     shutil.copyfile(newpath, pathname)
         return modified
 
+def _get_glibc_version():
+    import platform
+    ver = platform.libc_ver()
+    result = []
+    if ver[0] == 'glibc':
+        for s in ver[1].split('.'):
+            result.append(int(s) if s.isdigit() else 0)
+        result = tuple(result)
+    return result
+
 def compatible_tags():
     """
     Return (pyver, abi, arch) tuples compatible with this Python.
@@ -948,7 +994,7 @@ def compatible_tags():
         versions.append(''.join([major, str(minor)]))
 
     abis = []
-    for suffix, _, _ in imp.get_suffixes():
+    for suffix in _get_suffixes():
         if suffix.startswith('.abi'):
             abis.append(suffix.split('.', 2)[1])
     abis.sort()
@@ -985,6 +1031,23 @@ def compatible_tags():
     for abi in abis:
         for arch in arches:
             result.append((''.join((IMP_PREFIX, versions[0])), abi, arch))
+            # manylinux
+            if abi != 'none' and sys.platform.startswith('linux'):
+                arch = arch.replace('linux_', '')
+                parts = _get_glibc_version()
+                if len(parts) == 2:
+                    if parts >= (2, 5):
+                        result.append((''.join((IMP_PREFIX, versions[0])), abi,
+                                       'manylinux1_%s' % arch))
+                    if parts >= (2, 12):
+                        result.append((''.join((IMP_PREFIX, versions[0])), abi,
+                                       'manylinux2010_%s' % arch))
+                    if parts >= (2, 17):
+                        result.append((''.join((IMP_PREFIX, versions[0])), abi,
+                                       'manylinux2014_%s' % arch))
+                    result.append((''.join((IMP_PREFIX, versions[0])), abi,
+                                   'manylinux_%s_%s_%s' % (parts[0], parts[1],
+                                                           arch)))
 
     # where no ABI / arch dependency, but IMP_PREFIX dependency
     for i, version in enumerate(versions):
@@ -997,6 +1060,7 @@ def compatible_tags():
         result.append((''.join(('py', version)), 'none', 'any'))
         if i == 0:
             result.append((''.join(('py', version[0])), 'none', 'any'))
+
     return set(result)
 
 
diff --git a/env/Lib/site-packages/pip/_vendor/distro.py b/env/Lib/site-packages/pip/_vendor/distro.py
deleted file mode 100644
index 0611b62a..00000000
--- a/env/Lib/site-packages/pip/_vendor/distro.py
+++ /dev/null
@@ -1,1230 +0,0 @@
-# Copyright 2015,2016,2017 Nir Cohen
-#
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-"""
-The ``distro`` package (``distro`` stands for Linux Distribution) provides
-information about the Linux distribution it runs on, such as a reliable
-machine-readable distro ID, or version information.
-
-It is the recommended replacement for Python's original
-:py:func:`platform.linux_distribution` function, but it provides much more
-functionality. An alternative implementation became necessary because Python
-3.5 deprecated this function, and Python 3.8 will remove it altogether.
-Its predecessor function :py:func:`platform.dist` was already
-deprecated since Python 2.6 and will also be removed in Python 3.8.
-Still, there are many cases in which access to OS distribution information
-is needed. See `Python issue 1322 <https://bugs.python.org/issue1322>`_ for
-more information.
-"""
-
-import os
-import re
-import sys
-import json
-import shlex
-import logging
-import argparse
-import subprocess
-
-
-_UNIXCONFDIR = os.environ.get('UNIXCONFDIR', '/etc')
-_OS_RELEASE_BASENAME = 'os-release'
-
-#: Translation table for normalizing the "ID" attribute defined in os-release
-#: files, for use by the :func:`distro.id` method.
-#:
-#: * Key: Value as defined in the os-release file, translated to lower case,
-#:   with blanks translated to underscores.
-#:
-#: * Value: Normalized value.
-NORMALIZED_OS_ID = {
-    'ol': 'oracle',  # Oracle Linux
-}
-
-#: Translation table for normalizing the "Distributor ID" attribute returned by
-#: the lsb_release command, for use by the :func:`distro.id` method.
-#:
-#: * Key: Value as returned by the lsb_release command, translated to lower
-#:   case, with blanks translated to underscores.
-#:
-#: * Value: Normalized value.
-NORMALIZED_LSB_ID = {
-    'enterpriseenterpriseas': 'oracle',  # Oracle Enterprise Linux 4
-    'enterpriseenterpriseserver': 'oracle',  # Oracle Linux 5
-    'redhatenterpriseworkstation': 'rhel',  # RHEL 6, 7 Workstation
-    'redhatenterpriseserver': 'rhel',  # RHEL 6, 7 Server
-    'redhatenterprisecomputenode': 'rhel',  # RHEL 6 ComputeNode
-}
-
-#: Translation table for normalizing the distro ID derived from the file name
-#: of distro release files, for use by the :func:`distro.id` method.
-#:
-#: * Key: Value as derived from the file name of a distro release file,
-#:   translated to lower case, with blanks translated to underscores.
-#:
-#: * Value: Normalized value.
-NORMALIZED_DISTRO_ID = {
-    'redhat': 'rhel',  # RHEL 6.x, 7.x
-}
-
-# Pattern for content of distro release file (reversed)
-_DISTRO_RELEASE_CONTENT_REVERSED_PATTERN = re.compile(
-    r'(?:[^)]*\)(.*)\()? *(?:STL )?([\d.+\-a-z]*\d) *(?:esaeler *)?(.+)')
-
-# Pattern for base file name of distro release file
-_DISTRO_RELEASE_BASENAME_PATTERN = re.compile(
-    r'(\w+)[-_](release|version)$')
-
-# Base file names to be ignored when searching for distro release file
-_DISTRO_RELEASE_IGNORE_BASENAMES = (
-    'debian_version',
-    'lsb-release',
-    'oem-release',
-    _OS_RELEASE_BASENAME,
-    'system-release',
-    'plesk-release',
-)
-
-
-def linux_distribution(full_distribution_name=True):
-    """
-    Return information about the current OS distribution as a tuple
-    ``(id_name, version, codename)`` with items as follows:
-
-    * ``id_name``:  If *full_distribution_name* is false, the result of
-      :func:`distro.id`. Otherwise, the result of :func:`distro.name`.
-
-    * ``version``:  The result of :func:`distro.version`.
-
-    * ``codename``:  The result of :func:`distro.codename`.
-
-    The interface of this function is compatible with the original
-    :py:func:`platform.linux_distribution` function, supporting a subset of
-    its parameters.
-
-    The data it returns may not exactly be the same, because it uses more data
-    sources than the original function, and that may lead to different data if
-    the OS distribution is not consistent across multiple data sources it
-    provides (there are indeed such distributions ...).
-
-    Another reason for differences is the fact that the :func:`distro.id`
-    method normalizes the distro ID string to a reliable machine-readable value
-    for a number of popular OS distributions.
-    """
-    return _distro.linux_distribution(full_distribution_name)
-
-
-def id():
-    """
-    Return the distro ID of the current distribution, as a
-    machine-readable string.
-
-    For a number of OS distributions, the returned distro ID value is
-    *reliable*, in the sense that it is documented and that it does not change
-    across releases of the distribution.
-
-    This package maintains the following reliable distro ID values:
-
-    ==============  =========================================
-    Distro ID       Distribution
-    ==============  =========================================
-    "ubuntu"        Ubuntu
-    "debian"        Debian
-    "rhel"          RedHat Enterprise Linux
-    "centos"        CentOS
-    "fedora"        Fedora
-    "sles"          SUSE Linux Enterprise Server
-    "opensuse"      openSUSE
-    "amazon"        Amazon Linux
-    "arch"          Arch Linux
-    "cloudlinux"    CloudLinux OS
-    "exherbo"       Exherbo Linux
-    "gentoo"        GenToo Linux
-    "ibm_powerkvm"  IBM PowerKVM
-    "kvmibm"        KVM for IBM z Systems
-    "linuxmint"     Linux Mint
-    "mageia"        Mageia
-    "mandriva"      Mandriva Linux
-    "parallels"     Parallels
-    "pidora"        Pidora
-    "raspbian"      Raspbian
-    "oracle"        Oracle Linux (and Oracle Enterprise Linux)
-    "scientific"    Scientific Linux
-    "slackware"     Slackware
-    "xenserver"     XenServer
-    "openbsd"       OpenBSD
-    "netbsd"        NetBSD
-    "freebsd"       FreeBSD
-    "midnightbsd"   MidnightBSD
-    ==============  =========================================
-
-    If you have a need to get distros for reliable IDs added into this set,
-    or if you find that the :func:`distro.id` function returns a different
-    distro ID for one of the listed distros, please create an issue in the
-    `distro issue tracker`_.
-
-    **Lookup hierarchy and transformations:**
-
-    First, the ID is obtained from the following sources, in the specified
-    order. The first available and non-empty value is used:
-
-    * the value of the "ID" attribute of the os-release file,
-
-    * the value of the "Distributor ID" attribute returned by the lsb_release
-      command,
-
-    * the first part of the file name of the distro release file,
-
-    The so determined ID value then passes the following transformations,
-    before it is returned by this method:
-
-    * it is translated to lower case,
-
-    * blanks (which should not be there anyway) are translated to underscores,
-
-    * a normalization of the ID is performed, based upon
-      `normalization tables`_. The purpose of this normalization is to ensure
-      that the ID is as reliable as possible, even across incompatible changes
-      in the OS distributions. A common reason for an incompatible change is
-      the addition of an os-release file, or the addition of the lsb_release
-      command, with ID values that differ from what was previously determined
-      from the distro release file name.
-    """
-    return _distro.id()
-
-
-def name(pretty=False):
-    """
-    Return the name of the current OS distribution, as a human-readable
-    string.
-
-    If *pretty* is false, the name is returned without version or codename.
-    (e.g. "CentOS Linux")
-
-    If *pretty* is true, the version and codename are appended.
-    (e.g. "CentOS Linux 7.1.1503 (Core)")
-
-    **Lookup hierarchy:**
-
-    The name is obtained from the following sources, in the specified order.
-    The first available and non-empty value is used:
-
-    * If *pretty* is false:
-
-      - the value of the "NAME" attribute of the os-release file,
-
-      - the value of the "Distributor ID" attribute returned by the lsb_release
-        command,
-
-      - the value of the "<name>" field of the distro release file.
-
-    * If *pretty* is true:
-
-      - the value of the "PRETTY_NAME" attribute of the os-release file,
-
-      - the value of the "Description" attribute returned by the lsb_release
-        command,
-
-      - the value of the "<name>" field of the distro release file, appended
-        with the value of the pretty version ("<version_id>" and "<codename>"
-        fields) of the distro release file, if available.
-    """
-    return _distro.name(pretty)
-
-
-def version(pretty=False, best=False):
-    """
-    Return the version of the current OS distribution, as a human-readable
-    string.
-
-    If *pretty* is false, the version is returned without codename (e.g.
-    "7.0").
-
-    If *pretty* is true, the codename in parenthesis is appended, if the
-    codename is non-empty (e.g. "7.0 (Maipo)").
-
-    Some distributions provide version numbers with different precisions in
-    the different sources of distribution information. Examining the different
-    sources in a fixed priority order does not always yield the most precise
-    version (e.g. for Debian 8.2, or CentOS 7.1).
-
-    The *best* parameter can be used to control the approach for the returned
-    version:
-
-    If *best* is false, the first non-empty version number in priority order of
-    the examined sources is returned.
-
-    If *best* is true, the most precise version number out of all examined
-    sources is returned.
-
-    **Lookup hierarchy:**
-
-    In all cases, the version number is obtained from the following sources.
-    If *best* is false, this order represents the priority order:
-
-    * the value of the "VERSION_ID" attribute of the os-release file,
-    * the value of the "Release" attribute returned by the lsb_release
-      command,
-    * the version number parsed from the "<version_id>" field of the first line
-      of the distro release file,
-    * the version number parsed from the "PRETTY_NAME" attribute of the
-      os-release file, if it follows the format of the distro release files.
-    * the version number parsed from the "Description" attribute returned by
-      the lsb_release command, if it follows the format of the distro release
-      files.
-    """
-    return _distro.version(pretty, best)
-
-
-def version_parts(best=False):
-    """
-    Return the version of the current OS distribution as a tuple
-    ``(major, minor, build_number)`` with items as follows:
-
-    * ``major``:  The result of :func:`distro.major_version`.
-
-    * ``minor``:  The result of :func:`distro.minor_version`.
-
-    * ``build_number``:  The result of :func:`distro.build_number`.
-
-    For a description of the *best* parameter, see the :func:`distro.version`
-    method.
-    """
-    return _distro.version_parts(best)
-
-
-def major_version(best=False):
-    """
-    Return the major version of the current OS distribution, as a string,
-    if provided.
-    Otherwise, the empty string is returned. The major version is the first
-    part of the dot-separated version string.
-
-    For a description of the *best* parameter, see the :func:`distro.version`
-    method.
-    """
-    return _distro.major_version(best)
-
-
-def minor_version(best=False):
-    """
-    Return the minor version of the current OS distribution, as a string,
-    if provided.
-    Otherwise, the empty string is returned. The minor version is the second
-    part of the dot-separated version string.
-
-    For a description of the *best* parameter, see the :func:`distro.version`
-    method.
-    """
-    return _distro.minor_version(best)
-
-
-def build_number(best=False):
-    """
-    Return the build number of the current OS distribution, as a string,
-    if provided.
-    Otherwise, the empty string is returned. The build number is the third part
-    of the dot-separated version string.
-
-    For a description of the *best* parameter, see the :func:`distro.version`
-    method.
-    """
-    return _distro.build_number(best)
-
-
-def like():
-    """
-    Return a space-separated list of distro IDs of distributions that are
-    closely related to the current OS distribution in regards to packaging
-    and programming interfaces, for example distributions the current
-    distribution is a derivative from.
-
-    **Lookup hierarchy:**
-
-    This information item is only provided by the os-release file.
-    For details, see the description of the "ID_LIKE" attribute in the
-    `os-release man page
-    <http://www.freedesktop.org/software/systemd/man/os-release.html>`_.
-    """
-    return _distro.like()
-
-
-def codename():
-    """
-    Return the codename for the release of the current OS distribution,
-    as a string.
-
-    If the distribution does not have a codename, an empty string is returned.
-
-    Note that the returned codename is not always really a codename. For
-    example, openSUSE returns "x86_64". This function does not handle such
-    cases in any special way and just returns the string it finds, if any.
-
-    **Lookup hierarchy:**
-
-    * the codename within the "VERSION" attribute of the os-release file, if
-      provided,
-
-    * the value of the "Codename" attribute returned by the lsb_release
-      command,
-
-    * the value of the "<codename>" field of the distro release file.
-    """
-    return _distro.codename()
-
-
-def info(pretty=False, best=False):
-    """
-    Return certain machine-readable information items about the current OS
-    distribution in a dictionary, as shown in the following example:
-
-    .. sourcecode:: python
-
-        {
-            'id': 'rhel',
-            'version': '7.0',
-            'version_parts': {
-                'major': '7',
-                'minor': '0',
-                'build_number': ''
-            },
-            'like': 'fedora',
-            'codename': 'Maipo'
-        }
-
-    The dictionary structure and keys are always the same, regardless of which
-    information items are available in the underlying data sources. The values
-    for the various keys are as follows:
-
-    * ``id``:  The result of :func:`distro.id`.
-
-    * ``version``:  The result of :func:`distro.version`.
-
-    * ``version_parts -> major``:  The result of :func:`distro.major_version`.
-
-    * ``version_parts -> minor``:  The result of :func:`distro.minor_version`.
-
-    * ``version_parts -> build_number``:  The result of
-      :func:`distro.build_number`.
-
-    * ``like``:  The result of :func:`distro.like`.
-
-    * ``codename``:  The result of :func:`distro.codename`.
-
-    For a description of the *pretty* and *best* parameters, see the
-    :func:`distro.version` method.
-    """
-    return _distro.info(pretty, best)
-
-
-def os_release_info():
-    """
-    Return a dictionary containing key-value pairs for the information items
-    from the os-release file data source of the current OS distribution.
-
-    See `os-release file`_ for details about these information items.
-    """
-    return _distro.os_release_info()
-
-
-def lsb_release_info():
-    """
-    Return a dictionary containing key-value pairs for the information items
-    from the lsb_release command data source of the current OS distribution.
-
-    See `lsb_release command output`_ for details about these information
-    items.
-    """
-    return _distro.lsb_release_info()
-
-
-def distro_release_info():
-    """
-    Return a dictionary containing key-value pairs for the information items
-    from the distro release file data source of the current OS distribution.
-
-    See `distro release file`_ for details about these information items.
-    """
-    return _distro.distro_release_info()
-
-
-def uname_info():
-    """
-    Return a dictionary containing key-value pairs for the information items
-    from the distro release file data source of the current OS distribution.
-    """
-    return _distro.uname_info()
-
-
-def os_release_attr(attribute):
-    """
-    Return a single named information item from the os-release file data source
-    of the current OS distribution.
-
-    Parameters:
-
-    * ``attribute`` (string): Key of the information item.
-
-    Returns:
-
-    * (string): Value of the information item, if the item exists.
-      The empty string, if the item does not exist.
-
-    See `os-release file`_ for details about these information items.
-    """
-    return _distro.os_release_attr(attribute)
-
-
-def lsb_release_attr(attribute):
-    """
-    Return a single named information item from the lsb_release command output
-    data source of the current OS distribution.
-
-    Parameters:
-
-    * ``attribute`` (string): Key of the information item.
-
-    Returns:
-
-    * (string): Value of the information item, if the item exists.
-      The empty string, if the item does not exist.
-
-    See `lsb_release command output`_ for details about these information
-    items.
-    """
-    return _distro.lsb_release_attr(attribute)
-
-
-def distro_release_attr(attribute):
-    """
-    Return a single named information item from the distro release file
-    data source of the current OS distribution.
-
-    Parameters:
-
-    * ``attribute`` (string): Key of the information item.
-
-    Returns:
-
-    * (string): Value of the information item, if the item exists.
-      The empty string, if the item does not exist.
-
-    See `distro release file`_ for details about these information items.
-    """
-    return _distro.distro_release_attr(attribute)
-
-
-def uname_attr(attribute):
-    """
-    Return a single named information item from the distro release file
-    data source of the current OS distribution.
-
-    Parameters:
-
-    * ``attribute`` (string): Key of the information item.
-
-    Returns:
-
-    * (string): Value of the information item, if the item exists.
-                The empty string, if the item does not exist.
-    """
-    return _distro.uname_attr(attribute)
-
-
-class cached_property(object):
-    """A version of @property which caches the value.  On access, it calls the
-    underlying function and sets the value in `__dict__` so future accesses
-    will not re-call the property.
-    """
-    def __init__(self, f):
-        self._fname = f.__name__
-        self._f = f
-
-    def __get__(self, obj, owner):
-        assert obj is not None, 'call {} on an instance'.format(self._fname)
-        ret = obj.__dict__[self._fname] = self._f(obj)
-        return ret
-
-
-class LinuxDistribution(object):
-    """
-    Provides information about a OS distribution.
-
-    This package creates a private module-global instance of this class with
-    default initialization arguments, that is used by the
-    `consolidated accessor functions`_ and `single source accessor functions`_.
-    By using default initialization arguments, that module-global instance
-    returns data about the current OS distribution (i.e. the distro this
-    package runs on).
-
-    Normally, it is not necessary to create additional instances of this class.
-    However, in situations where control is needed over the exact data sources
-    that are used, instances of this class can be created with a specific
-    distro release file, or a specific os-release file, or without invoking the
-    lsb_release command.
-    """
-
-    def __init__(self,
-                 include_lsb=True,
-                 os_release_file='',
-                 distro_release_file='',
-                 include_uname=True):
-        """
-        The initialization method of this class gathers information from the
-        available data sources, and stores that in private instance attributes.
-        Subsequent access to the information items uses these private instance
-        attributes, so that the data sources are read only once.
-
-        Parameters:
-
-        * ``include_lsb`` (bool): Controls whether the
-          `lsb_release command output`_ is included as a data source.
-
-          If the lsb_release command is not available in the program execution
-          path, the data source for the lsb_release command will be empty.
-
-        * ``os_release_file`` (string): The path name of the
-          `os-release file`_ that is to be used as a data source.
-
-          An empty string (the default) will cause the default path name to
-          be used (see `os-release file`_ for details).
-
-          If the specified or defaulted os-release file does not exist, the
-          data source for the os-release file will be empty.
-
-        * ``distro_release_file`` (string): The path name of the
-          `distro release file`_ that is to be used as a data source.
-
-          An empty string (the default) will cause a default search algorithm
-          to be used (see `distro release file`_ for details).
-
-          If the specified distro release file does not exist, or if no default
-          distro release file can be found, the data source for the distro
-          release file will be empty.
-
-        * ``include_uname`` (bool): Controls whether uname command output is
-          included as a data source. If the uname command is not available in
-          the program execution path the data source for the uname command will
-          be empty.
-
-        Public instance attributes:
-
-        * ``os_release_file`` (string): The path name of the
-          `os-release file`_ that is actually used as a data source. The
-          empty string if no distro release file is used as a data source.
-
-        * ``distro_release_file`` (string): The path name of the
-          `distro release file`_ that is actually used as a data source. The
-          empty string if no distro release file is used as a data source.
-
-        * ``include_lsb`` (bool): The result of the ``include_lsb`` parameter.
-          This controls whether the lsb information will be loaded.
-
-        * ``include_uname`` (bool): The result of the ``include_uname``
-          parameter. This controls whether the uname information will
-          be loaded.
-
-        Raises:
-
-        * :py:exc:`IOError`: Some I/O issue with an os-release file or distro
-          release file.
-
-        * :py:exc:`subprocess.CalledProcessError`: The lsb_release command had
-          some issue (other than not being available in the program execution
-          path).
-
-        * :py:exc:`UnicodeError`: A data source has unexpected characters or
-          uses an unexpected encoding.
-        """
-        self.os_release_file = os_release_file or \
-            os.path.join(_UNIXCONFDIR, _OS_RELEASE_BASENAME)
-        self.distro_release_file = distro_release_file or ''  # updated later
-        self.include_lsb = include_lsb
-        self.include_uname = include_uname
-
-    def __repr__(self):
-        """Return repr of all info
-        """
-        return \
-            "LinuxDistribution(" \
-            "os_release_file={self.os_release_file!r}, " \
-            "distro_release_file={self.distro_release_file!r}, " \
-            "include_lsb={self.include_lsb!r}, " \
-            "include_uname={self.include_uname!r}, " \
-            "_os_release_info={self._os_release_info!r}, " \
-            "_lsb_release_info={self._lsb_release_info!r}, " \
-            "_distro_release_info={self._distro_release_info!r}, " \
-            "_uname_info={self._uname_info!r})".format(
-                self=self)
-
-    def linux_distribution(self, full_distribution_name=True):
-        """
-        Return information about the OS distribution that is compatible
-        with Python's :func:`platform.linux_distribution`, supporting a subset
-        of its parameters.
-
-        For details, see :func:`distro.linux_distribution`.
-        """
-        return (
-            self.name() if full_distribution_name else self.id(),
-            self.version(),
-            self.codename()
-        )
-
-    def id(self):
-        """Return the distro ID of the OS distribution, as a string.
-
-        For details, see :func:`distro.id`.
-        """
-        def normalize(distro_id, table):
-            distro_id = distro_id.lower().replace(' ', '_')
-            return table.get(distro_id, distro_id)
-
-        distro_id = self.os_release_attr('id')
-        if distro_id:
-            return normalize(distro_id, NORMALIZED_OS_ID)
-
-        distro_id = self.lsb_release_attr('distributor_id')
-        if distro_id:
-            return normalize(distro_id, NORMALIZED_LSB_ID)
-
-        distro_id = self.distro_release_attr('id')
-        if distro_id:
-            return normalize(distro_id, NORMALIZED_DISTRO_ID)
-
-        distro_id = self.uname_attr('id')
-        if distro_id:
-            return normalize(distro_id, NORMALIZED_DISTRO_ID)
-
-        return ''
-
-    def name(self, pretty=False):
-        """
-        Return the name of the OS distribution, as a string.
-
-        For details, see :func:`distro.name`.
-        """
-        name = self.os_release_attr('name') \
-            or self.lsb_release_attr('distributor_id') \
-            or self.distro_release_attr('name') \
-            or self.uname_attr('name')
-        if pretty:
-            name = self.os_release_attr('pretty_name') \
-                or self.lsb_release_attr('description')
-            if not name:
-                name = self.distro_release_attr('name') \
-                       or self.uname_attr('name')
-                version = self.version(pretty=True)
-                if version:
-                    name = name + ' ' + version
-        return name or ''
-
-    def version(self, pretty=False, best=False):
-        """
-        Return the version of the OS distribution, as a string.
-
-        For details, see :func:`distro.version`.
-        """
-        versions = [
-            self.os_release_attr('version_id'),
-            self.lsb_release_attr('release'),
-            self.distro_release_attr('version_id'),
-            self._parse_distro_release_content(
-                self.os_release_attr('pretty_name')).get('version_id', ''),
-            self._parse_distro_release_content(
-                self.lsb_release_attr('description')).get('version_id', ''),
-            self.uname_attr('release')
-        ]
-        version = ''
-        if best:
-            # This algorithm uses the last version in priority order that has
-            # the best precision. If the versions are not in conflict, that
-            # does not matter; otherwise, using the last one instead of the
-            # first one might be considered a surprise.
-            for v in versions:
-                if v.count(".") > version.count(".") or version == '':
-                    version = v
-        else:
-            for v in versions:
-                if v != '':
-                    version = v
-                    break
-        if pretty and version and self.codename():
-            version = '{0} ({1})'.format(version, self.codename())
-        return version
-
-    def version_parts(self, best=False):
-        """
-        Return the version of the OS distribution, as a tuple of version
-        numbers.
-
-        For details, see :func:`distro.version_parts`.
-        """
-        version_str = self.version(best=best)
-        if version_str:
-            version_regex = re.compile(r'(\d+)\.?(\d+)?\.?(\d+)?')
-            matches = version_regex.match(version_str)
-            if matches:
-                major, minor, build_number = matches.groups()
-                return major, minor or '', build_number or ''
-        return '', '', ''
-
-    def major_version(self, best=False):
-        """
-        Return the major version number of the current distribution.
-
-        For details, see :func:`distro.major_version`.
-        """
-        return self.version_parts(best)[0]
-
-    def minor_version(self, best=False):
-        """
-        Return the minor version number of the current distribution.
-
-        For details, see :func:`distro.minor_version`.
-        """
-        return self.version_parts(best)[1]
-
-    def build_number(self, best=False):
-        """
-        Return the build number of the current distribution.
-
-        For details, see :func:`distro.build_number`.
-        """
-        return self.version_parts(best)[2]
-
-    def like(self):
-        """
-        Return the IDs of distributions that are like the OS distribution.
-
-        For details, see :func:`distro.like`.
-        """
-        return self.os_release_attr('id_like') or ''
-
-    def codename(self):
-        """
-        Return the codename of the OS distribution.
-
-        For details, see :func:`distro.codename`.
-        """
-        try:
-            # Handle os_release specially since distros might purposefully set
-            # this to empty string to have no codename
-            return self._os_release_info['codename']
-        except KeyError:
-            return self.lsb_release_attr('codename') \
-                or self.distro_release_attr('codename') \
-                or ''
-
-    def info(self, pretty=False, best=False):
-        """
-        Return certain machine-readable information about the OS
-        distribution.
-
-        For details, see :func:`distro.info`.
-        """
-        return dict(
-            id=self.id(),
-            version=self.version(pretty, best),
-            version_parts=dict(
-                major=self.major_version(best),
-                minor=self.minor_version(best),
-                build_number=self.build_number(best)
-            ),
-            like=self.like(),
-            codename=self.codename(),
-        )
-
-    def os_release_info(self):
-        """
-        Return a dictionary containing key-value pairs for the information
-        items from the os-release file data source of the OS distribution.
-
-        For details, see :func:`distro.os_release_info`.
-        """
-        return self._os_release_info
-
-    def lsb_release_info(self):
-        """
-        Return a dictionary containing key-value pairs for the information
-        items from the lsb_release command data source of the OS
-        distribution.
-
-        For details, see :func:`distro.lsb_release_info`.
-        """
-        return self._lsb_release_info
-
-    def distro_release_info(self):
-        """
-        Return a dictionary containing key-value pairs for the information
-        items from the distro release file data source of the OS
-        distribution.
-
-        For details, see :func:`distro.distro_release_info`.
-        """
-        return self._distro_release_info
-
-    def uname_info(self):
-        """
-        Return a dictionary containing key-value pairs for the information
-        items from the uname command data source of the OS distribution.
-
-        For details, see :func:`distro.uname_info`.
-        """
-        return self._uname_info
-
-    def os_release_attr(self, attribute):
-        """
-        Return a single named information item from the os-release file data
-        source of the OS distribution.
-
-        For details, see :func:`distro.os_release_attr`.
-        """
-        return self._os_release_info.get(attribute, '')
-
-    def lsb_release_attr(self, attribute):
-        """
-        Return a single named information item from the lsb_release command
-        output data source of the OS distribution.
-
-        For details, see :func:`distro.lsb_release_attr`.
-        """
-        return self._lsb_release_info.get(attribute, '')
-
-    def distro_release_attr(self, attribute):
-        """
-        Return a single named information item from the distro release file
-        data source of the OS distribution.
-
-        For details, see :func:`distro.distro_release_attr`.
-        """
-        return self._distro_release_info.get(attribute, '')
-
-    def uname_attr(self, attribute):
-        """
-        Return a single named information item from the uname command
-        output data source of the OS distribution.
-
-        For details, see :func:`distro.uname_release_attr`.
-        """
-        return self._uname_info.get(attribute, '')
-
-    @cached_property
-    def _os_release_info(self):
-        """
-        Get the information items from the specified os-release file.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        if os.path.isfile(self.os_release_file):
-            with open(self.os_release_file) as release_file:
-                return self._parse_os_release_content(release_file)
-        return {}
-
-    @staticmethod
-    def _parse_os_release_content(lines):
-        """
-        Parse the lines of an os-release file.
-
-        Parameters:
-
-        * lines: Iterable through the lines in the os-release file.
-                 Each line must be a unicode string or a UTF-8 encoded byte
-                 string.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        props = {}
-        lexer = shlex.shlex(lines, posix=True)
-        lexer.whitespace_split = True
-
-        # The shlex module defines its `wordchars` variable using literals,
-        # making it dependent on the encoding of the Python source file.
-        # In Python 2.6 and 2.7, the shlex source file is encoded in
-        # 'iso-8859-1', and the `wordchars` variable is defined as a byte
-        # string. This causes a UnicodeDecodeError to be raised when the
-        # parsed content is a unicode object. The following fix resolves that
-        # (... but it should be fixed in shlex...):
-        if sys.version_info[0] == 2 and isinstance(lexer.wordchars, bytes):
-            lexer.wordchars = lexer.wordchars.decode('iso-8859-1')
-
-        tokens = list(lexer)
-        for token in tokens:
-            # At this point, all shell-like parsing has been done (i.e.
-            # comments processed, quotes and backslash escape sequences
-            # processed, multi-line values assembled, trailing newlines
-            # stripped, etc.), so the tokens are now either:
-            # * variable assignments: var=value
-            # * commands or their arguments (not allowed in os-release)
-            if '=' in token:
-                k, v = token.split('=', 1)
-                props[k.lower()] = v
-            else:
-                # Ignore any tokens that are not variable assignments
-                pass
-
-        if 'version_codename' in props:
-            # os-release added a version_codename field.  Use that in
-            # preference to anything else Note that some distros purposefully
-            # do not have code names.  They should be setting
-            # version_codename=""
-            props['codename'] = props['version_codename']
-        elif 'ubuntu_codename' in props:
-            # Same as above but a non-standard field name used on older Ubuntus
-            props['codename'] = props['ubuntu_codename']
-        elif 'version' in props:
-            # If there is no version_codename, parse it from the version
-            codename = re.search(r'(\(\D+\))|,(\s+)?\D+', props['version'])
-            if codename:
-                codename = codename.group()
-                codename = codename.strip('()')
-                codename = codename.strip(',')
-                codename = codename.strip()
-                # codename appears within paranthese.
-                props['codename'] = codename
-
-        return props
-
-    @cached_property
-    def _lsb_release_info(self):
-        """
-        Get the information items from the lsb_release command output.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        if not self.include_lsb:
-            return {}
-        with open(os.devnull, 'w') as devnull:
-            try:
-                cmd = ('lsb_release', '-a')
-                stdout = subprocess.check_output(cmd, stderr=devnull)
-            except OSError:  # Command not found
-                return {}
-        content = self._to_str(stdout).splitlines()
-        return self._parse_lsb_release_content(content)
-
-    @staticmethod
-    def _parse_lsb_release_content(lines):
-        """
-        Parse the output of the lsb_release command.
-
-        Parameters:
-
-        * lines: Iterable through the lines of the lsb_release output.
-                 Each line must be a unicode string or a UTF-8 encoded byte
-                 string.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        props = {}
-        for line in lines:
-            kv = line.strip('\n').split(':', 1)
-            if len(kv) != 2:
-                # Ignore lines without colon.
-                continue
-            k, v = kv
-            props.update({k.replace(' ', '_').lower(): v.strip()})
-        return props
-
-    @cached_property
-    def _uname_info(self):
-        with open(os.devnull, 'w') as devnull:
-            try:
-                cmd = ('uname', '-rs')
-                stdout = subprocess.check_output(cmd, stderr=devnull)
-            except OSError:
-                return {}
-        content = self._to_str(stdout).splitlines()
-        return self._parse_uname_content(content)
-
-    @staticmethod
-    def _parse_uname_content(lines):
-        props = {}
-        match = re.search(r'^([^\s]+)\s+([\d\.]+)', lines[0].strip())
-        if match:
-            name, version = match.groups()
-
-            # This is to prevent the Linux kernel version from
-            # appearing as the 'best' version on otherwise
-            # identifiable distributions.
-            if name == 'Linux':
-                return {}
-            props['id'] = name.lower()
-            props['name'] = name
-            props['release'] = version
-        return props
-
-    @staticmethod
-    def _to_str(text):
-        encoding = sys.getfilesystemencoding()
-        encoding = 'utf-8' if encoding == 'ascii' else encoding
-
-        if sys.version_info[0] >= 3:
-            if isinstance(text, bytes):
-                return text.decode(encoding)
-        else:
-            if isinstance(text, unicode):  # noqa
-                return text.encode(encoding)
-
-        return text
-
-    @cached_property
-    def _distro_release_info(self):
-        """
-        Get the information items from the specified distro release file.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        if self.distro_release_file:
-            # If it was specified, we use it and parse what we can, even if
-            # its file name or content does not match the expected pattern.
-            distro_info = self._parse_distro_release_file(
-                self.distro_release_file)
-            basename = os.path.basename(self.distro_release_file)
-            # The file name pattern for user-specified distro release files
-            # is somewhat more tolerant (compared to when searching for the
-            # file), because we want to use what was specified as best as
-            # possible.
-            match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename)
-            if 'name' in distro_info \
-               and 'cloudlinux' in distro_info['name'].lower():
-                distro_info['id'] = 'cloudlinux'
-            elif match:
-                distro_info['id'] = match.group(1)
-            return distro_info
-        else:
-            try:
-                basenames = os.listdir(_UNIXCONFDIR)
-                # We sort for repeatability in cases where there are multiple
-                # distro specific files; e.g. CentOS, Oracle, Enterprise all
-                # containing `redhat-release` on top of their own.
-                basenames.sort()
-            except OSError:
-                # This may occur when /etc is not readable but we can't be
-                # sure about the *-release files. Check common entries of
-                # /etc for information. If they turn out to not be there the
-                # error is handled in `_parse_distro_release_file()`.
-                basenames = ['SuSE-release',
-                             'arch-release',
-                             'base-release',
-                             'centos-release',
-                             'fedora-release',
-                             'gentoo-release',
-                             'mageia-release',
-                             'mandrake-release',
-                             'mandriva-release',
-                             'mandrivalinux-release',
-                             'manjaro-release',
-                             'oracle-release',
-                             'redhat-release',
-                             'sl-release',
-                             'slackware-version']
-            for basename in basenames:
-                if basename in _DISTRO_RELEASE_IGNORE_BASENAMES:
-                    continue
-                match = _DISTRO_RELEASE_BASENAME_PATTERN.match(basename)
-                if match:
-                    filepath = os.path.join(_UNIXCONFDIR, basename)
-                    distro_info = self._parse_distro_release_file(filepath)
-                    if 'name' in distro_info:
-                        # The name is always present if the pattern matches
-                        self.distro_release_file = filepath
-                        distro_info['id'] = match.group(1)
-                        if 'cloudlinux' in distro_info['name'].lower():
-                            distro_info['id'] = 'cloudlinux'
-                        return distro_info
-            return {}
-
-    def _parse_distro_release_file(self, filepath):
-        """
-        Parse a distro release file.
-
-        Parameters:
-
-        * filepath: Path name of the distro release file.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        try:
-            with open(filepath) as fp:
-                # Only parse the first line. For instance, on SLES there
-                # are multiple lines. We don't want them...
-                return self._parse_distro_release_content(fp.readline())
-        except (OSError, IOError):
-            # Ignore not being able to read a specific, seemingly version
-            # related file.
-            # See https://github.com/nir0s/distro/issues/162
-            return {}
-
-    @staticmethod
-    def _parse_distro_release_content(line):
-        """
-        Parse a line from a distro release file.
-
-        Parameters:
-        * line: Line from the distro release file. Must be a unicode string
-                or a UTF-8 encoded byte string.
-
-        Returns:
-            A dictionary containing all information items.
-        """
-        matches = _DISTRO_RELEASE_CONTENT_REVERSED_PATTERN.match(
-            line.strip()[::-1])
-        distro_info = {}
-        if matches:
-            # regexp ensures non-None
-            distro_info['name'] = matches.group(3)[::-1]
-            if matches.group(2):
-                distro_info['version_id'] = matches.group(2)[::-1]
-            if matches.group(1):
-                distro_info['codename'] = matches.group(1)[::-1]
-        elif line:
-            distro_info['name'] = line.strip()
-        return distro_info
-
-
-_distro = LinuxDistribution()
-
-
-def main():
-    logger = logging.getLogger(__name__)
-    logger.setLevel(logging.DEBUG)
-    logger.addHandler(logging.StreamHandler(sys.stdout))
-
-    parser = argparse.ArgumentParser(description="OS distro info tool")
-    parser.add_argument(
-        '--json',
-        '-j',
-        help="Output in machine readable format",
-        action="store_true")
-    args = parser.parse_args()
-
-    if args.json:
-        logger.info(json.dumps(info(), indent=4, sort_keys=True))
-    else:
-        logger.info('Name: %s', name(pretty=True))
-        distribution_version = version(pretty=True)
-        logger.info('Version: %s', distribution_version)
-        distribution_codename = codename()
-        logger.info('Codename: %s', distribution_codename)
-
-
-if __name__ == '__main__':
-    main()
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/__init__.py
deleted file mode 100644
index d1d82f15..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/__init__.py
+++ /dev/null
@@ -1,35 +0,0 @@
-"""
-HTML parsing library based on the `WHATWG HTML specification
-<https://whatwg.org/html>`_. The parser is designed to be compatible with
-existing HTML found in the wild and implements well-defined error recovery that
-is largely compatible with modern desktop web browsers.
-
-Example usage::
-
-    from pip._vendor import html5lib
-    with open("my_document.html", "rb") as f:
-        tree = html5lib.parse(f)
-
-For convenience, this module re-exports the following names:
-
-* :func:`~.html5parser.parse`
-* :func:`~.html5parser.parseFragment`
-* :class:`~.html5parser.HTMLParser`
-* :func:`~.treebuilders.getTreeBuilder`
-* :func:`~.treewalkers.getTreeWalker`
-* :func:`~.serializer.serialize`
-"""
-
-from __future__ import absolute_import, division, unicode_literals
-
-from .html5parser import HTMLParser, parse, parseFragment
-from .treebuilders import getTreeBuilder
-from .treewalkers import getTreeWalker
-from .serializer import serialize
-
-__all__ = ["HTMLParser", "parse", "parseFragment", "getTreeBuilder",
-           "getTreeWalker", "serialize"]
-
-# this has to be at the top level, see how setup.py parses this
-#: Distribution version number.
-__version__ = "1.1"
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 2530cbe0ccc8bd73244b78c78f2dcf36e74eeb85..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1330
zcmYe~<>g{vU|^UdaWJ)mg@NHQh=Yuo7#J8F7#J9e6Brm6QW&BbQW#U1au{=&qL^}-
zqnLA9qF5LiQkYX%a#(ZOqS$iTqu6sfqBy`}tT~*yTv1$LHd_vNE>9E>n9ZKUo68r)
z$H<V*kixNuF^WHhGfE(ZE0{r(J8=yY0|S>wh_8=AL1IyHW?s5NPG(Y3Vo{|+Qetsx
zib8&#LP<udLPEHQV@SBW0$62nL27blT4r)$NoIZ?mrX`VNkOrdzJ7T|Vo7<rUVc%!
zenv@dj$J~$o<c}QD%jxEB8ALig_P9d%=Em}6ory}g``x4<ow)%#FEUUoK%JK%#sYQ
z)QZgF5|9(Xwxs2k=A|fPLhLWk%t=v51o3kVa#C|s^Gb>p%2RW4bW>8(GC?M$78T_e
zDHNq9=a;1xRVtKZB$jYx7Axc=7Nw`=RH9p@kei>9T9gNJP<BavfkJs|l0s5ZetB_f
zQL!Eumup2L$Qp&x;>7e+D=RK81qB6#w4(f6g@Viiz4)@!yp;SRh0NT7{Gt*CkY7!6
zGLyiHK>kq3FG$VPP|B^0PsvX%1-VrZq((_cL8&N7NmC)QSRu^{tQur&Nl|L5f-T$>
zJy0~HYNTm$ak=FeDJ19Tm8IrorsgH5>L`?CWEO*5UYe7tP?V~hS^=`Z7#u%o`8hfH
z<)E<3OUz9zw&LQ_Qm{%Z%}cgQr~}(>3O2V0VtfK#S+}CZbdamTs*-aOi;K|>0mV;1
zVo`Bw5m*h(9*|d(N;7j(K%tnPS`t!}n(74MW2h@n%*jSl77pg3s47k^%1q43tV%7?
zgEJGjUV<`<Ci5-+#H8Z<oYIoict|wd;z-FX%Ph{!&$}g1nwOcJpOPA%lUb5ll$cZe
zl97RdL6i9wIGsb>eTx+w9=CYG6wJq(jJNnu-L1)Zix(;aaiS*UEl#*|G}(&S7#J9e
z*g*sbh~NYfpd4Pr&A`A=#cZf&=%*=oi#;Bc7UJV?amB}{m6ntirN+k>fwFoLGe`pq
z0|Ub?ZcrkDMiZK`w|J0)wg_a&EpCtyG!%<KHs0cbyQ>InJIL0=oSgXhTio&SWvNA=
zz=@Av$xtK$vJ*u7YIL@W2?ZtknADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<
z7k@w3U{A-GU{_z);1Jg!1+$od0H2sd6WyHrbWpC%j!Dfci}A@!iYd-4N!2Y#OwLYB
zPc4oq$Slx@W*Bg(0Lm%)@$s2?nI-Y@dIgoYIBatBQ%ZAE?Ld)K%*VjMz#=BXB*Mr8
If=nE&0DiWj;{X5v

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_ihatexml.cpython-39.pyc
deleted file mode 100644
index 8b19e80b849505c197723be209619848dc28f768..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_inputstream.cpython-39.pyc
deleted file mode 100644
index 8fc47691b155fb6d6c129941004b4f0e9aec2a9f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 21658
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
QfqDi{fh2)?23rAj06)h(F#rGn

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_tokenizer.cpython-39.pyc
deleted file mode 100644
index c5eed21d6961fc3bf8743904ab24f7a38a99ddf6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 39753
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
H#KH^!(SPf$

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/_utils.cpython-39.pyc
deleted file mode 100644
index e3679b47f3241fbcae1d374b2e221839729b2740..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4830
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
Ghb#a|ms7I<

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/constants.cpython-39.pyc
deleted file mode 100644
index 5970137cbf6ec86e81124cc85908aa737c6ae27b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/html5parser.cpython-39.pyc
deleted file mode 100644
index 1c6cea33c4a0e43345bd7b91338b40b77075b430..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 91039
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
AVE_OC

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/__pycache__/serializer.cpython-39.pyc
deleted file mode 100644
index a4d75e6ec85c5feaf571585a21b770cd58cb4677..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 10841
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
HGZ+E@v+?(q

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py b/env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py
deleted file mode 100644
index 3ff803c1..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_ihatexml.py
+++ /dev/null
@@ -1,289 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-import re
-import warnings
-
-from .constants import DataLossWarning
-
-baseChar = """
-[#x0041-#x005A] | [#x0061-#x007A] | [#x00C0-#x00D6] | [#x00D8-#x00F6] |
-[#x00F8-#x00FF] | [#x0100-#x0131] | [#x0134-#x013E] | [#x0141-#x0148] |
-[#x014A-#x017E] | [#x0180-#x01C3] | [#x01CD-#x01F0] | [#x01F4-#x01F5] |
-[#x01FA-#x0217] | [#x0250-#x02A8] | [#x02BB-#x02C1] | #x0386 |
-[#x0388-#x038A] | #x038C | [#x038E-#x03A1] | [#x03A3-#x03CE] |
-[#x03D0-#x03D6] | #x03DA | #x03DC | #x03DE | #x03E0 | [#x03E2-#x03F3] |
-[#x0401-#x040C] | [#x040E-#x044F] | [#x0451-#x045C] | [#x045E-#x0481] |
-[#x0490-#x04C4] | [#x04C7-#x04C8] | [#x04CB-#x04CC] | [#x04D0-#x04EB] |
-[#x04EE-#x04F5] | [#x04F8-#x04F9] | [#x0531-#x0556] | #x0559 |
-[#x0561-#x0586] | [#x05D0-#x05EA] | [#x05F0-#x05F2] | [#x0621-#x063A] |
-[#x0641-#x064A] | [#x0671-#x06B7] | [#x06BA-#x06BE] | [#x06C0-#x06CE] |
-[#x06D0-#x06D3] | #x06D5 | [#x06E5-#x06E6] | [#x0905-#x0939] | #x093D |
-[#x0958-#x0961] | [#x0985-#x098C] | [#x098F-#x0990] | [#x0993-#x09A8] |
-[#x09AA-#x09B0] | #x09B2 | [#x09B6-#x09B9] | [#x09DC-#x09DD] |
-[#x09DF-#x09E1] | [#x09F0-#x09F1] | [#x0A05-#x0A0A] | [#x0A0F-#x0A10] |
-[#x0A13-#x0A28] | [#x0A2A-#x0A30] | [#x0A32-#x0A33] | [#x0A35-#x0A36] |
-[#x0A38-#x0A39] | [#x0A59-#x0A5C] | #x0A5E | [#x0A72-#x0A74] |
-[#x0A85-#x0A8B] | #x0A8D | [#x0A8F-#x0A91] | [#x0A93-#x0AA8] |
-[#x0AAA-#x0AB0] | [#x0AB2-#x0AB3] | [#x0AB5-#x0AB9] | #x0ABD | #x0AE0 |
-[#x0B05-#x0B0C] | [#x0B0F-#x0B10] | [#x0B13-#x0B28] | [#x0B2A-#x0B30] |
-[#x0B32-#x0B33] | [#x0B36-#x0B39] | #x0B3D | [#x0B5C-#x0B5D] |
-[#x0B5F-#x0B61] | [#x0B85-#x0B8A] | [#x0B8E-#x0B90] | [#x0B92-#x0B95] |
-[#x0B99-#x0B9A] | #x0B9C | [#x0B9E-#x0B9F] | [#x0BA3-#x0BA4] |
-[#x0BA8-#x0BAA] | [#x0BAE-#x0BB5] | [#x0BB7-#x0BB9] | [#x0C05-#x0C0C] |
-[#x0C0E-#x0C10] | [#x0C12-#x0C28] | [#x0C2A-#x0C33] | [#x0C35-#x0C39] |
-[#x0C60-#x0C61] | [#x0C85-#x0C8C] | [#x0C8E-#x0C90] | [#x0C92-#x0CA8] |
-[#x0CAA-#x0CB3] | [#x0CB5-#x0CB9] | #x0CDE | [#x0CE0-#x0CE1] |
-[#x0D05-#x0D0C] | [#x0D0E-#x0D10] | [#x0D12-#x0D28] | [#x0D2A-#x0D39] |
-[#x0D60-#x0D61] | [#x0E01-#x0E2E] | #x0E30 | [#x0E32-#x0E33] |
-[#x0E40-#x0E45] | [#x0E81-#x0E82] | #x0E84 | [#x0E87-#x0E88] | #x0E8A |
-#x0E8D | [#x0E94-#x0E97] | [#x0E99-#x0E9F] | [#x0EA1-#x0EA3] | #x0EA5 |
-#x0EA7 | [#x0EAA-#x0EAB] | [#x0EAD-#x0EAE] | #x0EB0 | [#x0EB2-#x0EB3] |
-#x0EBD | [#x0EC0-#x0EC4] | [#x0F40-#x0F47] | [#x0F49-#x0F69] |
-[#x10A0-#x10C5] | [#x10D0-#x10F6] | #x1100 | [#x1102-#x1103] |
-[#x1105-#x1107] | #x1109 | [#x110B-#x110C] | [#x110E-#x1112] | #x113C |
-#x113E | #x1140 | #x114C | #x114E | #x1150 | [#x1154-#x1155] | #x1159 |
-[#x115F-#x1161] | #x1163 | #x1165 | #x1167 | #x1169 | [#x116D-#x116E] |
-[#x1172-#x1173] | #x1175 | #x119E | #x11A8 | #x11AB | [#x11AE-#x11AF] |
-[#x11B7-#x11B8] | #x11BA | [#x11BC-#x11C2] | #x11EB | #x11F0 | #x11F9 |
-[#x1E00-#x1E9B] | [#x1EA0-#x1EF9] | [#x1F00-#x1F15] | [#x1F18-#x1F1D] |
-[#x1F20-#x1F45] | [#x1F48-#x1F4D] | [#x1F50-#x1F57] | #x1F59 | #x1F5B |
-#x1F5D | [#x1F5F-#x1F7D] | [#x1F80-#x1FB4] | [#x1FB6-#x1FBC] | #x1FBE |
-[#x1FC2-#x1FC4] | [#x1FC6-#x1FCC] | [#x1FD0-#x1FD3] | [#x1FD6-#x1FDB] |
-[#x1FE0-#x1FEC] | [#x1FF2-#x1FF4] | [#x1FF6-#x1FFC] | #x2126 |
-[#x212A-#x212B] | #x212E | [#x2180-#x2182] | [#x3041-#x3094] |
-[#x30A1-#x30FA] | [#x3105-#x312C] | [#xAC00-#xD7A3]"""
-
-ideographic = """[#x4E00-#x9FA5] | #x3007 | [#x3021-#x3029]"""
-
-combiningCharacter = """
-[#x0300-#x0345] | [#x0360-#x0361] | [#x0483-#x0486] | [#x0591-#x05A1] |
-[#x05A3-#x05B9] | [#x05BB-#x05BD] | #x05BF | [#x05C1-#x05C2] | #x05C4 |
-[#x064B-#x0652] | #x0670 | [#x06D6-#x06DC] | [#x06DD-#x06DF] |
-[#x06E0-#x06E4] | [#x06E7-#x06E8] | [#x06EA-#x06ED] | [#x0901-#x0903] |
-#x093C | [#x093E-#x094C] | #x094D | [#x0951-#x0954] | [#x0962-#x0963] |
-[#x0981-#x0983] | #x09BC | #x09BE | #x09BF | [#x09C0-#x09C4] |
-[#x09C7-#x09C8] | [#x09CB-#x09CD] | #x09D7 | [#x09E2-#x09E3] | #x0A02 |
-#x0A3C | #x0A3E | #x0A3F | [#x0A40-#x0A42] | [#x0A47-#x0A48] |
-[#x0A4B-#x0A4D] | [#x0A70-#x0A71] | [#x0A81-#x0A83] | #x0ABC |
-[#x0ABE-#x0AC5] | [#x0AC7-#x0AC9] | [#x0ACB-#x0ACD] | [#x0B01-#x0B03] |
-#x0B3C | [#x0B3E-#x0B43] | [#x0B47-#x0B48] | [#x0B4B-#x0B4D] |
-[#x0B56-#x0B57] | [#x0B82-#x0B83] | [#x0BBE-#x0BC2] | [#x0BC6-#x0BC8] |
-[#x0BCA-#x0BCD] | #x0BD7 | [#x0C01-#x0C03] | [#x0C3E-#x0C44] |
-[#x0C46-#x0C48] | [#x0C4A-#x0C4D] | [#x0C55-#x0C56] | [#x0C82-#x0C83] |
-[#x0CBE-#x0CC4] | [#x0CC6-#x0CC8] | [#x0CCA-#x0CCD] | [#x0CD5-#x0CD6] |
-[#x0D02-#x0D03] | [#x0D3E-#x0D43] | [#x0D46-#x0D48] | [#x0D4A-#x0D4D] |
-#x0D57 | #x0E31 | [#x0E34-#x0E3A] | [#x0E47-#x0E4E] | #x0EB1 |
-[#x0EB4-#x0EB9] | [#x0EBB-#x0EBC] | [#x0EC8-#x0ECD] | [#x0F18-#x0F19] |
-#x0F35 | #x0F37 | #x0F39 | #x0F3E | #x0F3F | [#x0F71-#x0F84] |
-[#x0F86-#x0F8B] | [#x0F90-#x0F95] | #x0F97 | [#x0F99-#x0FAD] |
-[#x0FB1-#x0FB7] | #x0FB9 | [#x20D0-#x20DC] | #x20E1 | [#x302A-#x302F] |
-#x3099 | #x309A"""
-
-digit = """
-[#x0030-#x0039] | [#x0660-#x0669] | [#x06F0-#x06F9] | [#x0966-#x096F] |
-[#x09E6-#x09EF] | [#x0A66-#x0A6F] | [#x0AE6-#x0AEF] | [#x0B66-#x0B6F] |
-[#x0BE7-#x0BEF] | [#x0C66-#x0C6F] | [#x0CE6-#x0CEF] | [#x0D66-#x0D6F] |
-[#x0E50-#x0E59] | [#x0ED0-#x0ED9] | [#x0F20-#x0F29]"""
-
-extender = """
-#x00B7 | #x02D0 | #x02D1 | #x0387 | #x0640 | #x0E46 | #x0EC6 | #x3005 |
-#[#x3031-#x3035] | [#x309D-#x309E] | [#x30FC-#x30FE]"""
-
-letter = " | ".join([baseChar, ideographic])
-
-# Without the
-name = " | ".join([letter, digit, ".", "-", "_", combiningCharacter,
-                   extender])
-nameFirst = " | ".join([letter, "_"])
-
-reChar = re.compile(r"#x([\d|A-F]{4,4})")
-reCharRange = re.compile(r"\[#x([\d|A-F]{4,4})-#x([\d|A-F]{4,4})\]")
-
-
-def charStringToList(chars):
-    charRanges = [item.strip() for item in chars.split(" | ")]
-    rv = []
-    for item in charRanges:
-        foundMatch = False
-        for regexp in (reChar, reCharRange):
-            match = regexp.match(item)
-            if match is not None:
-                rv.append([hexToInt(item) for item in match.groups()])
-                if len(rv[-1]) == 1:
-                    rv[-1] = rv[-1] * 2
-                foundMatch = True
-                break
-        if not foundMatch:
-            assert len(item) == 1
-
-            rv.append([ord(item)] * 2)
-    rv = normaliseCharList(rv)
-    return rv
-
-
-def normaliseCharList(charList):
-    charList = sorted(charList)
-    for item in charList:
-        assert item[1] >= item[0]
-    rv = []
-    i = 0
-    while i < len(charList):
-        j = 1
-        rv.append(charList[i])
-        while i + j < len(charList) and charList[i + j][0] <= rv[-1][1] + 1:
-            rv[-1][1] = charList[i + j][1]
-            j += 1
-        i += j
-    return rv
-
-
-# We don't really support characters above the BMP :(
-max_unicode = int("FFFF", 16)
-
-
-def missingRanges(charList):
-    rv = []
-    if charList[0] != 0:
-        rv.append([0, charList[0][0] - 1])
-    for i, item in enumerate(charList[:-1]):
-        rv.append([item[1] + 1, charList[i + 1][0] - 1])
-    if charList[-1][1] != max_unicode:
-        rv.append([charList[-1][1] + 1, max_unicode])
-    return rv
-
-
-def listToRegexpStr(charList):
-    rv = []
-    for item in charList:
-        if item[0] == item[1]:
-            rv.append(escapeRegexp(chr(item[0])))
-        else:
-            rv.append(escapeRegexp(chr(item[0])) + "-" +
-                      escapeRegexp(chr(item[1])))
-    return "[%s]" % "".join(rv)
-
-
-def hexToInt(hex_str):
-    return int(hex_str, 16)
-
-
-def escapeRegexp(string):
-    specialCharacters = (".", "^", "$", "*", "+", "?", "{", "}",
-                         "[", "]", "|", "(", ")", "-")
-    for char in specialCharacters:
-        string = string.replace(char, "\\" + char)
-
-    return string
-
-# output from the above
-nonXmlNameBMPRegexp = re.compile('[\x00-,/:-@\\[-\\^`\\{-\xb6\xb8-\xbf\xd7\xf7\u0132-\u0133\u013f-\u0140\u0149\u017f\u01c4-\u01cc\u01f1-\u01f3\u01f6-\u01f9\u0218-\u024f\u02a9-\u02ba\u02c2-\u02cf\u02d2-\u02ff\u0346-\u035f\u0362-\u0385\u038b\u038d\u03a2\u03cf\u03d7-\u03d9\u03db\u03dd\u03df\u03e1\u03f4-\u0400\u040d\u0450\u045d\u0482\u0487-\u048f\u04c5-\u04c6\u04c9-\u04ca\u04cd-\u04cf\u04ec-\u04ed\u04f6-\u04f7\u04fa-\u0530\u0557-\u0558\u055a-\u0560\u0587-\u0590\u05a2\u05ba\u05be\u05c0\u05c3\u05c5-\u05cf\u05eb-\u05ef\u05f3-\u0620\u063b-\u063f\u0653-\u065f\u066a-\u066f\u06b8-\u06b9\u06bf\u06cf\u06d4\u06e9\u06ee-\u06ef\u06fa-\u0900\u0904\u093a-\u093b\u094e-\u0950\u0955-\u0957\u0964-\u0965\u0970-\u0980\u0984\u098d-\u098e\u0991-\u0992\u09a9\u09b1\u09b3-\u09b5\u09ba-\u09bb\u09bd\u09c5-\u09c6\u09c9-\u09ca\u09ce-\u09d6\u09d8-\u09db\u09de\u09e4-\u09e5\u09f2-\u0a01\u0a03-\u0a04\u0a0b-\u0a0e\u0a11-\u0a12\u0a29\u0a31\u0a34\u0a37\u0a3a-\u0a3b\u0a3d\u0a43-\u0a46\u0a49-\u0a4a\u0a4e-\u0a58\u0a5d\u0a5f-\u0a65\u0a75-\u0a80\u0a84\u0a8c\u0a8e\u0a92\u0aa9\u0ab1\u0ab4\u0aba-\u0abb\u0ac6\u0aca\u0ace-\u0adf\u0ae1-\u0ae5\u0af0-\u0b00\u0b04\u0b0d-\u0b0e\u0b11-\u0b12\u0b29\u0b31\u0b34-\u0b35\u0b3a-\u0b3b\u0b44-\u0b46\u0b49-\u0b4a\u0b4e-\u0b55\u0b58-\u0b5b\u0b5e\u0b62-\u0b65\u0b70-\u0b81\u0b84\u0b8b-\u0b8d\u0b91\u0b96-\u0b98\u0b9b\u0b9d\u0ba0-\u0ba2\u0ba5-\u0ba7\u0bab-\u0bad\u0bb6\u0bba-\u0bbd\u0bc3-\u0bc5\u0bc9\u0bce-\u0bd6\u0bd8-\u0be6\u0bf0-\u0c00\u0c04\u0c0d\u0c11\u0c29\u0c34\u0c3a-\u0c3d\u0c45\u0c49\u0c4e-\u0c54\u0c57-\u0c5f\u0c62-\u0c65\u0c70-\u0c81\u0c84\u0c8d\u0c91\u0ca9\u0cb4\u0cba-\u0cbd\u0cc5\u0cc9\u0cce-\u0cd4\u0cd7-\u0cdd\u0cdf\u0ce2-\u0ce5\u0cf0-\u0d01\u0d04\u0d0d\u0d11\u0d29\u0d3a-\u0d3d\u0d44-\u0d45\u0d49\u0d4e-\u0d56\u0d58-\u0d5f\u0d62-\u0d65\u0d70-\u0e00\u0e2f\u0e3b-\u0e3f\u0e4f\u0e5a-\u0e80\u0e83\u0e85-\u0e86\u0e89\u0e8b-\u0e8c\u0e8e-\u0e93\u0e98\u0ea0\u0ea4\u0ea6\u0ea8-\u0ea9\u0eac\u0eaf\u0eba\u0ebe-\u0ebf\u0ec5\u0ec7\u0ece-\u0ecf\u0eda-\u0f17\u0f1a-\u0f1f\u0f2a-\u0f34\u0f36\u0f38\u0f3a-\u0f3d\u0f48\u0f6a-\u0f70\u0f85\u0f8c-\u0f8f\u0f96\u0f98\u0fae-\u0fb0\u0fb8\u0fba-\u109f\u10c6-\u10cf\u10f7-\u10ff\u1101\u1104\u1108\u110a\u110d\u1113-\u113b\u113d\u113f\u1141-\u114b\u114d\u114f\u1151-\u1153\u1156-\u1158\u115a-\u115e\u1162\u1164\u1166\u1168\u116a-\u116c\u116f-\u1171\u1174\u1176-\u119d\u119f-\u11a7\u11a9-\u11aa\u11ac-\u11ad\u11b0-\u11b6\u11b9\u11bb\u11c3-\u11ea\u11ec-\u11ef\u11f1-\u11f8\u11fa-\u1dff\u1e9c-\u1e9f\u1efa-\u1eff\u1f16-\u1f17\u1f1e-\u1f1f\u1f46-\u1f47\u1f4e-\u1f4f\u1f58\u1f5a\u1f5c\u1f5e\u1f7e-\u1f7f\u1fb5\u1fbd\u1fbf-\u1fc1\u1fc5\u1fcd-\u1fcf\u1fd4-\u1fd5\u1fdc-\u1fdf\u1fed-\u1ff1\u1ff5\u1ffd-\u20cf\u20dd-\u20e0\u20e2-\u2125\u2127-\u2129\u212c-\u212d\u212f-\u217f\u2183-\u3004\u3006\u3008-\u3020\u3030\u3036-\u3040\u3095-\u3098\u309b-\u309c\u309f-\u30a0\u30fb\u30ff-\u3104\u312d-\u4dff\u9fa6-\uabff\ud7a4-\uffff]')  # noqa
-
-nonXmlNameFirstBMPRegexp = re.compile('[\x00-@\\[-\\^`\\{-\xbf\xd7\xf7\u0132-\u0133\u013f-\u0140\u0149\u017f\u01c4-\u01cc\u01f1-\u01f3\u01f6-\u01f9\u0218-\u024f\u02a9-\u02ba\u02c2-\u0385\u0387\u038b\u038d\u03a2\u03cf\u03d7-\u03d9\u03db\u03dd\u03df\u03e1\u03f4-\u0400\u040d\u0450\u045d\u0482-\u048f\u04c5-\u04c6\u04c9-\u04ca\u04cd-\u04cf\u04ec-\u04ed\u04f6-\u04f7\u04fa-\u0530\u0557-\u0558\u055a-\u0560\u0587-\u05cf\u05eb-\u05ef\u05f3-\u0620\u063b-\u0640\u064b-\u0670\u06b8-\u06b9\u06bf\u06cf\u06d4\u06d6-\u06e4\u06e7-\u0904\u093a-\u093c\u093e-\u0957\u0962-\u0984\u098d-\u098e\u0991-\u0992\u09a9\u09b1\u09b3-\u09b5\u09ba-\u09db\u09de\u09e2-\u09ef\u09f2-\u0a04\u0a0b-\u0a0e\u0a11-\u0a12\u0a29\u0a31\u0a34\u0a37\u0a3a-\u0a58\u0a5d\u0a5f-\u0a71\u0a75-\u0a84\u0a8c\u0a8e\u0a92\u0aa9\u0ab1\u0ab4\u0aba-\u0abc\u0abe-\u0adf\u0ae1-\u0b04\u0b0d-\u0b0e\u0b11-\u0b12\u0b29\u0b31\u0b34-\u0b35\u0b3a-\u0b3c\u0b3e-\u0b5b\u0b5e\u0b62-\u0b84\u0b8b-\u0b8d\u0b91\u0b96-\u0b98\u0b9b\u0b9d\u0ba0-\u0ba2\u0ba5-\u0ba7\u0bab-\u0bad\u0bb6\u0bba-\u0c04\u0c0d\u0c11\u0c29\u0c34\u0c3a-\u0c5f\u0c62-\u0c84\u0c8d\u0c91\u0ca9\u0cb4\u0cba-\u0cdd\u0cdf\u0ce2-\u0d04\u0d0d\u0d11\u0d29\u0d3a-\u0d5f\u0d62-\u0e00\u0e2f\u0e31\u0e34-\u0e3f\u0e46-\u0e80\u0e83\u0e85-\u0e86\u0e89\u0e8b-\u0e8c\u0e8e-\u0e93\u0e98\u0ea0\u0ea4\u0ea6\u0ea8-\u0ea9\u0eac\u0eaf\u0eb1\u0eb4-\u0ebc\u0ebe-\u0ebf\u0ec5-\u0f3f\u0f48\u0f6a-\u109f\u10c6-\u10cf\u10f7-\u10ff\u1101\u1104\u1108\u110a\u110d\u1113-\u113b\u113d\u113f\u1141-\u114b\u114d\u114f\u1151-\u1153\u1156-\u1158\u115a-\u115e\u1162\u1164\u1166\u1168\u116a-\u116c\u116f-\u1171\u1174\u1176-\u119d\u119f-\u11a7\u11a9-\u11aa\u11ac-\u11ad\u11b0-\u11b6\u11b9\u11bb\u11c3-\u11ea\u11ec-\u11ef\u11f1-\u11f8\u11fa-\u1dff\u1e9c-\u1e9f\u1efa-\u1eff\u1f16-\u1f17\u1f1e-\u1f1f\u1f46-\u1f47\u1f4e-\u1f4f\u1f58\u1f5a\u1f5c\u1f5e\u1f7e-\u1f7f\u1fb5\u1fbd\u1fbf-\u1fc1\u1fc5\u1fcd-\u1fcf\u1fd4-\u1fd5\u1fdc-\u1fdf\u1fed-\u1ff1\u1ff5\u1ffd-\u2125\u2127-\u2129\u212c-\u212d\u212f-\u217f\u2183-\u3006\u3008-\u3020\u302a-\u3040\u3095-\u30a0\u30fb-\u3104\u312d-\u4dff\u9fa6-\uabff\ud7a4-\uffff]')  # noqa
-
-# Simpler things
-nonPubidCharRegexp = re.compile("[^\x20\x0D\x0Aa-zA-Z0-9\\-'()+,./:=?;!*#@$_%]")
-
-
-class InfosetFilter(object):
-    replacementRegexp = re.compile(r"U[\dA-F]{5,5}")
-
-    def __init__(self,
-                 dropXmlnsLocalName=False,
-                 dropXmlnsAttrNs=False,
-                 preventDoubleDashComments=False,
-                 preventDashAtCommentEnd=False,
-                 replaceFormFeedCharacters=True,
-                 preventSingleQuotePubid=False):
-
-        self.dropXmlnsLocalName = dropXmlnsLocalName
-        self.dropXmlnsAttrNs = dropXmlnsAttrNs
-
-        self.preventDoubleDashComments = preventDoubleDashComments
-        self.preventDashAtCommentEnd = preventDashAtCommentEnd
-
-        self.replaceFormFeedCharacters = replaceFormFeedCharacters
-
-        self.preventSingleQuotePubid = preventSingleQuotePubid
-
-        self.replaceCache = {}
-
-    def coerceAttribute(self, name, namespace=None):
-        if self.dropXmlnsLocalName and name.startswith("xmlns:"):
-            warnings.warn("Attributes cannot begin with xmlns", DataLossWarning)
-            return None
-        elif (self.dropXmlnsAttrNs and
-              namespace == "http://www.w3.org/2000/xmlns/"):
-            warnings.warn("Attributes cannot be in the xml namespace", DataLossWarning)
-            return None
-        else:
-            return self.toXmlName(name)
-
-    def coerceElement(self, name):
-        return self.toXmlName(name)
-
-    def coerceComment(self, data):
-        if self.preventDoubleDashComments:
-            while "--" in data:
-                warnings.warn("Comments cannot contain adjacent dashes", DataLossWarning)
-                data = data.replace("--", "- -")
-            if data.endswith("-"):
-                warnings.warn("Comments cannot end in a dash", DataLossWarning)
-                data += " "
-        return data
-
-    def coerceCharacters(self, data):
-        if self.replaceFormFeedCharacters:
-            for _ in range(data.count("\x0C")):
-                warnings.warn("Text cannot contain U+000C", DataLossWarning)
-            data = data.replace("\x0C", " ")
-        # Other non-xml characters
-        return data
-
-    def coercePubid(self, data):
-        dataOutput = data
-        for char in nonPubidCharRegexp.findall(data):
-            warnings.warn("Coercing non-XML pubid", DataLossWarning)
-            replacement = self.getReplacementCharacter(char)
-            dataOutput = dataOutput.replace(char, replacement)
-        if self.preventSingleQuotePubid and dataOutput.find("'") >= 0:
-            warnings.warn("Pubid cannot contain single quote", DataLossWarning)
-            dataOutput = dataOutput.replace("'", self.getReplacementCharacter("'"))
-        return dataOutput
-
-    def toXmlName(self, name):
-        nameFirst = name[0]
-        nameRest = name[1:]
-        m = nonXmlNameFirstBMPRegexp.match(nameFirst)
-        if m:
-            warnings.warn("Coercing non-XML name: %s" % name, DataLossWarning)
-            nameFirstOutput = self.getReplacementCharacter(nameFirst)
-        else:
-            nameFirstOutput = nameFirst
-
-        nameRestOutput = nameRest
-        replaceChars = set(nonXmlNameBMPRegexp.findall(nameRest))
-        for char in replaceChars:
-            warnings.warn("Coercing non-XML name: %s" % name, DataLossWarning)
-            replacement = self.getReplacementCharacter(char)
-            nameRestOutput = nameRestOutput.replace(char, replacement)
-        return nameFirstOutput + nameRestOutput
-
-    def getReplacementCharacter(self, char):
-        if char in self.replaceCache:
-            replacement = self.replaceCache[char]
-        else:
-            replacement = self.escapeChar(char)
-        return replacement
-
-    def fromXmlName(self, name):
-        for item in set(self.replacementRegexp.findall(name)):
-            name = name.replace(item, self.unescapeChar(item))
-        return name
-
-    def escapeChar(self, char):
-        replacement = "U%05X" % ord(char)
-        self.replaceCache[char] = replacement
-        return replacement
-
-    def unescapeChar(self, charcode):
-        return chr(int(charcode[1:], 16))
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py b/env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py
deleted file mode 100644
index e0bb3760..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_inputstream.py
+++ /dev/null
@@ -1,918 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from pip._vendor.six import text_type
-from pip._vendor.six.moves import http_client, urllib
-
-import codecs
-import re
-from io import BytesIO, StringIO
-
-from pip._vendor import webencodings
-
-from .constants import EOF, spaceCharacters, asciiLetters, asciiUppercase
-from .constants import _ReparseException
-from . import _utils
-
-# Non-unicode versions of constants for use in the pre-parser
-spaceCharactersBytes = frozenset([item.encode("ascii") for item in spaceCharacters])
-asciiLettersBytes = frozenset([item.encode("ascii") for item in asciiLetters])
-asciiUppercaseBytes = frozenset([item.encode("ascii") for item in asciiUppercase])
-spacesAngleBrackets = spaceCharactersBytes | frozenset([b">", b"<"])
-
-
-invalid_unicode_no_surrogate = "[\u0001-\u0008\u000B\u000E-\u001F\u007F-\u009F\uFDD0-\uFDEF\uFFFE\uFFFF\U0001FFFE\U0001FFFF\U0002FFFE\U0002FFFF\U0003FFFE\U0003FFFF\U0004FFFE\U0004FFFF\U0005FFFE\U0005FFFF\U0006FFFE\U0006FFFF\U0007FFFE\U0007FFFF\U0008FFFE\U0008FFFF\U0009FFFE\U0009FFFF\U000AFFFE\U000AFFFF\U000BFFFE\U000BFFFF\U000CFFFE\U000CFFFF\U000DFFFE\U000DFFFF\U000EFFFE\U000EFFFF\U000FFFFE\U000FFFFF\U0010FFFE\U0010FFFF]"  # noqa
-
-if _utils.supports_lone_surrogates:
-    # Use one extra step of indirection and create surrogates with
-    # eval. Not using this indirection would introduce an illegal
-    # unicode literal on platforms not supporting such lone
-    # surrogates.
-    assert invalid_unicode_no_surrogate[-1] == "]" and invalid_unicode_no_surrogate.count("]") == 1
-    invalid_unicode_re = re.compile(invalid_unicode_no_surrogate[:-1] +
-                                    eval('"\\uD800-\\uDFFF"') +  # pylint:disable=eval-used
-                                    "]")
-else:
-    invalid_unicode_re = re.compile(invalid_unicode_no_surrogate)
-
-non_bmp_invalid_codepoints = {0x1FFFE, 0x1FFFF, 0x2FFFE, 0x2FFFF, 0x3FFFE,
-                              0x3FFFF, 0x4FFFE, 0x4FFFF, 0x5FFFE, 0x5FFFF,
-                              0x6FFFE, 0x6FFFF, 0x7FFFE, 0x7FFFF, 0x8FFFE,
-                              0x8FFFF, 0x9FFFE, 0x9FFFF, 0xAFFFE, 0xAFFFF,
-                              0xBFFFE, 0xBFFFF, 0xCFFFE, 0xCFFFF, 0xDFFFE,
-                              0xDFFFF, 0xEFFFE, 0xEFFFF, 0xFFFFE, 0xFFFFF,
-                              0x10FFFE, 0x10FFFF}
-
-ascii_punctuation_re = re.compile("[\u0009-\u000D\u0020-\u002F\u003A-\u0040\u005C\u005B-\u0060\u007B-\u007E]")
-
-# Cache for charsUntil()
-charsUntilRegEx = {}
-
-
-class BufferedStream(object):
-    """Buffering for streams that do not have buffering of their own
-
-    The buffer is implemented as a list of chunks on the assumption that
-    joining many strings will be slow since it is O(n**2)
-    """
-
-    def __init__(self, stream):
-        self.stream = stream
-        self.buffer = []
-        self.position = [-1, 0]  # chunk number, offset
-
-    def tell(self):
-        pos = 0
-        for chunk in self.buffer[:self.position[0]]:
-            pos += len(chunk)
-        pos += self.position[1]
-        return pos
-
-    def seek(self, pos):
-        assert pos <= self._bufferedBytes()
-        offset = pos
-        i = 0
-        while len(self.buffer[i]) < offset:
-            offset -= len(self.buffer[i])
-            i += 1
-        self.position = [i, offset]
-
-    def read(self, bytes):
-        if not self.buffer:
-            return self._readStream(bytes)
-        elif (self.position[0] == len(self.buffer) and
-              self.position[1] == len(self.buffer[-1])):
-            return self._readStream(bytes)
-        else:
-            return self._readFromBuffer(bytes)
-
-    def _bufferedBytes(self):
-        return sum([len(item) for item in self.buffer])
-
-    def _readStream(self, bytes):
-        data = self.stream.read(bytes)
-        self.buffer.append(data)
-        self.position[0] += 1
-        self.position[1] = len(data)
-        return data
-
-    def _readFromBuffer(self, bytes):
-        remainingBytes = bytes
-        rv = []
-        bufferIndex = self.position[0]
-        bufferOffset = self.position[1]
-        while bufferIndex < len(self.buffer) and remainingBytes != 0:
-            assert remainingBytes > 0
-            bufferedData = self.buffer[bufferIndex]
-
-            if remainingBytes <= len(bufferedData) - bufferOffset:
-                bytesToRead = remainingBytes
-                self.position = [bufferIndex, bufferOffset + bytesToRead]
-            else:
-                bytesToRead = len(bufferedData) - bufferOffset
-                self.position = [bufferIndex, len(bufferedData)]
-                bufferIndex += 1
-            rv.append(bufferedData[bufferOffset:bufferOffset + bytesToRead])
-            remainingBytes -= bytesToRead
-
-            bufferOffset = 0
-
-        if remainingBytes:
-            rv.append(self._readStream(remainingBytes))
-
-        return b"".join(rv)
-
-
-def HTMLInputStream(source, **kwargs):
-    # Work around Python bug #20007: read(0) closes the connection.
-    # http://bugs.python.org/issue20007
-    if (isinstance(source, http_client.HTTPResponse) or
-        # Also check for addinfourl wrapping HTTPResponse
-        (isinstance(source, urllib.response.addbase) and
-         isinstance(source.fp, http_client.HTTPResponse))):
-        isUnicode = False
-    elif hasattr(source, "read"):
-        isUnicode = isinstance(source.read(0), text_type)
-    else:
-        isUnicode = isinstance(source, text_type)
-
-    if isUnicode:
-        encodings = [x for x in kwargs if x.endswith("_encoding")]
-        if encodings:
-            raise TypeError("Cannot set an encoding with a unicode input, set %r" % encodings)
-
-        return HTMLUnicodeInputStream(source, **kwargs)
-    else:
-        return HTMLBinaryInputStream(source, **kwargs)
-
-
-class HTMLUnicodeInputStream(object):
-    """Provides a unicode stream of characters to the HTMLTokenizer.
-
-    This class takes care of character encoding and removing or replacing
-    incorrect byte-sequences and also provides column and line tracking.
-
-    """
-
-    _defaultChunkSize = 10240
-
-    def __init__(self, source):
-        """Initialises the HTMLInputStream.
-
-        HTMLInputStream(source, [encoding]) -> Normalized stream from source
-        for use by html5lib.
-
-        source can be either a file-object, local filename or a string.
-
-        The optional encoding parameter must be a string that indicates
-        the encoding.  If specified, that encoding will be used,
-        regardless of any BOM or later declaration (such as in a meta
-        element)
-
-        """
-
-        if not _utils.supports_lone_surrogates:
-            # Such platforms will have already checked for such
-            # surrogate errors, so no need to do this checking.
-            self.reportCharacterErrors = None
-        elif len("\U0010FFFF") == 1:
-            self.reportCharacterErrors = self.characterErrorsUCS4
-        else:
-            self.reportCharacterErrors = self.characterErrorsUCS2
-
-        # List of where new lines occur
-        self.newLines = [0]
-
-        self.charEncoding = (lookupEncoding("utf-8"), "certain")
-        self.dataStream = self.openStream(source)
-
-        self.reset()
-
-    def reset(self):
-        self.chunk = ""
-        self.chunkSize = 0
-        self.chunkOffset = 0
-        self.errors = []
-
-        # number of (complete) lines in previous chunks
-        self.prevNumLines = 0
-        # number of columns in the last line of the previous chunk
-        self.prevNumCols = 0
-
-        # Deal with CR LF and surrogates split over chunk boundaries
-        self._bufferedCharacter = None
-
-    def openStream(self, source):
-        """Produces a file object from source.
-
-        source can be either a file object, local filename or a string.
-
-        """
-        # Already a file object
-        if hasattr(source, 'read'):
-            stream = source
-        else:
-            stream = StringIO(source)
-
-        return stream
-
-    def _position(self, offset):
-        chunk = self.chunk
-        nLines = chunk.count('\n', 0, offset)
-        positionLine = self.prevNumLines + nLines
-        lastLinePos = chunk.rfind('\n', 0, offset)
-        if lastLinePos == -1:
-            positionColumn = self.prevNumCols + offset
-        else:
-            positionColumn = offset - (lastLinePos + 1)
-        return (positionLine, positionColumn)
-
-    def position(self):
-        """Returns (line, col) of the current position in the stream."""
-        line, col = self._position(self.chunkOffset)
-        return (line + 1, col)
-
-    def char(self):
-        """ Read one character from the stream or queue if available. Return
-            EOF when EOF is reached.
-        """
-        # Read a new chunk from the input stream if necessary
-        if self.chunkOffset >= self.chunkSize:
-            if not self.readChunk():
-                return EOF
-
-        chunkOffset = self.chunkOffset
-        char = self.chunk[chunkOffset]
-        self.chunkOffset = chunkOffset + 1
-
-        return char
-
-    def readChunk(self, chunkSize=None):
-        if chunkSize is None:
-            chunkSize = self._defaultChunkSize
-
-        self.prevNumLines, self.prevNumCols = self._position(self.chunkSize)
-
-        self.chunk = ""
-        self.chunkSize = 0
-        self.chunkOffset = 0
-
-        data = self.dataStream.read(chunkSize)
-
-        # Deal with CR LF and surrogates broken across chunks
-        if self._bufferedCharacter:
-            data = self._bufferedCharacter + data
-            self._bufferedCharacter = None
-        elif not data:
-            # We have no more data, bye-bye stream
-            return False
-
-        if len(data) > 1:
-            lastv = ord(data[-1])
-            if lastv == 0x0D or 0xD800 <= lastv <= 0xDBFF:
-                self._bufferedCharacter = data[-1]
-                data = data[:-1]
-
-        if self.reportCharacterErrors:
-            self.reportCharacterErrors(data)
-
-        # Replace invalid characters
-        data = data.replace("\r\n", "\n")
-        data = data.replace("\r", "\n")
-
-        self.chunk = data
-        self.chunkSize = len(data)
-
-        return True
-
-    def characterErrorsUCS4(self, data):
-        for _ in range(len(invalid_unicode_re.findall(data))):
-            self.errors.append("invalid-codepoint")
-
-    def characterErrorsUCS2(self, data):
-        # Someone picked the wrong compile option
-        # You lose
-        skip = False
-        for match in invalid_unicode_re.finditer(data):
-            if skip:
-                continue
-            codepoint = ord(match.group())
-            pos = match.start()
-            # Pretty sure there should be endianness issues here
-            if _utils.isSurrogatePair(data[pos:pos + 2]):
-                # We have a surrogate pair!
-                char_val = _utils.surrogatePairToCodepoint(data[pos:pos + 2])
-                if char_val in non_bmp_invalid_codepoints:
-                    self.errors.append("invalid-codepoint")
-                skip = True
-            elif (codepoint >= 0xD800 and codepoint <= 0xDFFF and
-                  pos == len(data) - 1):
-                self.errors.append("invalid-codepoint")
-            else:
-                skip = False
-                self.errors.append("invalid-codepoint")
-
-    def charsUntil(self, characters, opposite=False):
-        """ Returns a string of characters from the stream up to but not
-        including any character in 'characters' or EOF. 'characters' must be
-        a container that supports the 'in' method and iteration over its
-        characters.
-        """
-
-        # Use a cache of regexps to find the required characters
-        try:
-            chars = charsUntilRegEx[(characters, opposite)]
-        except KeyError:
-            if __debug__:
-                for c in characters:
-                    assert(ord(c) < 128)
-            regex = "".join(["\\x%02x" % ord(c) for c in characters])
-            if not opposite:
-                regex = "^%s" % regex
-            chars = charsUntilRegEx[(characters, opposite)] = re.compile("[%s]+" % regex)
-
-        rv = []
-
-        while True:
-            # Find the longest matching prefix
-            m = chars.match(self.chunk, self.chunkOffset)
-            if m is None:
-                # If nothing matched, and it wasn't because we ran out of chunk,
-                # then stop
-                if self.chunkOffset != self.chunkSize:
-                    break
-            else:
-                end = m.end()
-                # If not the whole chunk matched, return everything
-                # up to the part that didn't match
-                if end != self.chunkSize:
-                    rv.append(self.chunk[self.chunkOffset:end])
-                    self.chunkOffset = end
-                    break
-            # If the whole remainder of the chunk matched,
-            # use it all and read the next chunk
-            rv.append(self.chunk[self.chunkOffset:])
-            if not self.readChunk():
-                # Reached EOF
-                break
-
-        r = "".join(rv)
-        return r
-
-    def unget(self, char):
-        # Only one character is allowed to be ungotten at once - it must
-        # be consumed again before any further call to unget
-        if char is not EOF:
-            if self.chunkOffset == 0:
-                # unget is called quite rarely, so it's a good idea to do
-                # more work here if it saves a bit of work in the frequently
-                # called char and charsUntil.
-                # So, just prepend the ungotten character onto the current
-                # chunk:
-                self.chunk = char + self.chunk
-                self.chunkSize += 1
-            else:
-                self.chunkOffset -= 1
-                assert self.chunk[self.chunkOffset] == char
-
-
-class HTMLBinaryInputStream(HTMLUnicodeInputStream):
-    """Provides a unicode stream of characters to the HTMLTokenizer.
-
-    This class takes care of character encoding and removing or replacing
-    incorrect byte-sequences and also provides column and line tracking.
-
-    """
-
-    def __init__(self, source, override_encoding=None, transport_encoding=None,
-                 same_origin_parent_encoding=None, likely_encoding=None,
-                 default_encoding="windows-1252", useChardet=True):
-        """Initialises the HTMLInputStream.
-
-        HTMLInputStream(source, [encoding]) -> Normalized stream from source
-        for use by html5lib.
-
-        source can be either a file-object, local filename or a string.
-
-        The optional encoding parameter must be a string that indicates
-        the encoding.  If specified, that encoding will be used,
-        regardless of any BOM or later declaration (such as in a meta
-        element)
-
-        """
-        # Raw Stream - for unicode objects this will encode to utf-8 and set
-        #              self.charEncoding as appropriate
-        self.rawStream = self.openStream(source)
-
-        HTMLUnicodeInputStream.__init__(self, self.rawStream)
-
-        # Encoding Information
-        # Number of bytes to use when looking for a meta element with
-        # encoding information
-        self.numBytesMeta = 1024
-        # Number of bytes to use when using detecting encoding using chardet
-        self.numBytesChardet = 100
-        # Things from args
-        self.override_encoding = override_encoding
-        self.transport_encoding = transport_encoding
-        self.same_origin_parent_encoding = same_origin_parent_encoding
-        self.likely_encoding = likely_encoding
-        self.default_encoding = default_encoding
-
-        # Determine encoding
-        self.charEncoding = self.determineEncoding(useChardet)
-        assert self.charEncoding[0] is not None
-
-        # Call superclass
-        self.reset()
-
-    def reset(self):
-        self.dataStream = self.charEncoding[0].codec_info.streamreader(self.rawStream, 'replace')
-        HTMLUnicodeInputStream.reset(self)
-
-    def openStream(self, source):
-        """Produces a file object from source.
-
-        source can be either a file object, local filename or a string.
-
-        """
-        # Already a file object
-        if hasattr(source, 'read'):
-            stream = source
-        else:
-            stream = BytesIO(source)
-
-        try:
-            stream.seek(stream.tell())
-        except Exception:
-            stream = BufferedStream(stream)
-
-        return stream
-
-    def determineEncoding(self, chardet=True):
-        # BOMs take precedence over everything
-        # This will also read past the BOM if present
-        charEncoding = self.detectBOM(), "certain"
-        if charEncoding[0] is not None:
-            return charEncoding
-
-        # If we've been overridden, we've been overridden
-        charEncoding = lookupEncoding(self.override_encoding), "certain"
-        if charEncoding[0] is not None:
-            return charEncoding
-
-        # Now check the transport layer
-        charEncoding = lookupEncoding(self.transport_encoding), "certain"
-        if charEncoding[0] is not None:
-            return charEncoding
-
-        # Look for meta elements with encoding information
-        charEncoding = self.detectEncodingMeta(), "tentative"
-        if charEncoding[0] is not None:
-            return charEncoding
-
-        # Parent document encoding
-        charEncoding = lookupEncoding(self.same_origin_parent_encoding), "tentative"
-        if charEncoding[0] is not None and not charEncoding[0].name.startswith("utf-16"):
-            return charEncoding
-
-        # "likely" encoding
-        charEncoding = lookupEncoding(self.likely_encoding), "tentative"
-        if charEncoding[0] is not None:
-            return charEncoding
-
-        # Guess with chardet, if available
-        if chardet:
-            try:
-                from pip._vendor.chardet.universaldetector import UniversalDetector
-            except ImportError:
-                pass
-            else:
-                buffers = []
-                detector = UniversalDetector()
-                while not detector.done:
-                    buffer = self.rawStream.read(self.numBytesChardet)
-                    assert isinstance(buffer, bytes)
-                    if not buffer:
-                        break
-                    buffers.append(buffer)
-                    detector.feed(buffer)
-                detector.close()
-                encoding = lookupEncoding(detector.result['encoding'])
-                self.rawStream.seek(0)
-                if encoding is not None:
-                    return encoding, "tentative"
-
-        # Try the default encoding
-        charEncoding = lookupEncoding(self.default_encoding), "tentative"
-        if charEncoding[0] is not None:
-            return charEncoding
-
-        # Fallback to html5lib's default if even that hasn't worked
-        return lookupEncoding("windows-1252"), "tentative"
-
-    def changeEncoding(self, newEncoding):
-        assert self.charEncoding[1] != "certain"
-        newEncoding = lookupEncoding(newEncoding)
-        if newEncoding is None:
-            return
-        if newEncoding.name in ("utf-16be", "utf-16le"):
-            newEncoding = lookupEncoding("utf-8")
-            assert newEncoding is not None
-        elif newEncoding == self.charEncoding[0]:
-            self.charEncoding = (self.charEncoding[0], "certain")
-        else:
-            self.rawStream.seek(0)
-            self.charEncoding = (newEncoding, "certain")
-            self.reset()
-            raise _ReparseException("Encoding changed from %s to %s" % (self.charEncoding[0], newEncoding))
-
-    def detectBOM(self):
-        """Attempts to detect at BOM at the start of the stream. If
-        an encoding can be determined from the BOM return the name of the
-        encoding otherwise return None"""
-        bomDict = {
-            codecs.BOM_UTF8: 'utf-8',
-            codecs.BOM_UTF16_LE: 'utf-16le', codecs.BOM_UTF16_BE: 'utf-16be',
-            codecs.BOM_UTF32_LE: 'utf-32le', codecs.BOM_UTF32_BE: 'utf-32be'
-        }
-
-        # Go to beginning of file and read in 4 bytes
-        string = self.rawStream.read(4)
-        assert isinstance(string, bytes)
-
-        # Try detecting the BOM using bytes from the string
-        encoding = bomDict.get(string[:3])         # UTF-8
-        seek = 3
-        if not encoding:
-            # Need to detect UTF-32 before UTF-16
-            encoding = bomDict.get(string)         # UTF-32
-            seek = 4
-            if not encoding:
-                encoding = bomDict.get(string[:2])  # UTF-16
-                seek = 2
-
-        # Set the read position past the BOM if one was found, otherwise
-        # set it to the start of the stream
-        if encoding:
-            self.rawStream.seek(seek)
-            return lookupEncoding(encoding)
-        else:
-            self.rawStream.seek(0)
-            return None
-
-    def detectEncodingMeta(self):
-        """Report the encoding declared by the meta element
-        """
-        buffer = self.rawStream.read(self.numBytesMeta)
-        assert isinstance(buffer, bytes)
-        parser = EncodingParser(buffer)
-        self.rawStream.seek(0)
-        encoding = parser.getEncoding()
-
-        if encoding is not None and encoding.name in ("utf-16be", "utf-16le"):
-            encoding = lookupEncoding("utf-8")
-
-        return encoding
-
-
-class EncodingBytes(bytes):
-    """String-like object with an associated position and various extra methods
-    If the position is ever greater than the string length then an exception is
-    raised"""
-    def __new__(self, value):
-        assert isinstance(value, bytes)
-        return bytes.__new__(self, value.lower())
-
-    def __init__(self, value):
-        # pylint:disable=unused-argument
-        self._position = -1
-
-    def __iter__(self):
-        return self
-
-    def __next__(self):
-        p = self._position = self._position + 1
-        if p >= len(self):
-            raise StopIteration
-        elif p < 0:
-            raise TypeError
-        return self[p:p + 1]
-
-    def next(self):
-        # Py2 compat
-        return self.__next__()
-
-    def previous(self):
-        p = self._position
-        if p >= len(self):
-            raise StopIteration
-        elif p < 0:
-            raise TypeError
-        self._position = p = p - 1
-        return self[p:p + 1]
-
-    def setPosition(self, position):
-        if self._position >= len(self):
-            raise StopIteration
-        self._position = position
-
-    def getPosition(self):
-        if self._position >= len(self):
-            raise StopIteration
-        if self._position >= 0:
-            return self._position
-        else:
-            return None
-
-    position = property(getPosition, setPosition)
-
-    def getCurrentByte(self):
-        return self[self.position:self.position + 1]
-
-    currentByte = property(getCurrentByte)
-
-    def skip(self, chars=spaceCharactersBytes):
-        """Skip past a list of characters"""
-        p = self.position               # use property for the error-checking
-        while p < len(self):
-            c = self[p:p + 1]
-            if c not in chars:
-                self._position = p
-                return c
-            p += 1
-        self._position = p
-        return None
-
-    def skipUntil(self, chars):
-        p = self.position
-        while p < len(self):
-            c = self[p:p + 1]
-            if c in chars:
-                self._position = p
-                return c
-            p += 1
-        self._position = p
-        return None
-
-    def matchBytes(self, bytes):
-        """Look for a sequence of bytes at the start of a string. If the bytes
-        are found return True and advance the position to the byte after the
-        match. Otherwise return False and leave the position alone"""
-        rv = self.startswith(bytes, self.position)
-        if rv:
-            self.position += len(bytes)
-        return rv
-
-    def jumpTo(self, bytes):
-        """Look for the next sequence of bytes matching a given sequence. If
-        a match is found advance the position to the last byte of the match"""
-        try:
-            self._position = self.index(bytes, self.position) + len(bytes) - 1
-        except ValueError:
-            raise StopIteration
-        return True
-
-
-class EncodingParser(object):
-    """Mini parser for detecting character encoding from meta elements"""
-
-    def __init__(self, data):
-        """string - the data to work on for encoding detection"""
-        self.data = EncodingBytes(data)
-        self.encoding = None
-
-    def getEncoding(self):
-        if b"<meta" not in self.data:
-            return None
-
-        methodDispatch = (
-            (b"<!--", self.handleComment),
-            (b"<meta", self.handleMeta),
-            (b"</", self.handlePossibleEndTag),
-            (b"<!", self.handleOther),
-            (b"<?", self.handleOther),
-            (b"<", self.handlePossibleStartTag))
-        for _ in self.data:
-            keepParsing = True
-            try:
-                self.data.jumpTo(b"<")
-            except StopIteration:
-                break
-            for key, method in methodDispatch:
-                if self.data.matchBytes(key):
-                    try:
-                        keepParsing = method()
-                        break
-                    except StopIteration:
-                        keepParsing = False
-                        break
-            if not keepParsing:
-                break
-
-        return self.encoding
-
-    def handleComment(self):
-        """Skip over comments"""
-        return self.data.jumpTo(b"-->")
-
-    def handleMeta(self):
-        if self.data.currentByte not in spaceCharactersBytes:
-            # if we have <meta not followed by a space so just keep going
-            return True
-        # We have a valid meta element we want to search for attributes
-        hasPragma = False
-        pendingEncoding = None
-        while True:
-            # Try to find the next attribute after the current position
-            attr = self.getAttribute()
-            if attr is None:
-                return True
-            else:
-                if attr[0] == b"http-equiv":
-                    hasPragma = attr[1] == b"content-type"
-                    if hasPragma and pendingEncoding is not None:
-                        self.encoding = pendingEncoding
-                        return False
-                elif attr[0] == b"charset":
-                    tentativeEncoding = attr[1]
-                    codec = lookupEncoding(tentativeEncoding)
-                    if codec is not None:
-                        self.encoding = codec
-                        return False
-                elif attr[0] == b"content":
-                    contentParser = ContentAttrParser(EncodingBytes(attr[1]))
-                    tentativeEncoding = contentParser.parse()
-                    if tentativeEncoding is not None:
-                        codec = lookupEncoding(tentativeEncoding)
-                        if codec is not None:
-                            if hasPragma:
-                                self.encoding = codec
-                                return False
-                            else:
-                                pendingEncoding = codec
-
-    def handlePossibleStartTag(self):
-        return self.handlePossibleTag(False)
-
-    def handlePossibleEndTag(self):
-        next(self.data)
-        return self.handlePossibleTag(True)
-
-    def handlePossibleTag(self, endTag):
-        data = self.data
-        if data.currentByte not in asciiLettersBytes:
-            # If the next byte is not an ascii letter either ignore this
-            # fragment (possible start tag case) or treat it according to
-            # handleOther
-            if endTag:
-                data.previous()
-                self.handleOther()
-            return True
-
-        c = data.skipUntil(spacesAngleBrackets)
-        if c == b"<":
-            # return to the first step in the overall "two step" algorithm
-            # reprocessing the < byte
-            data.previous()
-        else:
-            # Read all attributes
-            attr = self.getAttribute()
-            while attr is not None:
-                attr = self.getAttribute()
-        return True
-
-    def handleOther(self):
-        return self.data.jumpTo(b">")
-
-    def getAttribute(self):
-        """Return a name,value pair for the next attribute in the stream,
-        if one is found, or None"""
-        data = self.data
-        # Step 1 (skip chars)
-        c = data.skip(spaceCharactersBytes | frozenset([b"/"]))
-        assert c is None or len(c) == 1
-        # Step 2
-        if c in (b">", None):
-            return None
-        # Step 3
-        attrName = []
-        attrValue = []
-        # Step 4 attribute name
-        while True:
-            if c == b"=" and attrName:
-                break
-            elif c in spaceCharactersBytes:
-                # Step 6!
-                c = data.skip()
-                break
-            elif c in (b"/", b">"):
-                return b"".join(attrName), b""
-            elif c in asciiUppercaseBytes:
-                attrName.append(c.lower())
-            elif c is None:
-                return None
-            else:
-                attrName.append(c)
-            # Step 5
-            c = next(data)
-        # Step 7
-        if c != b"=":
-            data.previous()
-            return b"".join(attrName), b""
-        # Step 8
-        next(data)
-        # Step 9
-        c = data.skip()
-        # Step 10
-        if c in (b"'", b'"'):
-            # 10.1
-            quoteChar = c
-            while True:
-                # 10.2
-                c = next(data)
-                # 10.3
-                if c == quoteChar:
-                    next(data)
-                    return b"".join(attrName), b"".join(attrValue)
-                # 10.4
-                elif c in asciiUppercaseBytes:
-                    attrValue.append(c.lower())
-                # 10.5
-                else:
-                    attrValue.append(c)
-        elif c == b">":
-            return b"".join(attrName), b""
-        elif c in asciiUppercaseBytes:
-            attrValue.append(c.lower())
-        elif c is None:
-            return None
-        else:
-            attrValue.append(c)
-        # Step 11
-        while True:
-            c = next(data)
-            if c in spacesAngleBrackets:
-                return b"".join(attrName), b"".join(attrValue)
-            elif c in asciiUppercaseBytes:
-                attrValue.append(c.lower())
-            elif c is None:
-                return None
-            else:
-                attrValue.append(c)
-
-
-class ContentAttrParser(object):
-    def __init__(self, data):
-        assert isinstance(data, bytes)
-        self.data = data
-
-    def parse(self):
-        try:
-            # Check if the attr name is charset
-            # otherwise return
-            self.data.jumpTo(b"charset")
-            self.data.position += 1
-            self.data.skip()
-            if not self.data.currentByte == b"=":
-                # If there is no = sign keep looking for attrs
-                return None
-            self.data.position += 1
-            self.data.skip()
-            # Look for an encoding between matching quote marks
-            if self.data.currentByte in (b'"', b"'"):
-                quoteMark = self.data.currentByte
-                self.data.position += 1
-                oldPosition = self.data.position
-                if self.data.jumpTo(quoteMark):
-                    return self.data[oldPosition:self.data.position]
-                else:
-                    return None
-            else:
-                # Unquoted value
-                oldPosition = self.data.position
-                try:
-                    self.data.skipUntil(spaceCharactersBytes)
-                    return self.data[oldPosition:self.data.position]
-                except StopIteration:
-                    # Return the whole remaining value
-                    return self.data[oldPosition:]
-        except StopIteration:
-            return None
-
-
-def lookupEncoding(encoding):
-    """Return the python codec name corresponding to an encoding or None if the
-    string doesn't correspond to a valid encoding."""
-    if isinstance(encoding, bytes):
-        try:
-            encoding = encoding.decode("ascii")
-        except UnicodeDecodeError:
-            return None
-
-    if encoding is not None:
-        try:
-            return webencodings.lookup(encoding)
-        except AttributeError:
-            return None
-    else:
-        return None
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py b/env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py
deleted file mode 100644
index 5f00253e..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_tokenizer.py
+++ /dev/null
@@ -1,1735 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from pip._vendor.six import unichr as chr
-
-from collections import deque, OrderedDict
-from sys import version_info
-
-from .constants import spaceCharacters
-from .constants import entities
-from .constants import asciiLetters, asciiUpper2Lower
-from .constants import digits, hexDigits, EOF
-from .constants import tokenTypes, tagTokenTypes
-from .constants import replacementCharacters
-
-from ._inputstream import HTMLInputStream
-
-from ._trie import Trie
-
-entitiesTrie = Trie(entities)
-
-if version_info >= (3, 7):
-    attributeMap = dict
-else:
-    attributeMap = OrderedDict
-
-
-class HTMLTokenizer(object):
-    """ This class takes care of tokenizing HTML.
-
-    * self.currentToken
-      Holds the token that is currently being processed.
-
-    * self.state
-      Holds a reference to the method to be invoked... XXX
-
-    * self.stream
-      Points to HTMLInputStream object.
-    """
-
-    def __init__(self, stream, parser=None, **kwargs):
-
-        self.stream = HTMLInputStream(stream, **kwargs)
-        self.parser = parser
-
-        # Setup the initial tokenizer state
-        self.escapeFlag = False
-        self.lastFourChars = []
-        self.state = self.dataState
-        self.escape = False
-
-        # The current token being created
-        self.currentToken = None
-        super(HTMLTokenizer, self).__init__()
-
-    def __iter__(self):
-        """ This is where the magic happens.
-
-        We do our usually processing through the states and when we have a token
-        to return we yield the token which pauses processing until the next token
-        is requested.
-        """
-        self.tokenQueue = deque([])
-        # Start processing. When EOF is reached self.state will return False
-        # instead of True and the loop will terminate.
-        while self.state():
-            while self.stream.errors:
-                yield {"type": tokenTypes["ParseError"], "data": self.stream.errors.pop(0)}
-            while self.tokenQueue:
-                yield self.tokenQueue.popleft()
-
-    def consumeNumberEntity(self, isHex):
-        """This function returns either U+FFFD or the character based on the
-        decimal or hexadecimal representation. It also discards ";" if present.
-        If not present self.tokenQueue.append({"type": tokenTypes["ParseError"]}) is invoked.
-        """
-
-        allowed = digits
-        radix = 10
-        if isHex:
-            allowed = hexDigits
-            radix = 16
-
-        charStack = []
-
-        # Consume all the characters that are in range while making sure we
-        # don't hit an EOF.
-        c = self.stream.char()
-        while c in allowed and c is not EOF:
-            charStack.append(c)
-            c = self.stream.char()
-
-        # Convert the set of characters consumed to an int.
-        charAsInt = int("".join(charStack), radix)
-
-        # Certain characters get replaced with others
-        if charAsInt in replacementCharacters:
-            char = replacementCharacters[charAsInt]
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "illegal-codepoint-for-numeric-entity",
-                                    "datavars": {"charAsInt": charAsInt}})
-        elif ((0xD800 <= charAsInt <= 0xDFFF) or
-              (charAsInt > 0x10FFFF)):
-            char = "\uFFFD"
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "illegal-codepoint-for-numeric-entity",
-                                    "datavars": {"charAsInt": charAsInt}})
-        else:
-            # Should speed up this check somehow (e.g. move the set to a constant)
-            if ((0x0001 <= charAsInt <= 0x0008) or
-                (0x000E <= charAsInt <= 0x001F) or
-                (0x007F <= charAsInt <= 0x009F) or
-                (0xFDD0 <= charAsInt <= 0xFDEF) or
-                charAsInt in frozenset([0x000B, 0xFFFE, 0xFFFF, 0x1FFFE,
-                                        0x1FFFF, 0x2FFFE, 0x2FFFF, 0x3FFFE,
-                                        0x3FFFF, 0x4FFFE, 0x4FFFF, 0x5FFFE,
-                                        0x5FFFF, 0x6FFFE, 0x6FFFF, 0x7FFFE,
-                                        0x7FFFF, 0x8FFFE, 0x8FFFF, 0x9FFFE,
-                                        0x9FFFF, 0xAFFFE, 0xAFFFF, 0xBFFFE,
-                                        0xBFFFF, 0xCFFFE, 0xCFFFF, 0xDFFFE,
-                                        0xDFFFF, 0xEFFFE, 0xEFFFF, 0xFFFFE,
-                                        0xFFFFF, 0x10FFFE, 0x10FFFF])):
-                self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                        "data":
-                                        "illegal-codepoint-for-numeric-entity",
-                                        "datavars": {"charAsInt": charAsInt}})
-            try:
-                # Try/except needed as UCS-2 Python builds' unichar only works
-                # within the BMP.
-                char = chr(charAsInt)
-            except ValueError:
-                v = charAsInt - 0x10000
-                char = chr(0xD800 | (v >> 10)) + chr(0xDC00 | (v & 0x3FF))
-
-        # Discard the ; if present. Otherwise, put it back on the queue and
-        # invoke parseError on parser.
-        if c != ";":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "numeric-entity-without-semicolon"})
-            self.stream.unget(c)
-
-        return char
-
-    def consumeEntity(self, allowedChar=None, fromAttribute=False):
-        # Initialise to the default output for when no entity is matched
-        output = "&"
-
-        charStack = [self.stream.char()]
-        if (charStack[0] in spaceCharacters or charStack[0] in (EOF, "<", "&") or
-                (allowedChar is not None and allowedChar == charStack[0])):
-            self.stream.unget(charStack[0])
-
-        elif charStack[0] == "#":
-            # Read the next character to see if it's hex or decimal
-            hex = False
-            charStack.append(self.stream.char())
-            if charStack[-1] in ("x", "X"):
-                hex = True
-                charStack.append(self.stream.char())
-
-            # charStack[-1] should be the first digit
-            if (hex and charStack[-1] in hexDigits) \
-                    or (not hex and charStack[-1] in digits):
-                # At least one digit found, so consume the whole number
-                self.stream.unget(charStack[-1])
-                output = self.consumeNumberEntity(hex)
-            else:
-                # No digits found
-                self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                        "data": "expected-numeric-entity"})
-                self.stream.unget(charStack.pop())
-                output = "&" + "".join(charStack)
-
-        else:
-            # At this point in the process might have named entity. Entities
-            # are stored in the global variable "entities".
-            #
-            # Consume characters and compare to these to a substring of the
-            # entity names in the list until the substring no longer matches.
-            while (charStack[-1] is not EOF):
-                if not entitiesTrie.has_keys_with_prefix("".join(charStack)):
-                    break
-                charStack.append(self.stream.char())
-
-            # At this point we have a string that starts with some characters
-            # that may match an entity
-            # Try to find the longest entity the string will match to take care
-            # of &noti for instance.
-            try:
-                entityName = entitiesTrie.longest_prefix("".join(charStack[:-1]))
-                entityLength = len(entityName)
-            except KeyError:
-                entityName = None
-
-            if entityName is not None:
-                if entityName[-1] != ";":
-                    self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                            "named-entity-without-semicolon"})
-                if (entityName[-1] != ";" and fromAttribute and
-                    (charStack[entityLength] in asciiLetters or
-                     charStack[entityLength] in digits or
-                     charStack[entityLength] == "=")):
-                    self.stream.unget(charStack.pop())
-                    output = "&" + "".join(charStack)
-                else:
-                    output = entities[entityName]
-                    self.stream.unget(charStack.pop())
-                    output += "".join(charStack[entityLength:])
-            else:
-                self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                        "expected-named-entity"})
-                self.stream.unget(charStack.pop())
-                output = "&" + "".join(charStack)
-
-        if fromAttribute:
-            self.currentToken["data"][-1][1] += output
-        else:
-            if output in spaceCharacters:
-                tokenType = "SpaceCharacters"
-            else:
-                tokenType = "Characters"
-            self.tokenQueue.append({"type": tokenTypes[tokenType], "data": output})
-
-    def processEntityInAttribute(self, allowedChar):
-        """This method replaces the need for "entityInAttributeValueState".
-        """
-        self.consumeEntity(allowedChar=allowedChar, fromAttribute=True)
-
-    def emitCurrentToken(self):
-        """This method is a generic handler for emitting the tags. It also sets
-        the state to "data" because that's what's needed after a token has been
-        emitted.
-        """
-        token = self.currentToken
-        # Add token to the queue to be yielded
-        if (token["type"] in tagTokenTypes):
-            token["name"] = token["name"].translate(asciiUpper2Lower)
-            if token["type"] == tokenTypes["StartTag"]:
-                raw = token["data"]
-                data = attributeMap(raw)
-                if len(raw) > len(data):
-                    # we had some duplicated attribute, fix so first wins
-                    data.update(raw[::-1])
-                token["data"] = data
-
-            if token["type"] == tokenTypes["EndTag"]:
-                if token["data"]:
-                    self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                            "data": "attributes-in-end-tag"})
-                if token["selfClosing"]:
-                    self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                            "data": "self-closing-flag-on-end-tag"})
-        self.tokenQueue.append(token)
-        self.state = self.dataState
-
-    # Below are the various tokenizer states worked out.
-    def dataState(self):
-        data = self.stream.char()
-        if data == "&":
-            self.state = self.entityDataState
-        elif data == "<":
-            self.state = self.tagOpenState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\u0000"})
-        elif data is EOF:
-            # Tokenization ends.
-            return False
-        elif data in spaceCharacters:
-            # Directly after emitting a token you switch back to the "data
-            # state". At that point spaceCharacters are important so they are
-            # emitted separately.
-            self.tokenQueue.append({"type": tokenTypes["SpaceCharacters"], "data":
-                                    data + self.stream.charsUntil(spaceCharacters, True)})
-            # No need to update lastFourChars here, since the first space will
-            # have already been appended to lastFourChars and will have broken
-            # any <!-- or --> sequences
-        else:
-            chars = self.stream.charsUntil(("&", "<", "\u0000"))
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data":
-                                    data + chars})
-        return True
-
-    def entityDataState(self):
-        self.consumeEntity()
-        self.state = self.dataState
-        return True
-
-    def rcdataState(self):
-        data = self.stream.char()
-        if data == "&":
-            self.state = self.characterReferenceInRcdata
-        elif data == "<":
-            self.state = self.rcdataLessThanSignState
-        elif data == EOF:
-            # Tokenization ends.
-            return False
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-        elif data in spaceCharacters:
-            # Directly after emitting a token you switch back to the "data
-            # state". At that point spaceCharacters are important so they are
-            # emitted separately.
-            self.tokenQueue.append({"type": tokenTypes["SpaceCharacters"], "data":
-                                    data + self.stream.charsUntil(spaceCharacters, True)})
-            # No need to update lastFourChars here, since the first space will
-            # have already been appended to lastFourChars and will have broken
-            # any <!-- or --> sequences
-        else:
-            chars = self.stream.charsUntil(("&", "<", "\u0000"))
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data":
-                                    data + chars})
-        return True
-
-    def characterReferenceInRcdata(self):
-        self.consumeEntity()
-        self.state = self.rcdataState
-        return True
-
-    def rawtextState(self):
-        data = self.stream.char()
-        if data == "<":
-            self.state = self.rawtextLessThanSignState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-        elif data == EOF:
-            # Tokenization ends.
-            return False
-        else:
-            chars = self.stream.charsUntil(("<", "\u0000"))
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data":
-                                    data + chars})
-        return True
-
-    def scriptDataState(self):
-        data = self.stream.char()
-        if data == "<":
-            self.state = self.scriptDataLessThanSignState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-        elif data == EOF:
-            # Tokenization ends.
-            return False
-        else:
-            chars = self.stream.charsUntil(("<", "\u0000"))
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data":
-                                    data + chars})
-        return True
-
-    def plaintextState(self):
-        data = self.stream.char()
-        if data == EOF:
-            # Tokenization ends.
-            return False
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data":
-                                    data + self.stream.charsUntil("\u0000")})
-        return True
-
-    def tagOpenState(self):
-        data = self.stream.char()
-        if data == "!":
-            self.state = self.markupDeclarationOpenState
-        elif data == "/":
-            self.state = self.closeTagOpenState
-        elif data in asciiLetters:
-            self.currentToken = {"type": tokenTypes["StartTag"],
-                                 "name": data, "data": [],
-                                 "selfClosing": False,
-                                 "selfClosingAcknowledged": False}
-            self.state = self.tagNameState
-        elif data == ">":
-            # XXX In theory it could be something besides a tag name. But
-            # do we really care?
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-tag-name-but-got-right-bracket"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<>"})
-            self.state = self.dataState
-        elif data == "?":
-            # XXX In theory it could be something besides a tag name. But
-            # do we really care?
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-tag-name-but-got-question-mark"})
-            self.stream.unget(data)
-            self.state = self.bogusCommentState
-        else:
-            # XXX
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-tag-name"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.stream.unget(data)
-            self.state = self.dataState
-        return True
-
-    def closeTagOpenState(self):
-        data = self.stream.char()
-        if data in asciiLetters:
-            self.currentToken = {"type": tokenTypes["EndTag"], "name": data,
-                                 "data": [], "selfClosing": False}
-            self.state = self.tagNameState
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-closing-tag-but-got-right-bracket"})
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-closing-tag-but-got-eof"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"})
-            self.state = self.dataState
-        else:
-            # XXX data can be _'_...
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-closing-tag-but-got-char",
-                                    "datavars": {"data": data}})
-            self.stream.unget(data)
-            self.state = self.bogusCommentState
-        return True
-
-    def tagNameState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.beforeAttributeNameState
-        elif data == ">":
-            self.emitCurrentToken()
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-tag-name"})
-            self.state = self.dataState
-        elif data == "/":
-            self.state = self.selfClosingStartTagState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["name"] += "\uFFFD"
-        else:
-            self.currentToken["name"] += data
-            # (Don't use charsUntil here, because tag names are
-            # very short and it's faster to not do anything fancy)
-        return True
-
-    def rcdataLessThanSignState(self):
-        data = self.stream.char()
-        if data == "/":
-            self.temporaryBuffer = ""
-            self.state = self.rcdataEndTagOpenState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.stream.unget(data)
-            self.state = self.rcdataState
-        return True
-
-    def rcdataEndTagOpenState(self):
-        data = self.stream.char()
-        if data in asciiLetters:
-            self.temporaryBuffer += data
-            self.state = self.rcdataEndTagNameState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"})
-            self.stream.unget(data)
-            self.state = self.rcdataState
-        return True
-
-    def rcdataEndTagNameState(self):
-        appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower()
-        data = self.stream.char()
-        if data in spaceCharacters and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.beforeAttributeNameState
-        elif data == "/" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.selfClosingStartTagState
-        elif data == ">" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.emitCurrentToken()
-            self.state = self.dataState
-        elif data in asciiLetters:
-            self.temporaryBuffer += data
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "</" + self.temporaryBuffer})
-            self.stream.unget(data)
-            self.state = self.rcdataState
-        return True
-
-    def rawtextLessThanSignState(self):
-        data = self.stream.char()
-        if data == "/":
-            self.temporaryBuffer = ""
-            self.state = self.rawtextEndTagOpenState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.stream.unget(data)
-            self.state = self.rawtextState
-        return True
-
-    def rawtextEndTagOpenState(self):
-        data = self.stream.char()
-        if data in asciiLetters:
-            self.temporaryBuffer += data
-            self.state = self.rawtextEndTagNameState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"})
-            self.stream.unget(data)
-            self.state = self.rawtextState
-        return True
-
-    def rawtextEndTagNameState(self):
-        appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower()
-        data = self.stream.char()
-        if data in spaceCharacters and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.beforeAttributeNameState
-        elif data == "/" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.selfClosingStartTagState
-        elif data == ">" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.emitCurrentToken()
-            self.state = self.dataState
-        elif data in asciiLetters:
-            self.temporaryBuffer += data
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "</" + self.temporaryBuffer})
-            self.stream.unget(data)
-            self.state = self.rawtextState
-        return True
-
-    def scriptDataLessThanSignState(self):
-        data = self.stream.char()
-        if data == "/":
-            self.temporaryBuffer = ""
-            self.state = self.scriptDataEndTagOpenState
-        elif data == "!":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<!"})
-            self.state = self.scriptDataEscapeStartState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.stream.unget(data)
-            self.state = self.scriptDataState
-        return True
-
-    def scriptDataEndTagOpenState(self):
-        data = self.stream.char()
-        if data in asciiLetters:
-            self.temporaryBuffer += data
-            self.state = self.scriptDataEndTagNameState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"})
-            self.stream.unget(data)
-            self.state = self.scriptDataState
-        return True
-
-    def scriptDataEndTagNameState(self):
-        appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower()
-        data = self.stream.char()
-        if data in spaceCharacters and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.beforeAttributeNameState
-        elif data == "/" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.selfClosingStartTagState
-        elif data == ">" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.emitCurrentToken()
-            self.state = self.dataState
-        elif data in asciiLetters:
-            self.temporaryBuffer += data
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "</" + self.temporaryBuffer})
-            self.stream.unget(data)
-            self.state = self.scriptDataState
-        return True
-
-    def scriptDataEscapeStartState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-            self.state = self.scriptDataEscapeStartDashState
-        else:
-            self.stream.unget(data)
-            self.state = self.scriptDataState
-        return True
-
-    def scriptDataEscapeStartDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-            self.state = self.scriptDataEscapedDashDashState
-        else:
-            self.stream.unget(data)
-            self.state = self.scriptDataState
-        return True
-
-    def scriptDataEscapedState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-            self.state = self.scriptDataEscapedDashState
-        elif data == "<":
-            self.state = self.scriptDataEscapedLessThanSignState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-        elif data == EOF:
-            self.state = self.dataState
-        else:
-            chars = self.stream.charsUntil(("<", "-", "\u0000"))
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data":
-                                    data + chars})
-        return True
-
-    def scriptDataEscapedDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-            self.state = self.scriptDataEscapedDashDashState
-        elif data == "<":
-            self.state = self.scriptDataEscapedLessThanSignState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-            self.state = self.scriptDataEscapedState
-        elif data == EOF:
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            self.state = self.scriptDataEscapedState
-        return True
-
-    def scriptDataEscapedDashDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-        elif data == "<":
-            self.state = self.scriptDataEscapedLessThanSignState
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": ">"})
-            self.state = self.scriptDataState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-            self.state = self.scriptDataEscapedState
-        elif data == EOF:
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            self.state = self.scriptDataEscapedState
-        return True
-
-    def scriptDataEscapedLessThanSignState(self):
-        data = self.stream.char()
-        if data == "/":
-            self.temporaryBuffer = ""
-            self.state = self.scriptDataEscapedEndTagOpenState
-        elif data in asciiLetters:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<" + data})
-            self.temporaryBuffer = data
-            self.state = self.scriptDataDoubleEscapeStartState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.stream.unget(data)
-            self.state = self.scriptDataEscapedState
-        return True
-
-    def scriptDataEscapedEndTagOpenState(self):
-        data = self.stream.char()
-        if data in asciiLetters:
-            self.temporaryBuffer = data
-            self.state = self.scriptDataEscapedEndTagNameState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "</"})
-            self.stream.unget(data)
-            self.state = self.scriptDataEscapedState
-        return True
-
-    def scriptDataEscapedEndTagNameState(self):
-        appropriate = self.currentToken and self.currentToken["name"].lower() == self.temporaryBuffer.lower()
-        data = self.stream.char()
-        if data in spaceCharacters and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.beforeAttributeNameState
-        elif data == "/" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.state = self.selfClosingStartTagState
-        elif data == ">" and appropriate:
-            self.currentToken = {"type": tokenTypes["EndTag"],
-                                 "name": self.temporaryBuffer,
-                                 "data": [], "selfClosing": False}
-            self.emitCurrentToken()
-            self.state = self.dataState
-        elif data in asciiLetters:
-            self.temporaryBuffer += data
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "</" + self.temporaryBuffer})
-            self.stream.unget(data)
-            self.state = self.scriptDataEscapedState
-        return True
-
-    def scriptDataDoubleEscapeStartState(self):
-        data = self.stream.char()
-        if data in (spaceCharacters | frozenset(("/", ">"))):
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            if self.temporaryBuffer.lower() == "script":
-                self.state = self.scriptDataDoubleEscapedState
-            else:
-                self.state = self.scriptDataEscapedState
-        elif data in asciiLetters:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            self.temporaryBuffer += data
-        else:
-            self.stream.unget(data)
-            self.state = self.scriptDataEscapedState
-        return True
-
-    def scriptDataDoubleEscapedState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-            self.state = self.scriptDataDoubleEscapedDashState
-        elif data == "<":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.state = self.scriptDataDoubleEscapedLessThanSignState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-        elif data == EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-script-in-script"})
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-        return True
-
-    def scriptDataDoubleEscapedDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-            self.state = self.scriptDataDoubleEscapedDashDashState
-        elif data == "<":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.state = self.scriptDataDoubleEscapedLessThanSignState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-            self.state = self.scriptDataDoubleEscapedState
-        elif data == EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-script-in-script"})
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            self.state = self.scriptDataDoubleEscapedState
-        return True
-
-    def scriptDataDoubleEscapedDashDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "-"})
-        elif data == "<":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "<"})
-            self.state = self.scriptDataDoubleEscapedLessThanSignState
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": ">"})
-            self.state = self.scriptDataState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": "\uFFFD"})
-            self.state = self.scriptDataDoubleEscapedState
-        elif data == EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-script-in-script"})
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            self.state = self.scriptDataDoubleEscapedState
-        return True
-
-    def scriptDataDoubleEscapedLessThanSignState(self):
-        data = self.stream.char()
-        if data == "/":
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": "/"})
-            self.temporaryBuffer = ""
-            self.state = self.scriptDataDoubleEscapeEndState
-        else:
-            self.stream.unget(data)
-            self.state = self.scriptDataDoubleEscapedState
-        return True
-
-    def scriptDataDoubleEscapeEndState(self):
-        data = self.stream.char()
-        if data in (spaceCharacters | frozenset(("/", ">"))):
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            if self.temporaryBuffer.lower() == "script":
-                self.state = self.scriptDataEscapedState
-            else:
-                self.state = self.scriptDataDoubleEscapedState
-        elif data in asciiLetters:
-            self.tokenQueue.append({"type": tokenTypes["Characters"], "data": data})
-            self.temporaryBuffer += data
-        else:
-            self.stream.unget(data)
-            self.state = self.scriptDataDoubleEscapedState
-        return True
-
-    def beforeAttributeNameState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.stream.charsUntil(spaceCharacters, True)
-        elif data in asciiLetters:
-            self.currentToken["data"].append([data, ""])
-            self.state = self.attributeNameState
-        elif data == ">":
-            self.emitCurrentToken()
-        elif data == "/":
-            self.state = self.selfClosingStartTagState
-        elif data in ("'", '"', "=", "<"):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "invalid-character-in-attribute-name"})
-            self.currentToken["data"].append([data, ""])
-            self.state = self.attributeNameState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"].append(["\uFFFD", ""])
-            self.state = self.attributeNameState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-attribute-name-but-got-eof"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"].append([data, ""])
-            self.state = self.attributeNameState
-        return True
-
-    def attributeNameState(self):
-        data = self.stream.char()
-        leavingThisState = True
-        emitToken = False
-        if data == "=":
-            self.state = self.beforeAttributeValueState
-        elif data in asciiLetters:
-            self.currentToken["data"][-1][0] += data +\
-                self.stream.charsUntil(asciiLetters, True)
-            leavingThisState = False
-        elif data == ">":
-            # XXX If we emit here the attributes are converted to a dict
-            # without being checked and when the code below runs we error
-            # because data is a dict not a list
-            emitToken = True
-        elif data in spaceCharacters:
-            self.state = self.afterAttributeNameState
-        elif data == "/":
-            self.state = self.selfClosingStartTagState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"][-1][0] += "\uFFFD"
-            leavingThisState = False
-        elif data in ("'", '"', "<"):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data":
-                                    "invalid-character-in-attribute-name"})
-            self.currentToken["data"][-1][0] += data
-            leavingThisState = False
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "eof-in-attribute-name"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"][-1][0] += data
-            leavingThisState = False
-
-        if leavingThisState:
-            # Attributes are not dropped at this stage. That happens when the
-            # start tag token is emitted so values can still be safely appended
-            # to attributes, but we do want to report the parse error in time.
-            self.currentToken["data"][-1][0] = (
-                self.currentToken["data"][-1][0].translate(asciiUpper2Lower))
-            for name, _ in self.currentToken["data"][:-1]:
-                if self.currentToken["data"][-1][0] == name:
-                    self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                            "duplicate-attribute"})
-                    break
-            # XXX Fix for above XXX
-            if emitToken:
-                self.emitCurrentToken()
-        return True
-
-    def afterAttributeNameState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.stream.charsUntil(spaceCharacters, True)
-        elif data == "=":
-            self.state = self.beforeAttributeValueState
-        elif data == ">":
-            self.emitCurrentToken()
-        elif data in asciiLetters:
-            self.currentToken["data"].append([data, ""])
-            self.state = self.attributeNameState
-        elif data == "/":
-            self.state = self.selfClosingStartTagState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"].append(["\uFFFD", ""])
-            self.state = self.attributeNameState
-        elif data in ("'", '"', "<"):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "invalid-character-after-attribute-name"})
-            self.currentToken["data"].append([data, ""])
-            self.state = self.attributeNameState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-end-of-tag-but-got-eof"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"].append([data, ""])
-            self.state = self.attributeNameState
-        return True
-
-    def beforeAttributeValueState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.stream.charsUntil(spaceCharacters, True)
-        elif data == "\"":
-            self.state = self.attributeValueDoubleQuotedState
-        elif data == "&":
-            self.state = self.attributeValueUnQuotedState
-            self.stream.unget(data)
-        elif data == "'":
-            self.state = self.attributeValueSingleQuotedState
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-attribute-value-but-got-right-bracket"})
-            self.emitCurrentToken()
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"][-1][1] += "\uFFFD"
-            self.state = self.attributeValueUnQuotedState
-        elif data in ("=", "<", "`"):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "equals-in-unquoted-attribute-value"})
-            self.currentToken["data"][-1][1] += data
-            self.state = self.attributeValueUnQuotedState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-attribute-value-but-got-eof"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"][-1][1] += data
-            self.state = self.attributeValueUnQuotedState
-        return True
-
-    def attributeValueDoubleQuotedState(self):
-        data = self.stream.char()
-        if data == "\"":
-            self.state = self.afterAttributeValueState
-        elif data == "&":
-            self.processEntityInAttribute('"')
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"][-1][1] += "\uFFFD"
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-attribute-value-double-quote"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"][-1][1] += data +\
-                self.stream.charsUntil(("\"", "&", "\u0000"))
-        return True
-
-    def attributeValueSingleQuotedState(self):
-        data = self.stream.char()
-        if data == "'":
-            self.state = self.afterAttributeValueState
-        elif data == "&":
-            self.processEntityInAttribute("'")
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"][-1][1] += "\uFFFD"
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-attribute-value-single-quote"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"][-1][1] += data +\
-                self.stream.charsUntil(("'", "&", "\u0000"))
-        return True
-
-    def attributeValueUnQuotedState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.beforeAttributeNameState
-        elif data == "&":
-            self.processEntityInAttribute(">")
-        elif data == ">":
-            self.emitCurrentToken()
-        elif data in ('"', "'", "=", "<", "`"):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-character-in-unquoted-attribute-value"})
-            self.currentToken["data"][-1][1] += data
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"][-1][1] += "\uFFFD"
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-attribute-value-no-quotes"})
-            self.state = self.dataState
-        else:
-            self.currentToken["data"][-1][1] += data + self.stream.charsUntil(
-                frozenset(("&", ">", '"', "'", "=", "<", "`", "\u0000")) | spaceCharacters)
-        return True
-
-    def afterAttributeValueState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.beforeAttributeNameState
-        elif data == ">":
-            self.emitCurrentToken()
-        elif data == "/":
-            self.state = self.selfClosingStartTagState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-EOF-after-attribute-value"})
-            self.stream.unget(data)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-character-after-attribute-value"})
-            self.stream.unget(data)
-            self.state = self.beforeAttributeNameState
-        return True
-
-    def selfClosingStartTagState(self):
-        data = self.stream.char()
-        if data == ">":
-            self.currentToken["selfClosing"] = True
-            self.emitCurrentToken()
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data":
-                                    "unexpected-EOF-after-solidus-in-tag"})
-            self.stream.unget(data)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-character-after-solidus-in-tag"})
-            self.stream.unget(data)
-            self.state = self.beforeAttributeNameState
-        return True
-
-    def bogusCommentState(self):
-        # Make a new comment token and give it as value all the characters
-        # until the first > or EOF (charsUntil checks for EOF automatically)
-        # and emit it.
-        data = self.stream.charsUntil(">")
-        data = data.replace("\u0000", "\uFFFD")
-        self.tokenQueue.append(
-            {"type": tokenTypes["Comment"], "data": data})
-
-        # Eat the character directly after the bogus comment which is either a
-        # ">" or an EOF.
-        self.stream.char()
-        self.state = self.dataState
-        return True
-
-    def markupDeclarationOpenState(self):
-        charStack = [self.stream.char()]
-        if charStack[-1] == "-":
-            charStack.append(self.stream.char())
-            if charStack[-1] == "-":
-                self.currentToken = {"type": tokenTypes["Comment"], "data": ""}
-                self.state = self.commentStartState
-                return True
-        elif charStack[-1] in ('d', 'D'):
-            matched = True
-            for expected in (('o', 'O'), ('c', 'C'), ('t', 'T'),
-                             ('y', 'Y'), ('p', 'P'), ('e', 'E')):
-                charStack.append(self.stream.char())
-                if charStack[-1] not in expected:
-                    matched = False
-                    break
-            if matched:
-                self.currentToken = {"type": tokenTypes["Doctype"],
-                                     "name": "",
-                                     "publicId": None, "systemId": None,
-                                     "correct": True}
-                self.state = self.doctypeState
-                return True
-        elif (charStack[-1] == "[" and
-              self.parser is not None and
-              self.parser.tree.openElements and
-              self.parser.tree.openElements[-1].namespace != self.parser.tree.defaultNamespace):
-            matched = True
-            for expected in ["C", "D", "A", "T", "A", "["]:
-                charStack.append(self.stream.char())
-                if charStack[-1] != expected:
-                    matched = False
-                    break
-            if matched:
-                self.state = self.cdataSectionState
-                return True
-
-        self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                "expected-dashes-or-doctype"})
-
-        while charStack:
-            self.stream.unget(charStack.pop())
-        self.state = self.bogusCommentState
-        return True
-
-    def commentStartState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.state = self.commentStartDashState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"] += "\uFFFD"
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "incorrect-comment"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-comment"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["data"] += data
-            self.state = self.commentState
-        return True
-
-    def commentStartDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.state = self.commentEndState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"] += "-\uFFFD"
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "incorrect-comment"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-comment"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["data"] += "-" + data
-            self.state = self.commentState
-        return True
-
-    def commentState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.state = self.commentEndDashState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"] += "\uFFFD"
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "eof-in-comment"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["data"] += data + \
-                self.stream.charsUntil(("-", "\u0000"))
-        return True
-
-    def commentEndDashState(self):
-        data = self.stream.char()
-        if data == "-":
-            self.state = self.commentEndState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"] += "-\uFFFD"
-            self.state = self.commentState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-comment-end-dash"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["data"] += "-" + data
-            self.state = self.commentState
-        return True
-
-    def commentEndState(self):
-        data = self.stream.char()
-        if data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"] += "--\uFFFD"
-            self.state = self.commentState
-        elif data == "!":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-bang-after-double-dash-in-comment"})
-            self.state = self.commentEndBangState
-        elif data == "-":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-dash-after-double-dash-in-comment"})
-            self.currentToken["data"] += data
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-comment-double-dash"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            # XXX
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-comment"})
-            self.currentToken["data"] += "--" + data
-            self.state = self.commentState
-        return True
-
-    def commentEndBangState(self):
-        data = self.stream.char()
-        if data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data == "-":
-            self.currentToken["data"] += "--!"
-            self.state = self.commentEndDashState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["data"] += "--!\uFFFD"
-            self.state = self.commentState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-comment-end-bang-state"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["data"] += "--!" + data
-            self.state = self.commentState
-        return True
-
-    def doctypeState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.beforeDoctypeNameState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-doctype-name-but-got-eof"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "need-space-after-doctype"})
-            self.stream.unget(data)
-            self.state = self.beforeDoctypeNameState
-        return True
-
-    def beforeDoctypeNameState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            pass
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-doctype-name-but-got-right-bracket"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["name"] = "\uFFFD"
-            self.state = self.doctypeNameState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-doctype-name-but-got-eof"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["name"] = data
-            self.state = self.doctypeNameState
-        return True
-
-    def doctypeNameState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower)
-            self.state = self.afterDoctypeNameState
-        elif data == ">":
-            self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower)
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["name"] += "\uFFFD"
-            self.state = self.doctypeNameState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype-name"})
-            self.currentToken["correct"] = False
-            self.currentToken["name"] = self.currentToken["name"].translate(asciiUpper2Lower)
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["name"] += data
-        return True
-
-    def afterDoctypeNameState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            pass
-        elif data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.currentToken["correct"] = False
-            self.stream.unget(data)
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            if data in ("p", "P"):
-                matched = True
-                for expected in (("u", "U"), ("b", "B"), ("l", "L"),
-                                 ("i", "I"), ("c", "C")):
-                    data = self.stream.char()
-                    if data not in expected:
-                        matched = False
-                        break
-                if matched:
-                    self.state = self.afterDoctypePublicKeywordState
-                    return True
-            elif data in ("s", "S"):
-                matched = True
-                for expected in (("y", "Y"), ("s", "S"), ("t", "T"),
-                                 ("e", "E"), ("m", "M")):
-                    data = self.stream.char()
-                    if data not in expected:
-                        matched = False
-                        break
-                if matched:
-                    self.state = self.afterDoctypeSystemKeywordState
-                    return True
-
-            # All the characters read before the current 'data' will be
-            # [a-zA-Z], so they're garbage in the bogus doctype and can be
-            # discarded; only the latest character might be '>' or EOF
-            # and needs to be ungetted
-            self.stream.unget(data)
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "expected-space-or-right-bracket-in-doctype", "datavars":
-                                    {"data": data}})
-            self.currentToken["correct"] = False
-            self.state = self.bogusDoctypeState
-
-        return True
-
-    def afterDoctypePublicKeywordState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.beforeDoctypePublicIdentifierState
-        elif data in ("'", '"'):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.stream.unget(data)
-            self.state = self.beforeDoctypePublicIdentifierState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.stream.unget(data)
-            self.state = self.beforeDoctypePublicIdentifierState
-        return True
-
-    def beforeDoctypePublicIdentifierState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            pass
-        elif data == "\"":
-            self.currentToken["publicId"] = ""
-            self.state = self.doctypePublicIdentifierDoubleQuotedState
-        elif data == "'":
-            self.currentToken["publicId"] = ""
-            self.state = self.doctypePublicIdentifierSingleQuotedState
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-end-of-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["correct"] = False
-            self.state = self.bogusDoctypeState
-        return True
-
-    def doctypePublicIdentifierDoubleQuotedState(self):
-        data = self.stream.char()
-        if data == "\"":
-            self.state = self.afterDoctypePublicIdentifierState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["publicId"] += "\uFFFD"
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-end-of-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["publicId"] += data
-        return True
-
-    def doctypePublicIdentifierSingleQuotedState(self):
-        data = self.stream.char()
-        if data == "'":
-            self.state = self.afterDoctypePublicIdentifierState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["publicId"] += "\uFFFD"
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-end-of-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["publicId"] += data
-        return True
-
-    def afterDoctypePublicIdentifierState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.betweenDoctypePublicAndSystemIdentifiersState
-        elif data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data == '"':
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["systemId"] = ""
-            self.state = self.doctypeSystemIdentifierDoubleQuotedState
-        elif data == "'":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["systemId"] = ""
-            self.state = self.doctypeSystemIdentifierSingleQuotedState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["correct"] = False
-            self.state = self.bogusDoctypeState
-        return True
-
-    def betweenDoctypePublicAndSystemIdentifiersState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            pass
-        elif data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data == '"':
-            self.currentToken["systemId"] = ""
-            self.state = self.doctypeSystemIdentifierDoubleQuotedState
-        elif data == "'":
-            self.currentToken["systemId"] = ""
-            self.state = self.doctypeSystemIdentifierSingleQuotedState
-        elif data == EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["correct"] = False
-            self.state = self.bogusDoctypeState
-        return True
-
-    def afterDoctypeSystemKeywordState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            self.state = self.beforeDoctypeSystemIdentifierState
-        elif data in ("'", '"'):
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.stream.unget(data)
-            self.state = self.beforeDoctypeSystemIdentifierState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.stream.unget(data)
-            self.state = self.beforeDoctypeSystemIdentifierState
-        return True
-
-    def beforeDoctypeSystemIdentifierState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            pass
-        elif data == "\"":
-            self.currentToken["systemId"] = ""
-            self.state = self.doctypeSystemIdentifierDoubleQuotedState
-        elif data == "'":
-            self.currentToken["systemId"] = ""
-            self.state = self.doctypeSystemIdentifierSingleQuotedState
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.currentToken["correct"] = False
-            self.state = self.bogusDoctypeState
-        return True
-
-    def doctypeSystemIdentifierDoubleQuotedState(self):
-        data = self.stream.char()
-        if data == "\"":
-            self.state = self.afterDoctypeSystemIdentifierState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["systemId"] += "\uFFFD"
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-end-of-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["systemId"] += data
-        return True
-
-    def doctypeSystemIdentifierSingleQuotedState(self):
-        data = self.stream.char()
-        if data == "'":
-            self.state = self.afterDoctypeSystemIdentifierState
-        elif data == "\u0000":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                    "data": "invalid-codepoint"})
-            self.currentToken["systemId"] += "\uFFFD"
-        elif data == ">":
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-end-of-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.currentToken["systemId"] += data
-        return True
-
-    def afterDoctypeSystemIdentifierState(self):
-        data = self.stream.char()
-        if data in spaceCharacters:
-            pass
-        elif data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "eof-in-doctype"})
-            self.currentToken["correct"] = False
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            self.tokenQueue.append({"type": tokenTypes["ParseError"], "data":
-                                    "unexpected-char-in-doctype"})
-            self.state = self.bogusDoctypeState
-        return True
-
-    def bogusDoctypeState(self):
-        data = self.stream.char()
-        if data == ">":
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        elif data is EOF:
-            # XXX EMIT
-            self.stream.unget(data)
-            self.tokenQueue.append(self.currentToken)
-            self.state = self.dataState
-        else:
-            pass
-        return True
-
-    def cdataSectionState(self):
-        data = []
-        while True:
-            data.append(self.stream.charsUntil("]"))
-            data.append(self.stream.charsUntil(">"))
-            char = self.stream.char()
-            if char == EOF:
-                break
-            else:
-                assert char == ">"
-                if data[-1][-2:] == "]]":
-                    data[-1] = data[-1][:-2]
-                    break
-                else:
-                    data.append(char)
-
-        data = "".join(data)  # pylint:disable=redefined-variable-type
-        # Deal with null here rather than in the parser
-        nullCount = data.count("\u0000")
-        if nullCount > 0:
-            for _ in range(nullCount):
-                self.tokenQueue.append({"type": tokenTypes["ParseError"],
-                                        "data": "invalid-codepoint"})
-            data = data.replace("\u0000", "\uFFFD")
-        if data:
-            self.tokenQueue.append({"type": tokenTypes["Characters"],
-                                    "data": data})
-        self.state = self.dataState
-        return True
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py
deleted file mode 100644
index 07bad5d3..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__init__.py
+++ /dev/null
@@ -1,5 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from .py import Trie
-
-__all__ = ["Trie"]
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 948138bf21c0d7677f4e18a9dcc56d220438985a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 380
zcmYe~<>g{vU|^UdaWFNPfq~&Mh=Yuo7#J8F7#J9ewHO!}QW#Pga~N_NqZo6UqL^}-
zqnH^PQkYVhb69d&qgWXkQdrU%qu5edgBdj0UV==~WWL3pm{gpfQ(BT5pP5^bUsQ67
zBPFvevp6$9@0LJmUS@KBN@{#gW=U#MVovc(Mg|53O~zX+Aw`*~MQjWV41SvIx47ct
z(@IN9i&Ep`i$KmPVrF1qC}Lq?V7SFpPzhFci#<L*F()TJekDT@$Uk7>SG%)SOlWax
zQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9KYmkCj
zOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZuS!!NNevy7g
xNp6m5PG*vRd`VGes(yTYW?p7Ve7s&k<t+}I-29Z%oK!oI|B68_7h&RI0s!5RXkGvS

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/_base.cpython-39.pyc
deleted file mode 100644
index 2693bbb73e2f1897267f6d0e71288337437604d2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1624
zcmYe~<>g{vU|^UdaWM5OGXuk85C<7^FfcGUFfcF_M=&rjq%fo~<}l<kMlt3xMKR?v
zM=>)pR0*Uoq%h^M<g!MwGBSiS<jJuxq_R~yF*1N4SdJYc7s-&vWWeCgkiwk8(!!9!
zlFHi59L15s8qA={_7Y^LCi5-+#H8Z<oYIoi_{`jb{GyUu94VP)nZ=p;dA9^g^D>k3
zQ&Qt|GD}j65_5_*8E>)sCKeQA=A|ctv?F5{D5uzpfq@~FA&N1DA&M!5F^V~byPYA8
z5$pucD3%n~6t)(IDApAA6pj{#D7F;N6s{JADE4*+7KSK}U<OT|TPz_(nW<H>j!DHO
zMTyBJ3Q38@sS3$CiN(bVY57G8B}JL3#eT_5Q2Rg>GXnzy3>O<PFff!blrYvXG&3z=
zTF6k#)WML#P|8pwSHfJw)XW&n0Co>!3R4S54U-E4NJNv_FPRZ!5)^|BXJueu5C+AA
z6axc8215-)tWYgu4dVia4u*w{MJzRplb8xwf*DpaXfod7DlSPZDk(0{EXmMhy2Yet
zaEq~GCF3o&f}+&4%!(p*1_p*-EzVXkp~b01#WATlDVaqv{&}e`MVV!(3c3oRex6~j
zLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5FKAA}|
z#hE3kx&?{J*@@|?#W4k$1^V%2sd*{+Mfw>fxjCjenMwNbpzzX<2L+;DLFFw@o8r`x
z<ow(MJCNT#gZx`10}61x?9|F)J)4~T<iwm}J3Y8EO_p1%#ia$QMMZ233=FqeK+0}0
z7pInJGT&k;PR&Ux;$dK5C=z5~U|7j`i!(kR98>Y}Mcg1^UJwD211Ty7C2a;KJ|+%E
z4yGzjxUCp*2}(=OprBV`U|^_WSirE5!G$4Kq?W0MX#rym<3h$F4n~F)#$bj*jufU~
z22Eza5I0RGup5d%c4#sefqVyc*)8Vm)Jkv+KnReFZi!?h7RQ5p5)X>9ct|vff@}n7
zXJF)E<N`TS66{25YH>R`1mtAK8iq24BAyz?V1^Qg6vh(98pdYE6h?7|W+oSgSdChy
z8pafc8YXUrRwhXXuv$4}5heykhG2$5xe_Ljz9z;LhF}IwCcl@UB&x}Li?t{*FFo}Z
zb53gBEe`M0O4p*I{2~-TGiE|O3rcuJU?214<maWQ7MDQ%Dg*K>C{7p{IT%@(#2AGb
zMVP9D!Tv>6iQ!XFMgvEV7|5p#3m8BV0*aa%h8iYGhBQ!wF#2gS7RfR&Frc`KJqHrd
z=x!56wJ|=kBsEtJ<Umk5U|{58tdhXuFt9RBMn6r?TO9H6d5O8H@$t8~;^TAkQ%Z9{
zY@Yb|!qUVXs0@32d`f<Dd^{wTh=bB4$bm)jpj6EZO}5FYIXUt1NbVB>sRIQdIQ4Ua
z90e-9L1D(n$-&OS1r`Unfh#^ft+b@HC^bI52vmF&fx@W><bzxM$@w`ssmUdo`FX{9
ziAl*tprYj#w<ox~1xMa3ZX_jOBaz&Ih(rz>i0AA;385I|5D_LOMgc}1Mj>VZBvf}8

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/__pycache__/py.cpython-39.pyc
deleted file mode 100644
index ff2ef154a2f14c3b384b2ffb17b82206e1625b9e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py
deleted file mode 100644
index 6b71975f..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/_base.py
+++ /dev/null
@@ -1,40 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-try:
-    from collections.abc import Mapping
-except ImportError:  # Python 2.7
-    from collections import Mapping
-
-
-class Trie(Mapping):
-    """Abstract base class for tries"""
-
-    def keys(self, prefix=None):
-        # pylint:disable=arguments-differ
-        keys = super(Trie, self).keys()
-
-        if prefix is None:
-            return set(keys)
-
-        return {x for x in keys if x.startswith(prefix)}
-
-    def has_keys_with_prefix(self, prefix):
-        for key in self.keys():
-            if key.startswith(prefix):
-                return True
-
-        return False
-
-    def longest_prefix(self, prefix):
-        if prefix in self:
-            return prefix
-
-        for i in range(1, len(prefix) + 1):
-            if prefix[:-i] in self:
-                return prefix[:-i]
-
-        raise KeyError(prefix)
-
-    def longest_prefix_item(self, prefix):
-        lprefix = self.longest_prefix(prefix)
-        return (lprefix, self[lprefix])
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py b/env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py
deleted file mode 100644
index c178b219..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_trie/py.py
+++ /dev/null
@@ -1,67 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-from pip._vendor.six import text_type
-
-from bisect import bisect_left
-
-from ._base import Trie as ABCTrie
-
-
-class Trie(ABCTrie):
-    def __init__(self, data):
-        if not all(isinstance(x, text_type) for x in data.keys()):
-            raise TypeError("All keys must be strings")
-
-        self._data = data
-        self._keys = sorted(data.keys())
-        self._cachestr = ""
-        self._cachepoints = (0, len(data))
-
-    def __contains__(self, key):
-        return key in self._data
-
-    def __len__(self):
-        return len(self._data)
-
-    def __iter__(self):
-        return iter(self._data)
-
-    def __getitem__(self, key):
-        return self._data[key]
-
-    def keys(self, prefix=None):
-        if prefix is None or prefix == "" or not self._keys:
-            return set(self._keys)
-
-        if prefix.startswith(self._cachestr):
-            lo, hi = self._cachepoints
-            start = i = bisect_left(self._keys, prefix, lo, hi)
-        else:
-            start = i = bisect_left(self._keys, prefix)
-
-        keys = set()
-        if start == len(self._keys):
-            return keys
-
-        while self._keys[i].startswith(prefix):
-            keys.add(self._keys[i])
-            i += 1
-
-        self._cachestr = prefix
-        self._cachepoints = (start, i)
-
-        return keys
-
-    def has_keys_with_prefix(self, prefix):
-        if prefix in self._data:
-            return True
-
-        if prefix.startswith(self._cachestr):
-            lo, hi = self._cachepoints
-            i = bisect_left(self._keys, prefix, lo, hi)
-        else:
-            i = bisect_left(self._keys, prefix)
-
-        if i == len(self._keys):
-            return False
-
-        return self._keys[i].startswith(prefix)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/_utils.py b/env/Lib/site-packages/pip/_vendor/html5lib/_utils.py
deleted file mode 100644
index d7c4926a..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/_utils.py
+++ /dev/null
@@ -1,159 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from types import ModuleType
-
-try:
-    from collections.abc import Mapping
-except ImportError:
-    from collections import Mapping
-
-from pip._vendor.six import text_type, PY3
-
-if PY3:
-    import xml.etree.ElementTree as default_etree
-else:
-    try:
-        import xml.etree.cElementTree as default_etree
-    except ImportError:
-        import xml.etree.ElementTree as default_etree
-
-
-__all__ = ["default_etree", "MethodDispatcher", "isSurrogatePair",
-           "surrogatePairToCodepoint", "moduleFactoryFactory",
-           "supports_lone_surrogates"]
-
-
-# Platforms not supporting lone surrogates (\uD800-\uDFFF) should be
-# caught by the below test. In general this would be any platform
-# using UTF-16 as its encoding of unicode strings, such as
-# Jython. This is because UTF-16 itself is based on the use of such
-# surrogates, and there is no mechanism to further escape such
-# escapes.
-try:
-    _x = eval('"\\uD800"')  # pylint:disable=eval-used
-    if not isinstance(_x, text_type):
-        # We need this with u"" because of http://bugs.jython.org/issue2039
-        _x = eval('u"\\uD800"')  # pylint:disable=eval-used
-        assert isinstance(_x, text_type)
-except Exception:
-    supports_lone_surrogates = False
-else:
-    supports_lone_surrogates = True
-
-
-class MethodDispatcher(dict):
-    """Dict with 2 special properties:
-
-    On initiation, keys that are lists, sets or tuples are converted to
-    multiple keys so accessing any one of the items in the original
-    list-like object returns the matching value
-
-    md = MethodDispatcher({("foo", "bar"):"baz"})
-    md["foo"] == "baz"
-
-    A default value which can be set through the default attribute.
-    """
-
-    def __init__(self, items=()):
-        _dictEntries = []
-        for name, value in items:
-            if isinstance(name, (list, tuple, frozenset, set)):
-                for item in name:
-                    _dictEntries.append((item, value))
-            else:
-                _dictEntries.append((name, value))
-        dict.__init__(self, _dictEntries)
-        assert len(self) == len(_dictEntries)
-        self.default = None
-
-    def __getitem__(self, key):
-        return dict.get(self, key, self.default)
-
-    def __get__(self, instance, owner=None):
-        return BoundMethodDispatcher(instance, self)
-
-
-class BoundMethodDispatcher(Mapping):
-    """Wraps a MethodDispatcher, binding its return values to `instance`"""
-    def __init__(self, instance, dispatcher):
-        self.instance = instance
-        self.dispatcher = dispatcher
-
-    def __getitem__(self, key):
-        # see https://docs.python.org/3/reference/datamodel.html#object.__get__
-        # on a function, __get__ is used to bind a function to an instance as a bound method
-        return self.dispatcher[key].__get__(self.instance)
-
-    def get(self, key, default):
-        if key in self.dispatcher:
-            return self[key]
-        else:
-            return default
-
-    def __iter__(self):
-        return iter(self.dispatcher)
-
-    def __len__(self):
-        return len(self.dispatcher)
-
-    def __contains__(self, key):
-        return key in self.dispatcher
-
-
-# Some utility functions to deal with weirdness around UCS2 vs UCS4
-# python builds
-
-def isSurrogatePair(data):
-    return (len(data) == 2 and
-            ord(data[0]) >= 0xD800 and ord(data[0]) <= 0xDBFF and
-            ord(data[1]) >= 0xDC00 and ord(data[1]) <= 0xDFFF)
-
-
-def surrogatePairToCodepoint(data):
-    char_val = (0x10000 + (ord(data[0]) - 0xD800) * 0x400 +
-                (ord(data[1]) - 0xDC00))
-    return char_val
-
-# Module Factory Factory (no, this isn't Java, I know)
-# Here to stop this being duplicated all over the place.
-
-
-def moduleFactoryFactory(factory):
-    moduleCache = {}
-
-    def moduleFactory(baseModule, *args, **kwargs):
-        if isinstance(ModuleType.__name__, type("")):
-            name = "_%s_factory" % baseModule.__name__
-        else:
-            name = b"_%s_factory" % baseModule.__name__
-
-        kwargs_tuple = tuple(kwargs.items())
-
-        try:
-            return moduleCache[name][args][kwargs_tuple]
-        except KeyError:
-            mod = ModuleType(name)
-            objs = factory(baseModule, *args, **kwargs)
-            mod.__dict__.update(objs)
-            if "name" not in moduleCache:
-                moduleCache[name] = {}
-            if "args" not in moduleCache[name]:
-                moduleCache[name][args] = {}
-            if "kwargs" not in moduleCache[name][args]:
-                moduleCache[name][args][kwargs_tuple] = {}
-            moduleCache[name][args][kwargs_tuple] = mod
-            return mod
-
-    return moduleFactory
-
-
-def memoize(func):
-    cache = {}
-
-    def wrapped(*args, **kwargs):
-        key = (tuple(args), tuple(kwargs.items()))
-        if key not in cache:
-            cache[key] = func(*args, **kwargs)
-        return cache[key]
-
-    return wrapped
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/constants.py b/env/Lib/site-packages/pip/_vendor/html5lib/constants.py
deleted file mode 100644
index fe3e237c..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/constants.py
+++ /dev/null
@@ -1,2946 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-import string
-
-EOF = None
-
-E = {
-    "null-character":
-        "Null character in input stream, replaced with U+FFFD.",
-    "invalid-codepoint":
-        "Invalid codepoint in stream.",
-    "incorrectly-placed-solidus":
-        "Solidus (/) incorrectly placed in tag.",
-    "incorrect-cr-newline-entity":
-        "Incorrect CR newline entity, replaced with LF.",
-    "illegal-windows-1252-entity":
-        "Entity used with illegal number (windows-1252 reference).",
-    "cant-convert-numeric-entity":
-        "Numeric entity couldn't be converted to character "
-        "(codepoint U+%(charAsInt)08x).",
-    "illegal-codepoint-for-numeric-entity":
-        "Numeric entity represents an illegal codepoint: "
-        "U+%(charAsInt)08x.",
-    "numeric-entity-without-semicolon":
-        "Numeric entity didn't end with ';'.",
-    "expected-numeric-entity-but-got-eof":
-        "Numeric entity expected. Got end of file instead.",
-    "expected-numeric-entity":
-        "Numeric entity expected but none found.",
-    "named-entity-without-semicolon":
-        "Named entity didn't end with ';'.",
-    "expected-named-entity":
-        "Named entity expected. Got none.",
-    "attributes-in-end-tag":
-        "End tag contains unexpected attributes.",
-    'self-closing-flag-on-end-tag':
-        "End tag contains unexpected self-closing flag.",
-    "expected-tag-name-but-got-right-bracket":
-        "Expected tag name. Got '>' instead.",
-    "expected-tag-name-but-got-question-mark":
-        "Expected tag name. Got '?' instead. (HTML doesn't "
-        "support processing instructions.)",
-    "expected-tag-name":
-        "Expected tag name. Got something else instead",
-    "expected-closing-tag-but-got-right-bracket":
-        "Expected closing tag. Got '>' instead. Ignoring '</>'.",
-    "expected-closing-tag-but-got-eof":
-        "Expected closing tag. Unexpected end of file.",
-    "expected-closing-tag-but-got-char":
-        "Expected closing tag. Unexpected character '%(data)s' found.",
-    "eof-in-tag-name":
-        "Unexpected end of file in the tag name.",
-    "expected-attribute-name-but-got-eof":
-        "Unexpected end of file. Expected attribute name instead.",
-    "eof-in-attribute-name":
-        "Unexpected end of file in attribute name.",
-    "invalid-character-in-attribute-name":
-        "Invalid character in attribute name",
-    "duplicate-attribute":
-        "Dropped duplicate attribute on tag.",
-    "expected-end-of-tag-name-but-got-eof":
-        "Unexpected end of file. Expected = or end of tag.",
-    "expected-attribute-value-but-got-eof":
-        "Unexpected end of file. Expected attribute value.",
-    "expected-attribute-value-but-got-right-bracket":
-        "Expected attribute value. Got '>' instead.",
-    'equals-in-unquoted-attribute-value':
-        "Unexpected = in unquoted attribute",
-    'unexpected-character-in-unquoted-attribute-value':
-        "Unexpected character in unquoted attribute",
-    "invalid-character-after-attribute-name":
-        "Unexpected character after attribute name.",
-    "unexpected-character-after-attribute-value":
-        "Unexpected character after attribute value.",
-    "eof-in-attribute-value-double-quote":
-        "Unexpected end of file in attribute value (\").",
-    "eof-in-attribute-value-single-quote":
-        "Unexpected end of file in attribute value (').",
-    "eof-in-attribute-value-no-quotes":
-        "Unexpected end of file in attribute value.",
-    "unexpected-EOF-after-solidus-in-tag":
-        "Unexpected end of file in tag. Expected >",
-    "unexpected-character-after-solidus-in-tag":
-        "Unexpected character after / in tag. Expected >",
-    "expected-dashes-or-doctype":
-        "Expected '--' or 'DOCTYPE'. Not found.",
-    "unexpected-bang-after-double-dash-in-comment":
-        "Unexpected ! after -- in comment",
-    "unexpected-space-after-double-dash-in-comment":
-        "Unexpected space after -- in comment",
-    "incorrect-comment":
-        "Incorrect comment.",
-    "eof-in-comment":
-        "Unexpected end of file in comment.",
-    "eof-in-comment-end-dash":
-        "Unexpected end of file in comment (-)",
-    "unexpected-dash-after-double-dash-in-comment":
-        "Unexpected '-' after '--' found in comment.",
-    "eof-in-comment-double-dash":
-        "Unexpected end of file in comment (--).",
-    "eof-in-comment-end-space-state":
-        "Unexpected end of file in comment.",
-    "eof-in-comment-end-bang-state":
-        "Unexpected end of file in comment.",
-    "unexpected-char-in-comment":
-        "Unexpected character in comment found.",
-    "need-space-after-doctype":
-        "No space after literal string 'DOCTYPE'.",
-    "expected-doctype-name-but-got-right-bracket":
-        "Unexpected > character. Expected DOCTYPE name.",
-    "expected-doctype-name-but-got-eof":
-        "Unexpected end of file. Expected DOCTYPE name.",
-    "eof-in-doctype-name":
-        "Unexpected end of file in DOCTYPE name.",
-    "eof-in-doctype":
-        "Unexpected end of file in DOCTYPE.",
-    "expected-space-or-right-bracket-in-doctype":
-        "Expected space or '>'. Got '%(data)s'",
-    "unexpected-end-of-doctype":
-        "Unexpected end of DOCTYPE.",
-    "unexpected-char-in-doctype":
-        "Unexpected character in DOCTYPE.",
-    "eof-in-innerhtml":
-        "XXX innerHTML EOF",
-    "unexpected-doctype":
-        "Unexpected DOCTYPE. Ignored.",
-    "non-html-root":
-        "html needs to be the first start tag.",
-    "expected-doctype-but-got-eof":
-        "Unexpected End of file. Expected DOCTYPE.",
-    "unknown-doctype":
-        "Erroneous DOCTYPE.",
-    "expected-doctype-but-got-chars":
-        "Unexpected non-space characters. Expected DOCTYPE.",
-    "expected-doctype-but-got-start-tag":
-        "Unexpected start tag (%(name)s). Expected DOCTYPE.",
-    "expected-doctype-but-got-end-tag":
-        "Unexpected end tag (%(name)s). Expected DOCTYPE.",
-    "end-tag-after-implied-root":
-        "Unexpected end tag (%(name)s) after the (implied) root element.",
-    "expected-named-closing-tag-but-got-eof":
-        "Unexpected end of file. Expected end tag (%(name)s).",
-    "two-heads-are-not-better-than-one":
-        "Unexpected start tag head in existing head. Ignored.",
-    "unexpected-end-tag":
-        "Unexpected end tag (%(name)s). Ignored.",
-    "unexpected-start-tag-out-of-my-head":
-        "Unexpected start tag (%(name)s) that can be in head. Moved.",
-    "unexpected-start-tag":
-        "Unexpected start tag (%(name)s).",
-    "missing-end-tag":
-        "Missing end tag (%(name)s).",
-    "missing-end-tags":
-        "Missing end tags (%(name)s).",
-    "unexpected-start-tag-implies-end-tag":
-        "Unexpected start tag (%(startName)s) "
-        "implies end tag (%(endName)s).",
-    "unexpected-start-tag-treated-as":
-        "Unexpected start tag (%(originalName)s). Treated as %(newName)s.",
-    "deprecated-tag":
-        "Unexpected start tag %(name)s. Don't use it!",
-    "unexpected-start-tag-ignored":
-        "Unexpected start tag %(name)s. Ignored.",
-    "expected-one-end-tag-but-got-another":
-        "Unexpected end tag (%(gotName)s). "
-        "Missing end tag (%(expectedName)s).",
-    "end-tag-too-early":
-        "End tag (%(name)s) seen too early. Expected other end tag.",
-    "end-tag-too-early-named":
-        "Unexpected end tag (%(gotName)s). Expected end tag (%(expectedName)s).",
-    "end-tag-too-early-ignored":
-        "End tag (%(name)s) seen too early. Ignored.",
-    "adoption-agency-1.1":
-        "End tag (%(name)s) violates step 1, "
-        "paragraph 1 of the adoption agency algorithm.",
-    "adoption-agency-1.2":
-        "End tag (%(name)s) violates step 1, "
-        "paragraph 2 of the adoption agency algorithm.",
-    "adoption-agency-1.3":
-        "End tag (%(name)s) violates step 1, "
-        "paragraph 3 of the adoption agency algorithm.",
-    "adoption-agency-4.4":
-        "End tag (%(name)s) violates step 4, "
-        "paragraph 4 of the adoption agency algorithm.",
-    "unexpected-end-tag-treated-as":
-        "Unexpected end tag (%(originalName)s). Treated as %(newName)s.",
-    "no-end-tag":
-        "This element (%(name)s) has no end tag.",
-    "unexpected-implied-end-tag-in-table":
-        "Unexpected implied end tag (%(name)s) in the table phase.",
-    "unexpected-implied-end-tag-in-table-body":
-        "Unexpected implied end tag (%(name)s) in the table body phase.",
-    "unexpected-char-implies-table-voodoo":
-        "Unexpected non-space characters in "
-        "table context caused voodoo mode.",
-    "unexpected-hidden-input-in-table":
-        "Unexpected input with type hidden in table context.",
-    "unexpected-form-in-table":
-        "Unexpected form in table context.",
-    "unexpected-start-tag-implies-table-voodoo":
-        "Unexpected start tag (%(name)s) in "
-        "table context caused voodoo mode.",
-    "unexpected-end-tag-implies-table-voodoo":
-        "Unexpected end tag (%(name)s) in "
-        "table context caused voodoo mode.",
-    "unexpected-cell-in-table-body":
-        "Unexpected table cell start tag (%(name)s) "
-        "in the table body phase.",
-    "unexpected-cell-end-tag":
-        "Got table cell end tag (%(name)s) "
-        "while required end tags are missing.",
-    "unexpected-end-tag-in-table-body":
-        "Unexpected end tag (%(name)s) in the table body phase. Ignored.",
-    "unexpected-implied-end-tag-in-table-row":
-        "Unexpected implied end tag (%(name)s) in the table row phase.",
-    "unexpected-end-tag-in-table-row":
-        "Unexpected end tag (%(name)s) in the table row phase. Ignored.",
-    "unexpected-select-in-select":
-        "Unexpected select start tag in the select phase "
-        "treated as select end tag.",
-    "unexpected-input-in-select":
-        "Unexpected input start tag in the select phase.",
-    "unexpected-start-tag-in-select":
-        "Unexpected start tag token (%(name)s in the select phase. "
-        "Ignored.",
-    "unexpected-end-tag-in-select":
-        "Unexpected end tag (%(name)s) in the select phase. Ignored.",
-    "unexpected-table-element-start-tag-in-select-in-table":
-        "Unexpected table element start tag (%(name)s) in the select in table phase.",
-    "unexpected-table-element-end-tag-in-select-in-table":
-        "Unexpected table element end tag (%(name)s) in the select in table phase.",
-    "unexpected-char-after-body":
-        "Unexpected non-space characters in the after body phase.",
-    "unexpected-start-tag-after-body":
-        "Unexpected start tag token (%(name)s)"
-        " in the after body phase.",
-    "unexpected-end-tag-after-body":
-        "Unexpected end tag token (%(name)s)"
-        " in the after body phase.",
-    "unexpected-char-in-frameset":
-        "Unexpected characters in the frameset phase. Characters ignored.",
-    "unexpected-start-tag-in-frameset":
-        "Unexpected start tag token (%(name)s)"
-        " in the frameset phase. Ignored.",
-    "unexpected-frameset-in-frameset-innerhtml":
-        "Unexpected end tag token (frameset) "
-        "in the frameset phase (innerHTML).",
-    "unexpected-end-tag-in-frameset":
-        "Unexpected end tag token (%(name)s)"
-        " in the frameset phase. Ignored.",
-    "unexpected-char-after-frameset":
-        "Unexpected non-space characters in the "
-        "after frameset phase. Ignored.",
-    "unexpected-start-tag-after-frameset":
-        "Unexpected start tag (%(name)s)"
-        " in the after frameset phase. Ignored.",
-    "unexpected-end-tag-after-frameset":
-        "Unexpected end tag (%(name)s)"
-        " in the after frameset phase. Ignored.",
-    "unexpected-end-tag-after-body-innerhtml":
-        "Unexpected end tag after body(innerHtml)",
-    "expected-eof-but-got-char":
-        "Unexpected non-space characters. Expected end of file.",
-    "expected-eof-but-got-start-tag":
-        "Unexpected start tag (%(name)s)"
-        ". Expected end of file.",
-    "expected-eof-but-got-end-tag":
-        "Unexpected end tag (%(name)s)"
-        ". Expected end of file.",
-    "eof-in-table":
-        "Unexpected end of file. Expected table content.",
-    "eof-in-select":
-        "Unexpected end of file. Expected select content.",
-    "eof-in-frameset":
-        "Unexpected end of file. Expected frameset content.",
-    "eof-in-script-in-script":
-        "Unexpected end of file. Expected script content.",
-    "eof-in-foreign-lands":
-        "Unexpected end of file. Expected foreign content",
-    "non-void-element-with-trailing-solidus":
-        "Trailing solidus not allowed on element %(name)s",
-    "unexpected-html-element-in-foreign-content":
-        "Element %(name)s not allowed in a non-html context",
-    "unexpected-end-tag-before-html":
-        "Unexpected end tag (%(name)s) before html.",
-    "unexpected-inhead-noscript-tag":
-        "Element %(name)s not allowed in a inhead-noscript context",
-    "eof-in-head-noscript":
-        "Unexpected end of file. Expected inhead-noscript content",
-    "char-in-head-noscript":
-        "Unexpected non-space character. Expected inhead-noscript content",
-    "XXX-undefined-error":
-        "Undefined error (this sucks and should be fixed)",
-}
-
-namespaces = {
-    "html": "http://www.w3.org/1999/xhtml",
-    "mathml": "http://www.w3.org/1998/Math/MathML",
-    "svg": "http://www.w3.org/2000/svg",
-    "xlink": "http://www.w3.org/1999/xlink",
-    "xml": "http://www.w3.org/XML/1998/namespace",
-    "xmlns": "http://www.w3.org/2000/xmlns/"
-}
-
-scopingElements = frozenset([
-    (namespaces["html"], "applet"),
-    (namespaces["html"], "caption"),
-    (namespaces["html"], "html"),
-    (namespaces["html"], "marquee"),
-    (namespaces["html"], "object"),
-    (namespaces["html"], "table"),
-    (namespaces["html"], "td"),
-    (namespaces["html"], "th"),
-    (namespaces["mathml"], "mi"),
-    (namespaces["mathml"], "mo"),
-    (namespaces["mathml"], "mn"),
-    (namespaces["mathml"], "ms"),
-    (namespaces["mathml"], "mtext"),
-    (namespaces["mathml"], "annotation-xml"),
-    (namespaces["svg"], "foreignObject"),
-    (namespaces["svg"], "desc"),
-    (namespaces["svg"], "title"),
-])
-
-formattingElements = frozenset([
-    (namespaces["html"], "a"),
-    (namespaces["html"], "b"),
-    (namespaces["html"], "big"),
-    (namespaces["html"], "code"),
-    (namespaces["html"], "em"),
-    (namespaces["html"], "font"),
-    (namespaces["html"], "i"),
-    (namespaces["html"], "nobr"),
-    (namespaces["html"], "s"),
-    (namespaces["html"], "small"),
-    (namespaces["html"], "strike"),
-    (namespaces["html"], "strong"),
-    (namespaces["html"], "tt"),
-    (namespaces["html"], "u")
-])
-
-specialElements = frozenset([
-    (namespaces["html"], "address"),
-    (namespaces["html"], "applet"),
-    (namespaces["html"], "area"),
-    (namespaces["html"], "article"),
-    (namespaces["html"], "aside"),
-    (namespaces["html"], "base"),
-    (namespaces["html"], "basefont"),
-    (namespaces["html"], "bgsound"),
-    (namespaces["html"], "blockquote"),
-    (namespaces["html"], "body"),
-    (namespaces["html"], "br"),
-    (namespaces["html"], "button"),
-    (namespaces["html"], "caption"),
-    (namespaces["html"], "center"),
-    (namespaces["html"], "col"),
-    (namespaces["html"], "colgroup"),
-    (namespaces["html"], "command"),
-    (namespaces["html"], "dd"),
-    (namespaces["html"], "details"),
-    (namespaces["html"], "dir"),
-    (namespaces["html"], "div"),
-    (namespaces["html"], "dl"),
-    (namespaces["html"], "dt"),
-    (namespaces["html"], "embed"),
-    (namespaces["html"], "fieldset"),
-    (namespaces["html"], "figure"),
-    (namespaces["html"], "footer"),
-    (namespaces["html"], "form"),
-    (namespaces["html"], "frame"),
-    (namespaces["html"], "frameset"),
-    (namespaces["html"], "h1"),
-    (namespaces["html"], "h2"),
-    (namespaces["html"], "h3"),
-    (namespaces["html"], "h4"),
-    (namespaces["html"], "h5"),
-    (namespaces["html"], "h6"),
-    (namespaces["html"], "head"),
-    (namespaces["html"], "header"),
-    (namespaces["html"], "hr"),
-    (namespaces["html"], "html"),
-    (namespaces["html"], "iframe"),
-    # Note that image is commented out in the spec as "this isn't an
-    # element that can end up on the stack, so it doesn't matter,"
-    (namespaces["html"], "image"),
-    (namespaces["html"], "img"),
-    (namespaces["html"], "input"),
-    (namespaces["html"], "isindex"),
-    (namespaces["html"], "li"),
-    (namespaces["html"], "link"),
-    (namespaces["html"], "listing"),
-    (namespaces["html"], "marquee"),
-    (namespaces["html"], "menu"),
-    (namespaces["html"], "meta"),
-    (namespaces["html"], "nav"),
-    (namespaces["html"], "noembed"),
-    (namespaces["html"], "noframes"),
-    (namespaces["html"], "noscript"),
-    (namespaces["html"], "object"),
-    (namespaces["html"], "ol"),
-    (namespaces["html"], "p"),
-    (namespaces["html"], "param"),
-    (namespaces["html"], "plaintext"),
-    (namespaces["html"], "pre"),
-    (namespaces["html"], "script"),
-    (namespaces["html"], "section"),
-    (namespaces["html"], "select"),
-    (namespaces["html"], "style"),
-    (namespaces["html"], "table"),
-    (namespaces["html"], "tbody"),
-    (namespaces["html"], "td"),
-    (namespaces["html"], "textarea"),
-    (namespaces["html"], "tfoot"),
-    (namespaces["html"], "th"),
-    (namespaces["html"], "thead"),
-    (namespaces["html"], "title"),
-    (namespaces["html"], "tr"),
-    (namespaces["html"], "ul"),
-    (namespaces["html"], "wbr"),
-    (namespaces["html"], "xmp"),
-    (namespaces["svg"], "foreignObject")
-])
-
-htmlIntegrationPointElements = frozenset([
-    (namespaces["mathml"], "annotation-xml"),
-    (namespaces["svg"], "foreignObject"),
-    (namespaces["svg"], "desc"),
-    (namespaces["svg"], "title")
-])
-
-mathmlTextIntegrationPointElements = frozenset([
-    (namespaces["mathml"], "mi"),
-    (namespaces["mathml"], "mo"),
-    (namespaces["mathml"], "mn"),
-    (namespaces["mathml"], "ms"),
-    (namespaces["mathml"], "mtext")
-])
-
-adjustSVGAttributes = {
-    "attributename": "attributeName",
-    "attributetype": "attributeType",
-    "basefrequency": "baseFrequency",
-    "baseprofile": "baseProfile",
-    "calcmode": "calcMode",
-    "clippathunits": "clipPathUnits",
-    "contentscripttype": "contentScriptType",
-    "contentstyletype": "contentStyleType",
-    "diffuseconstant": "diffuseConstant",
-    "edgemode": "edgeMode",
-    "externalresourcesrequired": "externalResourcesRequired",
-    "filterres": "filterRes",
-    "filterunits": "filterUnits",
-    "glyphref": "glyphRef",
-    "gradienttransform": "gradientTransform",
-    "gradientunits": "gradientUnits",
-    "kernelmatrix": "kernelMatrix",
-    "kernelunitlength": "kernelUnitLength",
-    "keypoints": "keyPoints",
-    "keysplines": "keySplines",
-    "keytimes": "keyTimes",
-    "lengthadjust": "lengthAdjust",
-    "limitingconeangle": "limitingConeAngle",
-    "markerheight": "markerHeight",
-    "markerunits": "markerUnits",
-    "markerwidth": "markerWidth",
-    "maskcontentunits": "maskContentUnits",
-    "maskunits": "maskUnits",
-    "numoctaves": "numOctaves",
-    "pathlength": "pathLength",
-    "patterncontentunits": "patternContentUnits",
-    "patterntransform": "patternTransform",
-    "patternunits": "patternUnits",
-    "pointsatx": "pointsAtX",
-    "pointsaty": "pointsAtY",
-    "pointsatz": "pointsAtZ",
-    "preservealpha": "preserveAlpha",
-    "preserveaspectratio": "preserveAspectRatio",
-    "primitiveunits": "primitiveUnits",
-    "refx": "refX",
-    "refy": "refY",
-    "repeatcount": "repeatCount",
-    "repeatdur": "repeatDur",
-    "requiredextensions": "requiredExtensions",
-    "requiredfeatures": "requiredFeatures",
-    "specularconstant": "specularConstant",
-    "specularexponent": "specularExponent",
-    "spreadmethod": "spreadMethod",
-    "startoffset": "startOffset",
-    "stddeviation": "stdDeviation",
-    "stitchtiles": "stitchTiles",
-    "surfacescale": "surfaceScale",
-    "systemlanguage": "systemLanguage",
-    "tablevalues": "tableValues",
-    "targetx": "targetX",
-    "targety": "targetY",
-    "textlength": "textLength",
-    "viewbox": "viewBox",
-    "viewtarget": "viewTarget",
-    "xchannelselector": "xChannelSelector",
-    "ychannelselector": "yChannelSelector",
-    "zoomandpan": "zoomAndPan"
-}
-
-adjustMathMLAttributes = {"definitionurl": "definitionURL"}
-
-adjustForeignAttributes = {
-    "xlink:actuate": ("xlink", "actuate", namespaces["xlink"]),
-    "xlink:arcrole": ("xlink", "arcrole", namespaces["xlink"]),
-    "xlink:href": ("xlink", "href", namespaces["xlink"]),
-    "xlink:role": ("xlink", "role", namespaces["xlink"]),
-    "xlink:show": ("xlink", "show", namespaces["xlink"]),
-    "xlink:title": ("xlink", "title", namespaces["xlink"]),
-    "xlink:type": ("xlink", "type", namespaces["xlink"]),
-    "xml:base": ("xml", "base", namespaces["xml"]),
-    "xml:lang": ("xml", "lang", namespaces["xml"]),
-    "xml:space": ("xml", "space", namespaces["xml"]),
-    "xmlns": (None, "xmlns", namespaces["xmlns"]),
-    "xmlns:xlink": ("xmlns", "xlink", namespaces["xmlns"])
-}
-
-unadjustForeignAttributes = {(ns, local): qname for qname, (prefix, local, ns) in
-                             adjustForeignAttributes.items()}
-
-spaceCharacters = frozenset([
-    "\t",
-    "\n",
-    "\u000C",
-    " ",
-    "\r"
-])
-
-tableInsertModeElements = frozenset([
-    "table",
-    "tbody",
-    "tfoot",
-    "thead",
-    "tr"
-])
-
-asciiLowercase = frozenset(string.ascii_lowercase)
-asciiUppercase = frozenset(string.ascii_uppercase)
-asciiLetters = frozenset(string.ascii_letters)
-digits = frozenset(string.digits)
-hexDigits = frozenset(string.hexdigits)
-
-asciiUpper2Lower = {ord(c): ord(c.lower()) for c in string.ascii_uppercase}
-
-# Heading elements need to be ordered
-headingElements = (
-    "h1",
-    "h2",
-    "h3",
-    "h4",
-    "h5",
-    "h6"
-)
-
-voidElements = frozenset([
-    "base",
-    "command",
-    "event-source",
-    "link",
-    "meta",
-    "hr",
-    "br",
-    "img",
-    "embed",
-    "param",
-    "area",
-    "col",
-    "input",
-    "source",
-    "track"
-])
-
-cdataElements = frozenset(['title', 'textarea'])
-
-rcdataElements = frozenset([
-    'style',
-    'script',
-    'xmp',
-    'iframe',
-    'noembed',
-    'noframes',
-    'noscript'
-])
-
-booleanAttributes = {
-    "": frozenset(["irrelevant", "itemscope"]),
-    "style": frozenset(["scoped"]),
-    "img": frozenset(["ismap"]),
-    "audio": frozenset(["autoplay", "controls"]),
-    "video": frozenset(["autoplay", "controls"]),
-    "script": frozenset(["defer", "async"]),
-    "details": frozenset(["open"]),
-    "datagrid": frozenset(["multiple", "disabled"]),
-    "command": frozenset(["hidden", "disabled", "checked", "default"]),
-    "hr": frozenset(["noshade"]),
-    "menu": frozenset(["autosubmit"]),
-    "fieldset": frozenset(["disabled", "readonly"]),
-    "option": frozenset(["disabled", "readonly", "selected"]),
-    "optgroup": frozenset(["disabled", "readonly"]),
-    "button": frozenset(["disabled", "autofocus"]),
-    "input": frozenset(["disabled", "readonly", "required", "autofocus", "checked", "ismap"]),
-    "select": frozenset(["disabled", "readonly", "autofocus", "multiple"]),
-    "output": frozenset(["disabled", "readonly"]),
-    "iframe": frozenset(["seamless"]),
-}
-
-# entitiesWindows1252 has to be _ordered_ and needs to have an index. It
-# therefore can't be a frozenset.
-entitiesWindows1252 = (
-    8364,   # 0x80  0x20AC  EURO SIGN
-    65533,  # 0x81          UNDEFINED
-    8218,   # 0x82  0x201A  SINGLE LOW-9 QUOTATION MARK
-    402,    # 0x83  0x0192  LATIN SMALL LETTER F WITH HOOK
-    8222,   # 0x84  0x201E  DOUBLE LOW-9 QUOTATION MARK
-    8230,   # 0x85  0x2026  HORIZONTAL ELLIPSIS
-    8224,   # 0x86  0x2020  DAGGER
-    8225,   # 0x87  0x2021  DOUBLE DAGGER
-    710,    # 0x88  0x02C6  MODIFIER LETTER CIRCUMFLEX ACCENT
-    8240,   # 0x89  0x2030  PER MILLE SIGN
-    352,    # 0x8A  0x0160  LATIN CAPITAL LETTER S WITH CARON
-    8249,   # 0x8B  0x2039  SINGLE LEFT-POINTING ANGLE QUOTATION MARK
-    338,    # 0x8C  0x0152  LATIN CAPITAL LIGATURE OE
-    65533,  # 0x8D          UNDEFINED
-    381,    # 0x8E  0x017D  LATIN CAPITAL LETTER Z WITH CARON
-    65533,  # 0x8F          UNDEFINED
-    65533,  # 0x90          UNDEFINED
-    8216,   # 0x91  0x2018  LEFT SINGLE QUOTATION MARK
-    8217,   # 0x92  0x2019  RIGHT SINGLE QUOTATION MARK
-    8220,   # 0x93  0x201C  LEFT DOUBLE QUOTATION MARK
-    8221,   # 0x94  0x201D  RIGHT DOUBLE QUOTATION MARK
-    8226,   # 0x95  0x2022  BULLET
-    8211,   # 0x96  0x2013  EN DASH
-    8212,   # 0x97  0x2014  EM DASH
-    732,    # 0x98  0x02DC  SMALL TILDE
-    8482,   # 0x99  0x2122  TRADE MARK SIGN
-    353,    # 0x9A  0x0161  LATIN SMALL LETTER S WITH CARON
-    8250,   # 0x9B  0x203A  SINGLE RIGHT-POINTING ANGLE QUOTATION MARK
-    339,    # 0x9C  0x0153  LATIN SMALL LIGATURE OE
-    65533,  # 0x9D          UNDEFINED
-    382,    # 0x9E  0x017E  LATIN SMALL LETTER Z WITH CARON
-    376     # 0x9F  0x0178  LATIN CAPITAL LETTER Y WITH DIAERESIS
-)
-
-xmlEntities = frozenset(['lt;', 'gt;', 'amp;', 'apos;', 'quot;'])
-
-entities = {
-    "AElig": "\xc6",
-    "AElig;": "\xc6",
-    "AMP": "&",
-    "AMP;": "&",
-    "Aacute": "\xc1",
-    "Aacute;": "\xc1",
-    "Abreve;": "\u0102",
-    "Acirc": "\xc2",
-    "Acirc;": "\xc2",
-    "Acy;": "\u0410",
-    "Afr;": "\U0001d504",
-    "Agrave": "\xc0",
-    "Agrave;": "\xc0",
-    "Alpha;": "\u0391",
-    "Amacr;": "\u0100",
-    "And;": "\u2a53",
-    "Aogon;": "\u0104",
-    "Aopf;": "\U0001d538",
-    "ApplyFunction;": "\u2061",
-    "Aring": "\xc5",
-    "Aring;": "\xc5",
-    "Ascr;": "\U0001d49c",
-    "Assign;": "\u2254",
-    "Atilde": "\xc3",
-    "Atilde;": "\xc3",
-    "Auml": "\xc4",
-    "Auml;": "\xc4",
-    "Backslash;": "\u2216",
-    "Barv;": "\u2ae7",
-    "Barwed;": "\u2306",
-    "Bcy;": "\u0411",
-    "Because;": "\u2235",
-    "Bernoullis;": "\u212c",
-    "Beta;": "\u0392",
-    "Bfr;": "\U0001d505",
-    "Bopf;": "\U0001d539",
-    "Breve;": "\u02d8",
-    "Bscr;": "\u212c",
-    "Bumpeq;": "\u224e",
-    "CHcy;": "\u0427",
-    "COPY": "\xa9",
-    "COPY;": "\xa9",
-    "Cacute;": "\u0106",
-    "Cap;": "\u22d2",
-    "CapitalDifferentialD;": "\u2145",
-    "Cayleys;": "\u212d",
-    "Ccaron;": "\u010c",
-    "Ccedil": "\xc7",
-    "Ccedil;": "\xc7",
-    "Ccirc;": "\u0108",
-    "Cconint;": "\u2230",
-    "Cdot;": "\u010a",
-    "Cedilla;": "\xb8",
-    "CenterDot;": "\xb7",
-    "Cfr;": "\u212d",
-    "Chi;": "\u03a7",
-    "CircleDot;": "\u2299",
-    "CircleMinus;": "\u2296",
-    "CirclePlus;": "\u2295",
-    "CircleTimes;": "\u2297",
-    "ClockwiseContourIntegral;": "\u2232",
-    "CloseCurlyDoubleQuote;": "\u201d",
-    "CloseCurlyQuote;": "\u2019",
-    "Colon;": "\u2237",
-    "Colone;": "\u2a74",
-    "Congruent;": "\u2261",
-    "Conint;": "\u222f",
-    "ContourIntegral;": "\u222e",
-    "Copf;": "\u2102",
-    "Coproduct;": "\u2210",
-    "CounterClockwiseContourIntegral;": "\u2233",
-    "Cross;": "\u2a2f",
-    "Cscr;": "\U0001d49e",
-    "Cup;": "\u22d3",
-    "CupCap;": "\u224d",
-    "DD;": "\u2145",
-    "DDotrahd;": "\u2911",
-    "DJcy;": "\u0402",
-    "DScy;": "\u0405",
-    "DZcy;": "\u040f",
-    "Dagger;": "\u2021",
-    "Darr;": "\u21a1",
-    "Dashv;": "\u2ae4",
-    "Dcaron;": "\u010e",
-    "Dcy;": "\u0414",
-    "Del;": "\u2207",
-    "Delta;": "\u0394",
-    "Dfr;": "\U0001d507",
-    "DiacriticalAcute;": "\xb4",
-    "DiacriticalDot;": "\u02d9",
-    "DiacriticalDoubleAcute;": "\u02dd",
-    "DiacriticalGrave;": "`",
-    "DiacriticalTilde;": "\u02dc",
-    "Diamond;": "\u22c4",
-    "DifferentialD;": "\u2146",
-    "Dopf;": "\U0001d53b",
-    "Dot;": "\xa8",
-    "DotDot;": "\u20dc",
-    "DotEqual;": "\u2250",
-    "DoubleContourIntegral;": "\u222f",
-    "DoubleDot;": "\xa8",
-    "DoubleDownArrow;": "\u21d3",
-    "DoubleLeftArrow;": "\u21d0",
-    "DoubleLeftRightArrow;": "\u21d4",
-    "DoubleLeftTee;": "\u2ae4",
-    "DoubleLongLeftArrow;": "\u27f8",
-    "DoubleLongLeftRightArrow;": "\u27fa",
-    "DoubleLongRightArrow;": "\u27f9",
-    "DoubleRightArrow;": "\u21d2",
-    "DoubleRightTee;": "\u22a8",
-    "DoubleUpArrow;": "\u21d1",
-    "DoubleUpDownArrow;": "\u21d5",
-    "DoubleVerticalBar;": "\u2225",
-    "DownArrow;": "\u2193",
-    "DownArrowBar;": "\u2913",
-    "DownArrowUpArrow;": "\u21f5",
-    "DownBreve;": "\u0311",
-    "DownLeftRightVector;": "\u2950",
-    "DownLeftTeeVector;": "\u295e",
-    "DownLeftVector;": "\u21bd",
-    "DownLeftVectorBar;": "\u2956",
-    "DownRightTeeVector;": "\u295f",
-    "DownRightVector;": "\u21c1",
-    "DownRightVectorBar;": "\u2957",
-    "DownTee;": "\u22a4",
-    "DownTeeArrow;": "\u21a7",
-    "Downarrow;": "\u21d3",
-    "Dscr;": "\U0001d49f",
-    "Dstrok;": "\u0110",
-    "ENG;": "\u014a",
-    "ETH": "\xd0",
-    "ETH;": "\xd0",
-    "Eacute": "\xc9",
-    "Eacute;": "\xc9",
-    "Ecaron;": "\u011a",
-    "Ecirc": "\xca",
-    "Ecirc;": "\xca",
-    "Ecy;": "\u042d",
-    "Edot;": "\u0116",
-    "Efr;": "\U0001d508",
-    "Egrave": "\xc8",
-    "Egrave;": "\xc8",
-    "Element;": "\u2208",
-    "Emacr;": "\u0112",
-    "EmptySmallSquare;": "\u25fb",
-    "EmptyVerySmallSquare;": "\u25ab",
-    "Eogon;": "\u0118",
-    "Eopf;": "\U0001d53c",
-    "Epsilon;": "\u0395",
-    "Equal;": "\u2a75",
-    "EqualTilde;": "\u2242",
-    "Equilibrium;": "\u21cc",
-    "Escr;": "\u2130",
-    "Esim;": "\u2a73",
-    "Eta;": "\u0397",
-    "Euml": "\xcb",
-    "Euml;": "\xcb",
-    "Exists;": "\u2203",
-    "ExponentialE;": "\u2147",
-    "Fcy;": "\u0424",
-    "Ffr;": "\U0001d509",
-    "FilledSmallSquare;": "\u25fc",
-    "FilledVerySmallSquare;": "\u25aa",
-    "Fopf;": "\U0001d53d",
-    "ForAll;": "\u2200",
-    "Fouriertrf;": "\u2131",
-    "Fscr;": "\u2131",
-    "GJcy;": "\u0403",
-    "GT": ">",
-    "GT;": ">",
-    "Gamma;": "\u0393",
-    "Gammad;": "\u03dc",
-    "Gbreve;": "\u011e",
-    "Gcedil;": "\u0122",
-    "Gcirc;": "\u011c",
-    "Gcy;": "\u0413",
-    "Gdot;": "\u0120",
-    "Gfr;": "\U0001d50a",
-    "Gg;": "\u22d9",
-    "Gopf;": "\U0001d53e",
-    "GreaterEqual;": "\u2265",
-    "GreaterEqualLess;": "\u22db",
-    "GreaterFullEqual;": "\u2267",
-    "GreaterGreater;": "\u2aa2",
-    "GreaterLess;": "\u2277",
-    "GreaterSlantEqual;": "\u2a7e",
-    "GreaterTilde;": "\u2273",
-    "Gscr;": "\U0001d4a2",
-    "Gt;": "\u226b",
-    "HARDcy;": "\u042a",
-    "Hacek;": "\u02c7",
-    "Hat;": "^",
-    "Hcirc;": "\u0124",
-    "Hfr;": "\u210c",
-    "HilbertSpace;": "\u210b",
-    "Hopf;": "\u210d",
-    "HorizontalLine;": "\u2500",
-    "Hscr;": "\u210b",
-    "Hstrok;": "\u0126",
-    "HumpDownHump;": "\u224e",
-    "HumpEqual;": "\u224f",
-    "IEcy;": "\u0415",
-    "IJlig;": "\u0132",
-    "IOcy;": "\u0401",
-    "Iacute": "\xcd",
-    "Iacute;": "\xcd",
-    "Icirc": "\xce",
-    "Icirc;": "\xce",
-    "Icy;": "\u0418",
-    "Idot;": "\u0130",
-    "Ifr;": "\u2111",
-    "Igrave": "\xcc",
-    "Igrave;": "\xcc",
-    "Im;": "\u2111",
-    "Imacr;": "\u012a",
-    "ImaginaryI;": "\u2148",
-    "Implies;": "\u21d2",
-    "Int;": "\u222c",
-    "Integral;": "\u222b",
-    "Intersection;": "\u22c2",
-    "InvisibleComma;": "\u2063",
-    "InvisibleTimes;": "\u2062",
-    "Iogon;": "\u012e",
-    "Iopf;": "\U0001d540",
-    "Iota;": "\u0399",
-    "Iscr;": "\u2110",
-    "Itilde;": "\u0128",
-    "Iukcy;": "\u0406",
-    "Iuml": "\xcf",
-    "Iuml;": "\xcf",
-    "Jcirc;": "\u0134",
-    "Jcy;": "\u0419",
-    "Jfr;": "\U0001d50d",
-    "Jopf;": "\U0001d541",
-    "Jscr;": "\U0001d4a5",
-    "Jsercy;": "\u0408",
-    "Jukcy;": "\u0404",
-    "KHcy;": "\u0425",
-    "KJcy;": "\u040c",
-    "Kappa;": "\u039a",
-    "Kcedil;": "\u0136",
-    "Kcy;": "\u041a",
-    "Kfr;": "\U0001d50e",
-    "Kopf;": "\U0001d542",
-    "Kscr;": "\U0001d4a6",
-    "LJcy;": "\u0409",
-    "LT": "<",
-    "LT;": "<",
-    "Lacute;": "\u0139",
-    "Lambda;": "\u039b",
-    "Lang;": "\u27ea",
-    "Laplacetrf;": "\u2112",
-    "Larr;": "\u219e",
-    "Lcaron;": "\u013d",
-    "Lcedil;": "\u013b",
-    "Lcy;": "\u041b",
-    "LeftAngleBracket;": "\u27e8",
-    "LeftArrow;": "\u2190",
-    "LeftArrowBar;": "\u21e4",
-    "LeftArrowRightArrow;": "\u21c6",
-    "LeftCeiling;": "\u2308",
-    "LeftDoubleBracket;": "\u27e6",
-    "LeftDownTeeVector;": "\u2961",
-    "LeftDownVector;": "\u21c3",
-    "LeftDownVectorBar;": "\u2959",
-    "LeftFloor;": "\u230a",
-    "LeftRightArrow;": "\u2194",
-    "LeftRightVector;": "\u294e",
-    "LeftTee;": "\u22a3",
-    "LeftTeeArrow;": "\u21a4",
-    "LeftTeeVector;": "\u295a",
-    "LeftTriangle;": "\u22b2",
-    "LeftTriangleBar;": "\u29cf",
-    "LeftTriangleEqual;": "\u22b4",
-    "LeftUpDownVector;": "\u2951",
-    "LeftUpTeeVector;": "\u2960",
-    "LeftUpVector;": "\u21bf",
-    "LeftUpVectorBar;": "\u2958",
-    "LeftVector;": "\u21bc",
-    "LeftVectorBar;": "\u2952",
-    "Leftarrow;": "\u21d0",
-    "Leftrightarrow;": "\u21d4",
-    "LessEqualGreater;": "\u22da",
-    "LessFullEqual;": "\u2266",
-    "LessGreater;": "\u2276",
-    "LessLess;": "\u2aa1",
-    "LessSlantEqual;": "\u2a7d",
-    "LessTilde;": "\u2272",
-    "Lfr;": "\U0001d50f",
-    "Ll;": "\u22d8",
-    "Lleftarrow;": "\u21da",
-    "Lmidot;": "\u013f",
-    "LongLeftArrow;": "\u27f5",
-    "LongLeftRightArrow;": "\u27f7",
-    "LongRightArrow;": "\u27f6",
-    "Longleftarrow;": "\u27f8",
-    "Longleftrightarrow;": "\u27fa",
-    "Longrightarrow;": "\u27f9",
-    "Lopf;": "\U0001d543",
-    "LowerLeftArrow;": "\u2199",
-    "LowerRightArrow;": "\u2198",
-    "Lscr;": "\u2112",
-    "Lsh;": "\u21b0",
-    "Lstrok;": "\u0141",
-    "Lt;": "\u226a",
-    "Map;": "\u2905",
-    "Mcy;": "\u041c",
-    "MediumSpace;": "\u205f",
-    "Mellintrf;": "\u2133",
-    "Mfr;": "\U0001d510",
-    "MinusPlus;": "\u2213",
-    "Mopf;": "\U0001d544",
-    "Mscr;": "\u2133",
-    "Mu;": "\u039c",
-    "NJcy;": "\u040a",
-    "Nacute;": "\u0143",
-    "Ncaron;": "\u0147",
-    "Ncedil;": "\u0145",
-    "Ncy;": "\u041d",
-    "NegativeMediumSpace;": "\u200b",
-    "NegativeThickSpace;": "\u200b",
-    "NegativeThinSpace;": "\u200b",
-    "NegativeVeryThinSpace;": "\u200b",
-    "NestedGreaterGreater;": "\u226b",
-    "NestedLessLess;": "\u226a",
-    "NewLine;": "\n",
-    "Nfr;": "\U0001d511",
-    "NoBreak;": "\u2060",
-    "NonBreakingSpace;": "\xa0",
-    "Nopf;": "\u2115",
-    "Not;": "\u2aec",
-    "NotCongruent;": "\u2262",
-    "NotCupCap;": "\u226d",
-    "NotDoubleVerticalBar;": "\u2226",
-    "NotElement;": "\u2209",
-    "NotEqual;": "\u2260",
-    "NotEqualTilde;": "\u2242\u0338",
-    "NotExists;": "\u2204",
-    "NotGreater;": "\u226f",
-    "NotGreaterEqual;": "\u2271",
-    "NotGreaterFullEqual;": "\u2267\u0338",
-    "NotGreaterGreater;": "\u226b\u0338",
-    "NotGreaterLess;": "\u2279",
-    "NotGreaterSlantEqual;": "\u2a7e\u0338",
-    "NotGreaterTilde;": "\u2275",
-    "NotHumpDownHump;": "\u224e\u0338",
-    "NotHumpEqual;": "\u224f\u0338",
-    "NotLeftTriangle;": "\u22ea",
-    "NotLeftTriangleBar;": "\u29cf\u0338",
-    "NotLeftTriangleEqual;": "\u22ec",
-    "NotLess;": "\u226e",
-    "NotLessEqual;": "\u2270",
-    "NotLessGreater;": "\u2278",
-    "NotLessLess;": "\u226a\u0338",
-    "NotLessSlantEqual;": "\u2a7d\u0338",
-    "NotLessTilde;": "\u2274",
-    "NotNestedGreaterGreater;": "\u2aa2\u0338",
-    "NotNestedLessLess;": "\u2aa1\u0338",
-    "NotPrecedes;": "\u2280",
-    "NotPrecedesEqual;": "\u2aaf\u0338",
-    "NotPrecedesSlantEqual;": "\u22e0",
-    "NotReverseElement;": "\u220c",
-    "NotRightTriangle;": "\u22eb",
-    "NotRightTriangleBar;": "\u29d0\u0338",
-    "NotRightTriangleEqual;": "\u22ed",
-    "NotSquareSubset;": "\u228f\u0338",
-    "NotSquareSubsetEqual;": "\u22e2",
-    "NotSquareSuperset;": "\u2290\u0338",
-    "NotSquareSupersetEqual;": "\u22e3",
-    "NotSubset;": "\u2282\u20d2",
-    "NotSubsetEqual;": "\u2288",
-    "NotSucceeds;": "\u2281",
-    "NotSucceedsEqual;": "\u2ab0\u0338",
-    "NotSucceedsSlantEqual;": "\u22e1",
-    "NotSucceedsTilde;": "\u227f\u0338",
-    "NotSuperset;": "\u2283\u20d2",
-    "NotSupersetEqual;": "\u2289",
-    "NotTilde;": "\u2241",
-    "NotTildeEqual;": "\u2244",
-    "NotTildeFullEqual;": "\u2247",
-    "NotTildeTilde;": "\u2249",
-    "NotVerticalBar;": "\u2224",
-    "Nscr;": "\U0001d4a9",
-    "Ntilde": "\xd1",
-    "Ntilde;": "\xd1",
-    "Nu;": "\u039d",
-    "OElig;": "\u0152",
-    "Oacute": "\xd3",
-    "Oacute;": "\xd3",
-    "Ocirc": "\xd4",
-    "Ocirc;": "\xd4",
-    "Ocy;": "\u041e",
-    "Odblac;": "\u0150",
-    "Ofr;": "\U0001d512",
-    "Ograve": "\xd2",
-    "Ograve;": "\xd2",
-    "Omacr;": "\u014c",
-    "Omega;": "\u03a9",
-    "Omicron;": "\u039f",
-    "Oopf;": "\U0001d546",
-    "OpenCurlyDoubleQuote;": "\u201c",
-    "OpenCurlyQuote;": "\u2018",
-    "Or;": "\u2a54",
-    "Oscr;": "\U0001d4aa",
-    "Oslash": "\xd8",
-    "Oslash;": "\xd8",
-    "Otilde": "\xd5",
-    "Otilde;": "\xd5",
-    "Otimes;": "\u2a37",
-    "Ouml": "\xd6",
-    "Ouml;": "\xd6",
-    "OverBar;": "\u203e",
-    "OverBrace;": "\u23de",
-    "OverBracket;": "\u23b4",
-    "OverParenthesis;": "\u23dc",
-    "PartialD;": "\u2202",
-    "Pcy;": "\u041f",
-    "Pfr;": "\U0001d513",
-    "Phi;": "\u03a6",
-    "Pi;": "\u03a0",
-    "PlusMinus;": "\xb1",
-    "Poincareplane;": "\u210c",
-    "Popf;": "\u2119",
-    "Pr;": "\u2abb",
-    "Precedes;": "\u227a",
-    "PrecedesEqual;": "\u2aaf",
-    "PrecedesSlantEqual;": "\u227c",
-    "PrecedesTilde;": "\u227e",
-    "Prime;": "\u2033",
-    "Product;": "\u220f",
-    "Proportion;": "\u2237",
-    "Proportional;": "\u221d",
-    "Pscr;": "\U0001d4ab",
-    "Psi;": "\u03a8",
-    "QUOT": "\"",
-    "QUOT;": "\"",
-    "Qfr;": "\U0001d514",
-    "Qopf;": "\u211a",
-    "Qscr;": "\U0001d4ac",
-    "RBarr;": "\u2910",
-    "REG": "\xae",
-    "REG;": "\xae",
-    "Racute;": "\u0154",
-    "Rang;": "\u27eb",
-    "Rarr;": "\u21a0",
-    "Rarrtl;": "\u2916",
-    "Rcaron;": "\u0158",
-    "Rcedil;": "\u0156",
-    "Rcy;": "\u0420",
-    "Re;": "\u211c",
-    "ReverseElement;": "\u220b",
-    "ReverseEquilibrium;": "\u21cb",
-    "ReverseUpEquilibrium;": "\u296f",
-    "Rfr;": "\u211c",
-    "Rho;": "\u03a1",
-    "RightAngleBracket;": "\u27e9",
-    "RightArrow;": "\u2192",
-    "RightArrowBar;": "\u21e5",
-    "RightArrowLeftArrow;": "\u21c4",
-    "RightCeiling;": "\u2309",
-    "RightDoubleBracket;": "\u27e7",
-    "RightDownTeeVector;": "\u295d",
-    "RightDownVector;": "\u21c2",
-    "RightDownVectorBar;": "\u2955",
-    "RightFloor;": "\u230b",
-    "RightTee;": "\u22a2",
-    "RightTeeArrow;": "\u21a6",
-    "RightTeeVector;": "\u295b",
-    "RightTriangle;": "\u22b3",
-    "RightTriangleBar;": "\u29d0",
-    "RightTriangleEqual;": "\u22b5",
-    "RightUpDownVector;": "\u294f",
-    "RightUpTeeVector;": "\u295c",
-    "RightUpVector;": "\u21be",
-    "RightUpVectorBar;": "\u2954",
-    "RightVector;": "\u21c0",
-    "RightVectorBar;": "\u2953",
-    "Rightarrow;": "\u21d2",
-    "Ropf;": "\u211d",
-    "RoundImplies;": "\u2970",
-    "Rrightarrow;": "\u21db",
-    "Rscr;": "\u211b",
-    "Rsh;": "\u21b1",
-    "RuleDelayed;": "\u29f4",
-    "SHCHcy;": "\u0429",
-    "SHcy;": "\u0428",
-    "SOFTcy;": "\u042c",
-    "Sacute;": "\u015a",
-    "Sc;": "\u2abc",
-    "Scaron;": "\u0160",
-    "Scedil;": "\u015e",
-    "Scirc;": "\u015c",
-    "Scy;": "\u0421",
-    "Sfr;": "\U0001d516",
-    "ShortDownArrow;": "\u2193",
-    "ShortLeftArrow;": "\u2190",
-    "ShortRightArrow;": "\u2192",
-    "ShortUpArrow;": "\u2191",
-    "Sigma;": "\u03a3",
-    "SmallCircle;": "\u2218",
-    "Sopf;": "\U0001d54a",
-    "Sqrt;": "\u221a",
-    "Square;": "\u25a1",
-    "SquareIntersection;": "\u2293",
-    "SquareSubset;": "\u228f",
-    "SquareSubsetEqual;": "\u2291",
-    "SquareSuperset;": "\u2290",
-    "SquareSupersetEqual;": "\u2292",
-    "SquareUnion;": "\u2294",
-    "Sscr;": "\U0001d4ae",
-    "Star;": "\u22c6",
-    "Sub;": "\u22d0",
-    "Subset;": "\u22d0",
-    "SubsetEqual;": "\u2286",
-    "Succeeds;": "\u227b",
-    "SucceedsEqual;": "\u2ab0",
-    "SucceedsSlantEqual;": "\u227d",
-    "SucceedsTilde;": "\u227f",
-    "SuchThat;": "\u220b",
-    "Sum;": "\u2211",
-    "Sup;": "\u22d1",
-    "Superset;": "\u2283",
-    "SupersetEqual;": "\u2287",
-    "Supset;": "\u22d1",
-    "THORN": "\xde",
-    "THORN;": "\xde",
-    "TRADE;": "\u2122",
-    "TSHcy;": "\u040b",
-    "TScy;": "\u0426",
-    "Tab;": "\t",
-    "Tau;": "\u03a4",
-    "Tcaron;": "\u0164",
-    "Tcedil;": "\u0162",
-    "Tcy;": "\u0422",
-    "Tfr;": "\U0001d517",
-    "Therefore;": "\u2234",
-    "Theta;": "\u0398",
-    "ThickSpace;": "\u205f\u200a",
-    "ThinSpace;": "\u2009",
-    "Tilde;": "\u223c",
-    "TildeEqual;": "\u2243",
-    "TildeFullEqual;": "\u2245",
-    "TildeTilde;": "\u2248",
-    "Topf;": "\U0001d54b",
-    "TripleDot;": "\u20db",
-    "Tscr;": "\U0001d4af",
-    "Tstrok;": "\u0166",
-    "Uacute": "\xda",
-    "Uacute;": "\xda",
-    "Uarr;": "\u219f",
-    "Uarrocir;": "\u2949",
-    "Ubrcy;": "\u040e",
-    "Ubreve;": "\u016c",
-    "Ucirc": "\xdb",
-    "Ucirc;": "\xdb",
-    "Ucy;": "\u0423",
-    "Udblac;": "\u0170",
-    "Ufr;": "\U0001d518",
-    "Ugrave": "\xd9",
-    "Ugrave;": "\xd9",
-    "Umacr;": "\u016a",
-    "UnderBar;": "_",
-    "UnderBrace;": "\u23df",
-    "UnderBracket;": "\u23b5",
-    "UnderParenthesis;": "\u23dd",
-    "Union;": "\u22c3",
-    "UnionPlus;": "\u228e",
-    "Uogon;": "\u0172",
-    "Uopf;": "\U0001d54c",
-    "UpArrow;": "\u2191",
-    "UpArrowBar;": "\u2912",
-    "UpArrowDownArrow;": "\u21c5",
-    "UpDownArrow;": "\u2195",
-    "UpEquilibrium;": "\u296e",
-    "UpTee;": "\u22a5",
-    "UpTeeArrow;": "\u21a5",
-    "Uparrow;": "\u21d1",
-    "Updownarrow;": "\u21d5",
-    "UpperLeftArrow;": "\u2196",
-    "UpperRightArrow;": "\u2197",
-    "Upsi;": "\u03d2",
-    "Upsilon;": "\u03a5",
-    "Uring;": "\u016e",
-    "Uscr;": "\U0001d4b0",
-    "Utilde;": "\u0168",
-    "Uuml": "\xdc",
-    "Uuml;": "\xdc",
-    "VDash;": "\u22ab",
-    "Vbar;": "\u2aeb",
-    "Vcy;": "\u0412",
-    "Vdash;": "\u22a9",
-    "Vdashl;": "\u2ae6",
-    "Vee;": "\u22c1",
-    "Verbar;": "\u2016",
-    "Vert;": "\u2016",
-    "VerticalBar;": "\u2223",
-    "VerticalLine;": "|",
-    "VerticalSeparator;": "\u2758",
-    "VerticalTilde;": "\u2240",
-    "VeryThinSpace;": "\u200a",
-    "Vfr;": "\U0001d519",
-    "Vopf;": "\U0001d54d",
-    "Vscr;": "\U0001d4b1",
-    "Vvdash;": "\u22aa",
-    "Wcirc;": "\u0174",
-    "Wedge;": "\u22c0",
-    "Wfr;": "\U0001d51a",
-    "Wopf;": "\U0001d54e",
-    "Wscr;": "\U0001d4b2",
-    "Xfr;": "\U0001d51b",
-    "Xi;": "\u039e",
-    "Xopf;": "\U0001d54f",
-    "Xscr;": "\U0001d4b3",
-    "YAcy;": "\u042f",
-    "YIcy;": "\u0407",
-    "YUcy;": "\u042e",
-    "Yacute": "\xdd",
-    "Yacute;": "\xdd",
-    "Ycirc;": "\u0176",
-    "Ycy;": "\u042b",
-    "Yfr;": "\U0001d51c",
-    "Yopf;": "\U0001d550",
-    "Yscr;": "\U0001d4b4",
-    "Yuml;": "\u0178",
-    "ZHcy;": "\u0416",
-    "Zacute;": "\u0179",
-    "Zcaron;": "\u017d",
-    "Zcy;": "\u0417",
-    "Zdot;": "\u017b",
-    "ZeroWidthSpace;": "\u200b",
-    "Zeta;": "\u0396",
-    "Zfr;": "\u2128",
-    "Zopf;": "\u2124",
-    "Zscr;": "\U0001d4b5",
-    "aacute": "\xe1",
-    "aacute;": "\xe1",
-    "abreve;": "\u0103",
-    "ac;": "\u223e",
-    "acE;": "\u223e\u0333",
-    "acd;": "\u223f",
-    "acirc": "\xe2",
-    "acirc;": "\xe2",
-    "acute": "\xb4",
-    "acute;": "\xb4",
-    "acy;": "\u0430",
-    "aelig": "\xe6",
-    "aelig;": "\xe6",
-    "af;": "\u2061",
-    "afr;": "\U0001d51e",
-    "agrave": "\xe0",
-    "agrave;": "\xe0",
-    "alefsym;": "\u2135",
-    "aleph;": "\u2135",
-    "alpha;": "\u03b1",
-    "amacr;": "\u0101",
-    "amalg;": "\u2a3f",
-    "amp": "&",
-    "amp;": "&",
-    "and;": "\u2227",
-    "andand;": "\u2a55",
-    "andd;": "\u2a5c",
-    "andslope;": "\u2a58",
-    "andv;": "\u2a5a",
-    "ang;": "\u2220",
-    "ange;": "\u29a4",
-    "angle;": "\u2220",
-    "angmsd;": "\u2221",
-    "angmsdaa;": "\u29a8",
-    "angmsdab;": "\u29a9",
-    "angmsdac;": "\u29aa",
-    "angmsdad;": "\u29ab",
-    "angmsdae;": "\u29ac",
-    "angmsdaf;": "\u29ad",
-    "angmsdag;": "\u29ae",
-    "angmsdah;": "\u29af",
-    "angrt;": "\u221f",
-    "angrtvb;": "\u22be",
-    "angrtvbd;": "\u299d",
-    "angsph;": "\u2222",
-    "angst;": "\xc5",
-    "angzarr;": "\u237c",
-    "aogon;": "\u0105",
-    "aopf;": "\U0001d552",
-    "ap;": "\u2248",
-    "apE;": "\u2a70",
-    "apacir;": "\u2a6f",
-    "ape;": "\u224a",
-    "apid;": "\u224b",
-    "apos;": "'",
-    "approx;": "\u2248",
-    "approxeq;": "\u224a",
-    "aring": "\xe5",
-    "aring;": "\xe5",
-    "ascr;": "\U0001d4b6",
-    "ast;": "*",
-    "asymp;": "\u2248",
-    "asympeq;": "\u224d",
-    "atilde": "\xe3",
-    "atilde;": "\xe3",
-    "auml": "\xe4",
-    "auml;": "\xe4",
-    "awconint;": "\u2233",
-    "awint;": "\u2a11",
-    "bNot;": "\u2aed",
-    "backcong;": "\u224c",
-    "backepsilon;": "\u03f6",
-    "backprime;": "\u2035",
-    "backsim;": "\u223d",
-    "backsimeq;": "\u22cd",
-    "barvee;": "\u22bd",
-    "barwed;": "\u2305",
-    "barwedge;": "\u2305",
-    "bbrk;": "\u23b5",
-    "bbrktbrk;": "\u23b6",
-    "bcong;": "\u224c",
-    "bcy;": "\u0431",
-    "bdquo;": "\u201e",
-    "becaus;": "\u2235",
-    "because;": "\u2235",
-    "bemptyv;": "\u29b0",
-    "bepsi;": "\u03f6",
-    "bernou;": "\u212c",
-    "beta;": "\u03b2",
-    "beth;": "\u2136",
-    "between;": "\u226c",
-    "bfr;": "\U0001d51f",
-    "bigcap;": "\u22c2",
-    "bigcirc;": "\u25ef",
-    "bigcup;": "\u22c3",
-    "bigodot;": "\u2a00",
-    "bigoplus;": "\u2a01",
-    "bigotimes;": "\u2a02",
-    "bigsqcup;": "\u2a06",
-    "bigstar;": "\u2605",
-    "bigtriangledown;": "\u25bd",
-    "bigtriangleup;": "\u25b3",
-    "biguplus;": "\u2a04",
-    "bigvee;": "\u22c1",
-    "bigwedge;": "\u22c0",
-    "bkarow;": "\u290d",
-    "blacklozenge;": "\u29eb",
-    "blacksquare;": "\u25aa",
-    "blacktriangle;": "\u25b4",
-    "blacktriangledown;": "\u25be",
-    "blacktriangleleft;": "\u25c2",
-    "blacktriangleright;": "\u25b8",
-    "blank;": "\u2423",
-    "blk12;": "\u2592",
-    "blk14;": "\u2591",
-    "blk34;": "\u2593",
-    "block;": "\u2588",
-    "bne;": "=\u20e5",
-    "bnequiv;": "\u2261\u20e5",
-    "bnot;": "\u2310",
-    "bopf;": "\U0001d553",
-    "bot;": "\u22a5",
-    "bottom;": "\u22a5",
-    "bowtie;": "\u22c8",
-    "boxDL;": "\u2557",
-    "boxDR;": "\u2554",
-    "boxDl;": "\u2556",
-    "boxDr;": "\u2553",
-    "boxH;": "\u2550",
-    "boxHD;": "\u2566",
-    "boxHU;": "\u2569",
-    "boxHd;": "\u2564",
-    "boxHu;": "\u2567",
-    "boxUL;": "\u255d",
-    "boxUR;": "\u255a",
-    "boxUl;": "\u255c",
-    "boxUr;": "\u2559",
-    "boxV;": "\u2551",
-    "boxVH;": "\u256c",
-    "boxVL;": "\u2563",
-    "boxVR;": "\u2560",
-    "boxVh;": "\u256b",
-    "boxVl;": "\u2562",
-    "boxVr;": "\u255f",
-    "boxbox;": "\u29c9",
-    "boxdL;": "\u2555",
-    "boxdR;": "\u2552",
-    "boxdl;": "\u2510",
-    "boxdr;": "\u250c",
-    "boxh;": "\u2500",
-    "boxhD;": "\u2565",
-    "boxhU;": "\u2568",
-    "boxhd;": "\u252c",
-    "boxhu;": "\u2534",
-    "boxminus;": "\u229f",
-    "boxplus;": "\u229e",
-    "boxtimes;": "\u22a0",
-    "boxuL;": "\u255b",
-    "boxuR;": "\u2558",
-    "boxul;": "\u2518",
-    "boxur;": "\u2514",
-    "boxv;": "\u2502",
-    "boxvH;": "\u256a",
-    "boxvL;": "\u2561",
-    "boxvR;": "\u255e",
-    "boxvh;": "\u253c",
-    "boxvl;": "\u2524",
-    "boxvr;": "\u251c",
-    "bprime;": "\u2035",
-    "breve;": "\u02d8",
-    "brvbar": "\xa6",
-    "brvbar;": "\xa6",
-    "bscr;": "\U0001d4b7",
-    "bsemi;": "\u204f",
-    "bsim;": "\u223d",
-    "bsime;": "\u22cd",
-    "bsol;": "\\",
-    "bsolb;": "\u29c5",
-    "bsolhsub;": "\u27c8",
-    "bull;": "\u2022",
-    "bullet;": "\u2022",
-    "bump;": "\u224e",
-    "bumpE;": "\u2aae",
-    "bumpe;": "\u224f",
-    "bumpeq;": "\u224f",
-    "cacute;": "\u0107",
-    "cap;": "\u2229",
-    "capand;": "\u2a44",
-    "capbrcup;": "\u2a49",
-    "capcap;": "\u2a4b",
-    "capcup;": "\u2a47",
-    "capdot;": "\u2a40",
-    "caps;": "\u2229\ufe00",
-    "caret;": "\u2041",
-    "caron;": "\u02c7",
-    "ccaps;": "\u2a4d",
-    "ccaron;": "\u010d",
-    "ccedil": "\xe7",
-    "ccedil;": "\xe7",
-    "ccirc;": "\u0109",
-    "ccups;": "\u2a4c",
-    "ccupssm;": "\u2a50",
-    "cdot;": "\u010b",
-    "cedil": "\xb8",
-    "cedil;": "\xb8",
-    "cemptyv;": "\u29b2",
-    "cent": "\xa2",
-    "cent;": "\xa2",
-    "centerdot;": "\xb7",
-    "cfr;": "\U0001d520",
-    "chcy;": "\u0447",
-    "check;": "\u2713",
-    "checkmark;": "\u2713",
-    "chi;": "\u03c7",
-    "cir;": "\u25cb",
-    "cirE;": "\u29c3",
-    "circ;": "\u02c6",
-    "circeq;": "\u2257",
-    "circlearrowleft;": "\u21ba",
-    "circlearrowright;": "\u21bb",
-    "circledR;": "\xae",
-    "circledS;": "\u24c8",
-    "circledast;": "\u229b",
-    "circledcirc;": "\u229a",
-    "circleddash;": "\u229d",
-    "cire;": "\u2257",
-    "cirfnint;": "\u2a10",
-    "cirmid;": "\u2aef",
-    "cirscir;": "\u29c2",
-    "clubs;": "\u2663",
-    "clubsuit;": "\u2663",
-    "colon;": ":",
-    "colone;": "\u2254",
-    "coloneq;": "\u2254",
-    "comma;": ",",
-    "commat;": "@",
-    "comp;": "\u2201",
-    "compfn;": "\u2218",
-    "complement;": "\u2201",
-    "complexes;": "\u2102",
-    "cong;": "\u2245",
-    "congdot;": "\u2a6d",
-    "conint;": "\u222e",
-    "copf;": "\U0001d554",
-    "coprod;": "\u2210",
-    "copy": "\xa9",
-    "copy;": "\xa9",
-    "copysr;": "\u2117",
-    "crarr;": "\u21b5",
-    "cross;": "\u2717",
-    "cscr;": "\U0001d4b8",
-    "csub;": "\u2acf",
-    "csube;": "\u2ad1",
-    "csup;": "\u2ad0",
-    "csupe;": "\u2ad2",
-    "ctdot;": "\u22ef",
-    "cudarrl;": "\u2938",
-    "cudarrr;": "\u2935",
-    "cuepr;": "\u22de",
-    "cuesc;": "\u22df",
-    "cularr;": "\u21b6",
-    "cularrp;": "\u293d",
-    "cup;": "\u222a",
-    "cupbrcap;": "\u2a48",
-    "cupcap;": "\u2a46",
-    "cupcup;": "\u2a4a",
-    "cupdot;": "\u228d",
-    "cupor;": "\u2a45",
-    "cups;": "\u222a\ufe00",
-    "curarr;": "\u21b7",
-    "curarrm;": "\u293c",
-    "curlyeqprec;": "\u22de",
-    "curlyeqsucc;": "\u22df",
-    "curlyvee;": "\u22ce",
-    "curlywedge;": "\u22cf",
-    "curren": "\xa4",
-    "curren;": "\xa4",
-    "curvearrowleft;": "\u21b6",
-    "curvearrowright;": "\u21b7",
-    "cuvee;": "\u22ce",
-    "cuwed;": "\u22cf",
-    "cwconint;": "\u2232",
-    "cwint;": "\u2231",
-    "cylcty;": "\u232d",
-    "dArr;": "\u21d3",
-    "dHar;": "\u2965",
-    "dagger;": "\u2020",
-    "daleth;": "\u2138",
-    "darr;": "\u2193",
-    "dash;": "\u2010",
-    "dashv;": "\u22a3",
-    "dbkarow;": "\u290f",
-    "dblac;": "\u02dd",
-    "dcaron;": "\u010f",
-    "dcy;": "\u0434",
-    "dd;": "\u2146",
-    "ddagger;": "\u2021",
-    "ddarr;": "\u21ca",
-    "ddotseq;": "\u2a77",
-    "deg": "\xb0",
-    "deg;": "\xb0",
-    "delta;": "\u03b4",
-    "demptyv;": "\u29b1",
-    "dfisht;": "\u297f",
-    "dfr;": "\U0001d521",
-    "dharl;": "\u21c3",
-    "dharr;": "\u21c2",
-    "diam;": "\u22c4",
-    "diamond;": "\u22c4",
-    "diamondsuit;": "\u2666",
-    "diams;": "\u2666",
-    "die;": "\xa8",
-    "digamma;": "\u03dd",
-    "disin;": "\u22f2",
-    "div;": "\xf7",
-    "divide": "\xf7",
-    "divide;": "\xf7",
-    "divideontimes;": "\u22c7",
-    "divonx;": "\u22c7",
-    "djcy;": "\u0452",
-    "dlcorn;": "\u231e",
-    "dlcrop;": "\u230d",
-    "dollar;": "$",
-    "dopf;": "\U0001d555",
-    "dot;": "\u02d9",
-    "doteq;": "\u2250",
-    "doteqdot;": "\u2251",
-    "dotminus;": "\u2238",
-    "dotplus;": "\u2214",
-    "dotsquare;": "\u22a1",
-    "doublebarwedge;": "\u2306",
-    "downarrow;": "\u2193",
-    "downdownarrows;": "\u21ca",
-    "downharpoonleft;": "\u21c3",
-    "downharpoonright;": "\u21c2",
-    "drbkarow;": "\u2910",
-    "drcorn;": "\u231f",
-    "drcrop;": "\u230c",
-    "dscr;": "\U0001d4b9",
-    "dscy;": "\u0455",
-    "dsol;": "\u29f6",
-    "dstrok;": "\u0111",
-    "dtdot;": "\u22f1",
-    "dtri;": "\u25bf",
-    "dtrif;": "\u25be",
-    "duarr;": "\u21f5",
-    "duhar;": "\u296f",
-    "dwangle;": "\u29a6",
-    "dzcy;": "\u045f",
-    "dzigrarr;": "\u27ff",
-    "eDDot;": "\u2a77",
-    "eDot;": "\u2251",
-    "eacute": "\xe9",
-    "eacute;": "\xe9",
-    "easter;": "\u2a6e",
-    "ecaron;": "\u011b",
-    "ecir;": "\u2256",
-    "ecirc": "\xea",
-    "ecirc;": "\xea",
-    "ecolon;": "\u2255",
-    "ecy;": "\u044d",
-    "edot;": "\u0117",
-    "ee;": "\u2147",
-    "efDot;": "\u2252",
-    "efr;": "\U0001d522",
-    "eg;": "\u2a9a",
-    "egrave": "\xe8",
-    "egrave;": "\xe8",
-    "egs;": "\u2a96",
-    "egsdot;": "\u2a98",
-    "el;": "\u2a99",
-    "elinters;": "\u23e7",
-    "ell;": "\u2113",
-    "els;": "\u2a95",
-    "elsdot;": "\u2a97",
-    "emacr;": "\u0113",
-    "empty;": "\u2205",
-    "emptyset;": "\u2205",
-    "emptyv;": "\u2205",
-    "emsp13;": "\u2004",
-    "emsp14;": "\u2005",
-    "emsp;": "\u2003",
-    "eng;": "\u014b",
-    "ensp;": "\u2002",
-    "eogon;": "\u0119",
-    "eopf;": "\U0001d556",
-    "epar;": "\u22d5",
-    "eparsl;": "\u29e3",
-    "eplus;": "\u2a71",
-    "epsi;": "\u03b5",
-    "epsilon;": "\u03b5",
-    "epsiv;": "\u03f5",
-    "eqcirc;": "\u2256",
-    "eqcolon;": "\u2255",
-    "eqsim;": "\u2242",
-    "eqslantgtr;": "\u2a96",
-    "eqslantless;": "\u2a95",
-    "equals;": "=",
-    "equest;": "\u225f",
-    "equiv;": "\u2261",
-    "equivDD;": "\u2a78",
-    "eqvparsl;": "\u29e5",
-    "erDot;": "\u2253",
-    "erarr;": "\u2971",
-    "escr;": "\u212f",
-    "esdot;": "\u2250",
-    "esim;": "\u2242",
-    "eta;": "\u03b7",
-    "eth": "\xf0",
-    "eth;": "\xf0",
-    "euml": "\xeb",
-    "euml;": "\xeb",
-    "euro;": "\u20ac",
-    "excl;": "!",
-    "exist;": "\u2203",
-    "expectation;": "\u2130",
-    "exponentiale;": "\u2147",
-    "fallingdotseq;": "\u2252",
-    "fcy;": "\u0444",
-    "female;": "\u2640",
-    "ffilig;": "\ufb03",
-    "fflig;": "\ufb00",
-    "ffllig;": "\ufb04",
-    "ffr;": "\U0001d523",
-    "filig;": "\ufb01",
-    "fjlig;": "fj",
-    "flat;": "\u266d",
-    "fllig;": "\ufb02",
-    "fltns;": "\u25b1",
-    "fnof;": "\u0192",
-    "fopf;": "\U0001d557",
-    "forall;": "\u2200",
-    "fork;": "\u22d4",
-    "forkv;": "\u2ad9",
-    "fpartint;": "\u2a0d",
-    "frac12": "\xbd",
-    "frac12;": "\xbd",
-    "frac13;": "\u2153",
-    "frac14": "\xbc",
-    "frac14;": "\xbc",
-    "frac15;": "\u2155",
-    "frac16;": "\u2159",
-    "frac18;": "\u215b",
-    "frac23;": "\u2154",
-    "frac25;": "\u2156",
-    "frac34": "\xbe",
-    "frac34;": "\xbe",
-    "frac35;": "\u2157",
-    "frac38;": "\u215c",
-    "frac45;": "\u2158",
-    "frac56;": "\u215a",
-    "frac58;": "\u215d",
-    "frac78;": "\u215e",
-    "frasl;": "\u2044",
-    "frown;": "\u2322",
-    "fscr;": "\U0001d4bb",
-    "gE;": "\u2267",
-    "gEl;": "\u2a8c",
-    "gacute;": "\u01f5",
-    "gamma;": "\u03b3",
-    "gammad;": "\u03dd",
-    "gap;": "\u2a86",
-    "gbreve;": "\u011f",
-    "gcirc;": "\u011d",
-    "gcy;": "\u0433",
-    "gdot;": "\u0121",
-    "ge;": "\u2265",
-    "gel;": "\u22db",
-    "geq;": "\u2265",
-    "geqq;": "\u2267",
-    "geqslant;": "\u2a7e",
-    "ges;": "\u2a7e",
-    "gescc;": "\u2aa9",
-    "gesdot;": "\u2a80",
-    "gesdoto;": "\u2a82",
-    "gesdotol;": "\u2a84",
-    "gesl;": "\u22db\ufe00",
-    "gesles;": "\u2a94",
-    "gfr;": "\U0001d524",
-    "gg;": "\u226b",
-    "ggg;": "\u22d9",
-    "gimel;": "\u2137",
-    "gjcy;": "\u0453",
-    "gl;": "\u2277",
-    "glE;": "\u2a92",
-    "gla;": "\u2aa5",
-    "glj;": "\u2aa4",
-    "gnE;": "\u2269",
-    "gnap;": "\u2a8a",
-    "gnapprox;": "\u2a8a",
-    "gne;": "\u2a88",
-    "gneq;": "\u2a88",
-    "gneqq;": "\u2269",
-    "gnsim;": "\u22e7",
-    "gopf;": "\U0001d558",
-    "grave;": "`",
-    "gscr;": "\u210a",
-    "gsim;": "\u2273",
-    "gsime;": "\u2a8e",
-    "gsiml;": "\u2a90",
-    "gt": ">",
-    "gt;": ">",
-    "gtcc;": "\u2aa7",
-    "gtcir;": "\u2a7a",
-    "gtdot;": "\u22d7",
-    "gtlPar;": "\u2995",
-    "gtquest;": "\u2a7c",
-    "gtrapprox;": "\u2a86",
-    "gtrarr;": "\u2978",
-    "gtrdot;": "\u22d7",
-    "gtreqless;": "\u22db",
-    "gtreqqless;": "\u2a8c",
-    "gtrless;": "\u2277",
-    "gtrsim;": "\u2273",
-    "gvertneqq;": "\u2269\ufe00",
-    "gvnE;": "\u2269\ufe00",
-    "hArr;": "\u21d4",
-    "hairsp;": "\u200a",
-    "half;": "\xbd",
-    "hamilt;": "\u210b",
-    "hardcy;": "\u044a",
-    "harr;": "\u2194",
-    "harrcir;": "\u2948",
-    "harrw;": "\u21ad",
-    "hbar;": "\u210f",
-    "hcirc;": "\u0125",
-    "hearts;": "\u2665",
-    "heartsuit;": "\u2665",
-    "hellip;": "\u2026",
-    "hercon;": "\u22b9",
-    "hfr;": "\U0001d525",
-    "hksearow;": "\u2925",
-    "hkswarow;": "\u2926",
-    "hoarr;": "\u21ff",
-    "homtht;": "\u223b",
-    "hookleftarrow;": "\u21a9",
-    "hookrightarrow;": "\u21aa",
-    "hopf;": "\U0001d559",
-    "horbar;": "\u2015",
-    "hscr;": "\U0001d4bd",
-    "hslash;": "\u210f",
-    "hstrok;": "\u0127",
-    "hybull;": "\u2043",
-    "hyphen;": "\u2010",
-    "iacute": "\xed",
-    "iacute;": "\xed",
-    "ic;": "\u2063",
-    "icirc": "\xee",
-    "icirc;": "\xee",
-    "icy;": "\u0438",
-    "iecy;": "\u0435",
-    "iexcl": "\xa1",
-    "iexcl;": "\xa1",
-    "iff;": "\u21d4",
-    "ifr;": "\U0001d526",
-    "igrave": "\xec",
-    "igrave;": "\xec",
-    "ii;": "\u2148",
-    "iiiint;": "\u2a0c",
-    "iiint;": "\u222d",
-    "iinfin;": "\u29dc",
-    "iiota;": "\u2129",
-    "ijlig;": "\u0133",
-    "imacr;": "\u012b",
-    "image;": "\u2111",
-    "imagline;": "\u2110",
-    "imagpart;": "\u2111",
-    "imath;": "\u0131",
-    "imof;": "\u22b7",
-    "imped;": "\u01b5",
-    "in;": "\u2208",
-    "incare;": "\u2105",
-    "infin;": "\u221e",
-    "infintie;": "\u29dd",
-    "inodot;": "\u0131",
-    "int;": "\u222b",
-    "intcal;": "\u22ba",
-    "integers;": "\u2124",
-    "intercal;": "\u22ba",
-    "intlarhk;": "\u2a17",
-    "intprod;": "\u2a3c",
-    "iocy;": "\u0451",
-    "iogon;": "\u012f",
-    "iopf;": "\U0001d55a",
-    "iota;": "\u03b9",
-    "iprod;": "\u2a3c",
-    "iquest": "\xbf",
-    "iquest;": "\xbf",
-    "iscr;": "\U0001d4be",
-    "isin;": "\u2208",
-    "isinE;": "\u22f9",
-    "isindot;": "\u22f5",
-    "isins;": "\u22f4",
-    "isinsv;": "\u22f3",
-    "isinv;": "\u2208",
-    "it;": "\u2062",
-    "itilde;": "\u0129",
-    "iukcy;": "\u0456",
-    "iuml": "\xef",
-    "iuml;": "\xef",
-    "jcirc;": "\u0135",
-    "jcy;": "\u0439",
-    "jfr;": "\U0001d527",
-    "jmath;": "\u0237",
-    "jopf;": "\U0001d55b",
-    "jscr;": "\U0001d4bf",
-    "jsercy;": "\u0458",
-    "jukcy;": "\u0454",
-    "kappa;": "\u03ba",
-    "kappav;": "\u03f0",
-    "kcedil;": "\u0137",
-    "kcy;": "\u043a",
-    "kfr;": "\U0001d528",
-    "kgreen;": "\u0138",
-    "khcy;": "\u0445",
-    "kjcy;": "\u045c",
-    "kopf;": "\U0001d55c",
-    "kscr;": "\U0001d4c0",
-    "lAarr;": "\u21da",
-    "lArr;": "\u21d0",
-    "lAtail;": "\u291b",
-    "lBarr;": "\u290e",
-    "lE;": "\u2266",
-    "lEg;": "\u2a8b",
-    "lHar;": "\u2962",
-    "lacute;": "\u013a",
-    "laemptyv;": "\u29b4",
-    "lagran;": "\u2112",
-    "lambda;": "\u03bb",
-    "lang;": "\u27e8",
-    "langd;": "\u2991",
-    "langle;": "\u27e8",
-    "lap;": "\u2a85",
-    "laquo": "\xab",
-    "laquo;": "\xab",
-    "larr;": "\u2190",
-    "larrb;": "\u21e4",
-    "larrbfs;": "\u291f",
-    "larrfs;": "\u291d",
-    "larrhk;": "\u21a9",
-    "larrlp;": "\u21ab",
-    "larrpl;": "\u2939",
-    "larrsim;": "\u2973",
-    "larrtl;": "\u21a2",
-    "lat;": "\u2aab",
-    "latail;": "\u2919",
-    "late;": "\u2aad",
-    "lates;": "\u2aad\ufe00",
-    "lbarr;": "\u290c",
-    "lbbrk;": "\u2772",
-    "lbrace;": "{",
-    "lbrack;": "[",
-    "lbrke;": "\u298b",
-    "lbrksld;": "\u298f",
-    "lbrkslu;": "\u298d",
-    "lcaron;": "\u013e",
-    "lcedil;": "\u013c",
-    "lceil;": "\u2308",
-    "lcub;": "{",
-    "lcy;": "\u043b",
-    "ldca;": "\u2936",
-    "ldquo;": "\u201c",
-    "ldquor;": "\u201e",
-    "ldrdhar;": "\u2967",
-    "ldrushar;": "\u294b",
-    "ldsh;": "\u21b2",
-    "le;": "\u2264",
-    "leftarrow;": "\u2190",
-    "leftarrowtail;": "\u21a2",
-    "leftharpoondown;": "\u21bd",
-    "leftharpoonup;": "\u21bc",
-    "leftleftarrows;": "\u21c7",
-    "leftrightarrow;": "\u2194",
-    "leftrightarrows;": "\u21c6",
-    "leftrightharpoons;": "\u21cb",
-    "leftrightsquigarrow;": "\u21ad",
-    "leftthreetimes;": "\u22cb",
-    "leg;": "\u22da",
-    "leq;": "\u2264",
-    "leqq;": "\u2266",
-    "leqslant;": "\u2a7d",
-    "les;": "\u2a7d",
-    "lescc;": "\u2aa8",
-    "lesdot;": "\u2a7f",
-    "lesdoto;": "\u2a81",
-    "lesdotor;": "\u2a83",
-    "lesg;": "\u22da\ufe00",
-    "lesges;": "\u2a93",
-    "lessapprox;": "\u2a85",
-    "lessdot;": "\u22d6",
-    "lesseqgtr;": "\u22da",
-    "lesseqqgtr;": "\u2a8b",
-    "lessgtr;": "\u2276",
-    "lesssim;": "\u2272",
-    "lfisht;": "\u297c",
-    "lfloor;": "\u230a",
-    "lfr;": "\U0001d529",
-    "lg;": "\u2276",
-    "lgE;": "\u2a91",
-    "lhard;": "\u21bd",
-    "lharu;": "\u21bc",
-    "lharul;": "\u296a",
-    "lhblk;": "\u2584",
-    "ljcy;": "\u0459",
-    "ll;": "\u226a",
-    "llarr;": "\u21c7",
-    "llcorner;": "\u231e",
-    "llhard;": "\u296b",
-    "lltri;": "\u25fa",
-    "lmidot;": "\u0140",
-    "lmoust;": "\u23b0",
-    "lmoustache;": "\u23b0",
-    "lnE;": "\u2268",
-    "lnap;": "\u2a89",
-    "lnapprox;": "\u2a89",
-    "lne;": "\u2a87",
-    "lneq;": "\u2a87",
-    "lneqq;": "\u2268",
-    "lnsim;": "\u22e6",
-    "loang;": "\u27ec",
-    "loarr;": "\u21fd",
-    "lobrk;": "\u27e6",
-    "longleftarrow;": "\u27f5",
-    "longleftrightarrow;": "\u27f7",
-    "longmapsto;": "\u27fc",
-    "longrightarrow;": "\u27f6",
-    "looparrowleft;": "\u21ab",
-    "looparrowright;": "\u21ac",
-    "lopar;": "\u2985",
-    "lopf;": "\U0001d55d",
-    "loplus;": "\u2a2d",
-    "lotimes;": "\u2a34",
-    "lowast;": "\u2217",
-    "lowbar;": "_",
-    "loz;": "\u25ca",
-    "lozenge;": "\u25ca",
-    "lozf;": "\u29eb",
-    "lpar;": "(",
-    "lparlt;": "\u2993",
-    "lrarr;": "\u21c6",
-    "lrcorner;": "\u231f",
-    "lrhar;": "\u21cb",
-    "lrhard;": "\u296d",
-    "lrm;": "\u200e",
-    "lrtri;": "\u22bf",
-    "lsaquo;": "\u2039",
-    "lscr;": "\U0001d4c1",
-    "lsh;": "\u21b0",
-    "lsim;": "\u2272",
-    "lsime;": "\u2a8d",
-    "lsimg;": "\u2a8f",
-    "lsqb;": "[",
-    "lsquo;": "\u2018",
-    "lsquor;": "\u201a",
-    "lstrok;": "\u0142",
-    "lt": "<",
-    "lt;": "<",
-    "ltcc;": "\u2aa6",
-    "ltcir;": "\u2a79",
-    "ltdot;": "\u22d6",
-    "lthree;": "\u22cb",
-    "ltimes;": "\u22c9",
-    "ltlarr;": "\u2976",
-    "ltquest;": "\u2a7b",
-    "ltrPar;": "\u2996",
-    "ltri;": "\u25c3",
-    "ltrie;": "\u22b4",
-    "ltrif;": "\u25c2",
-    "lurdshar;": "\u294a",
-    "luruhar;": "\u2966",
-    "lvertneqq;": "\u2268\ufe00",
-    "lvnE;": "\u2268\ufe00",
-    "mDDot;": "\u223a",
-    "macr": "\xaf",
-    "macr;": "\xaf",
-    "male;": "\u2642",
-    "malt;": "\u2720",
-    "maltese;": "\u2720",
-    "map;": "\u21a6",
-    "mapsto;": "\u21a6",
-    "mapstodown;": "\u21a7",
-    "mapstoleft;": "\u21a4",
-    "mapstoup;": "\u21a5",
-    "marker;": "\u25ae",
-    "mcomma;": "\u2a29",
-    "mcy;": "\u043c",
-    "mdash;": "\u2014",
-    "measuredangle;": "\u2221",
-    "mfr;": "\U0001d52a",
-    "mho;": "\u2127",
-    "micro": "\xb5",
-    "micro;": "\xb5",
-    "mid;": "\u2223",
-    "midast;": "*",
-    "midcir;": "\u2af0",
-    "middot": "\xb7",
-    "middot;": "\xb7",
-    "minus;": "\u2212",
-    "minusb;": "\u229f",
-    "minusd;": "\u2238",
-    "minusdu;": "\u2a2a",
-    "mlcp;": "\u2adb",
-    "mldr;": "\u2026",
-    "mnplus;": "\u2213",
-    "models;": "\u22a7",
-    "mopf;": "\U0001d55e",
-    "mp;": "\u2213",
-    "mscr;": "\U0001d4c2",
-    "mstpos;": "\u223e",
-    "mu;": "\u03bc",
-    "multimap;": "\u22b8",
-    "mumap;": "\u22b8",
-    "nGg;": "\u22d9\u0338",
-    "nGt;": "\u226b\u20d2",
-    "nGtv;": "\u226b\u0338",
-    "nLeftarrow;": "\u21cd",
-    "nLeftrightarrow;": "\u21ce",
-    "nLl;": "\u22d8\u0338",
-    "nLt;": "\u226a\u20d2",
-    "nLtv;": "\u226a\u0338",
-    "nRightarrow;": "\u21cf",
-    "nVDash;": "\u22af",
-    "nVdash;": "\u22ae",
-    "nabla;": "\u2207",
-    "nacute;": "\u0144",
-    "nang;": "\u2220\u20d2",
-    "nap;": "\u2249",
-    "napE;": "\u2a70\u0338",
-    "napid;": "\u224b\u0338",
-    "napos;": "\u0149",
-    "napprox;": "\u2249",
-    "natur;": "\u266e",
-    "natural;": "\u266e",
-    "naturals;": "\u2115",
-    "nbsp": "\xa0",
-    "nbsp;": "\xa0",
-    "nbump;": "\u224e\u0338",
-    "nbumpe;": "\u224f\u0338",
-    "ncap;": "\u2a43",
-    "ncaron;": "\u0148",
-    "ncedil;": "\u0146",
-    "ncong;": "\u2247",
-    "ncongdot;": "\u2a6d\u0338",
-    "ncup;": "\u2a42",
-    "ncy;": "\u043d",
-    "ndash;": "\u2013",
-    "ne;": "\u2260",
-    "neArr;": "\u21d7",
-    "nearhk;": "\u2924",
-    "nearr;": "\u2197",
-    "nearrow;": "\u2197",
-    "nedot;": "\u2250\u0338",
-    "nequiv;": "\u2262",
-    "nesear;": "\u2928",
-    "nesim;": "\u2242\u0338",
-    "nexist;": "\u2204",
-    "nexists;": "\u2204",
-    "nfr;": "\U0001d52b",
-    "ngE;": "\u2267\u0338",
-    "nge;": "\u2271",
-    "ngeq;": "\u2271",
-    "ngeqq;": "\u2267\u0338",
-    "ngeqslant;": "\u2a7e\u0338",
-    "nges;": "\u2a7e\u0338",
-    "ngsim;": "\u2275",
-    "ngt;": "\u226f",
-    "ngtr;": "\u226f",
-    "nhArr;": "\u21ce",
-    "nharr;": "\u21ae",
-    "nhpar;": "\u2af2",
-    "ni;": "\u220b",
-    "nis;": "\u22fc",
-    "nisd;": "\u22fa",
-    "niv;": "\u220b",
-    "njcy;": "\u045a",
-    "nlArr;": "\u21cd",
-    "nlE;": "\u2266\u0338",
-    "nlarr;": "\u219a",
-    "nldr;": "\u2025",
-    "nle;": "\u2270",
-    "nleftarrow;": "\u219a",
-    "nleftrightarrow;": "\u21ae",
-    "nleq;": "\u2270",
-    "nleqq;": "\u2266\u0338",
-    "nleqslant;": "\u2a7d\u0338",
-    "nles;": "\u2a7d\u0338",
-    "nless;": "\u226e",
-    "nlsim;": "\u2274",
-    "nlt;": "\u226e",
-    "nltri;": "\u22ea",
-    "nltrie;": "\u22ec",
-    "nmid;": "\u2224",
-    "nopf;": "\U0001d55f",
-    "not": "\xac",
-    "not;": "\xac",
-    "notin;": "\u2209",
-    "notinE;": "\u22f9\u0338",
-    "notindot;": "\u22f5\u0338",
-    "notinva;": "\u2209",
-    "notinvb;": "\u22f7",
-    "notinvc;": "\u22f6",
-    "notni;": "\u220c",
-    "notniva;": "\u220c",
-    "notnivb;": "\u22fe",
-    "notnivc;": "\u22fd",
-    "npar;": "\u2226",
-    "nparallel;": "\u2226",
-    "nparsl;": "\u2afd\u20e5",
-    "npart;": "\u2202\u0338",
-    "npolint;": "\u2a14",
-    "npr;": "\u2280",
-    "nprcue;": "\u22e0",
-    "npre;": "\u2aaf\u0338",
-    "nprec;": "\u2280",
-    "npreceq;": "\u2aaf\u0338",
-    "nrArr;": "\u21cf",
-    "nrarr;": "\u219b",
-    "nrarrc;": "\u2933\u0338",
-    "nrarrw;": "\u219d\u0338",
-    "nrightarrow;": "\u219b",
-    "nrtri;": "\u22eb",
-    "nrtrie;": "\u22ed",
-    "nsc;": "\u2281",
-    "nsccue;": "\u22e1",
-    "nsce;": "\u2ab0\u0338",
-    "nscr;": "\U0001d4c3",
-    "nshortmid;": "\u2224",
-    "nshortparallel;": "\u2226",
-    "nsim;": "\u2241",
-    "nsime;": "\u2244",
-    "nsimeq;": "\u2244",
-    "nsmid;": "\u2224",
-    "nspar;": "\u2226",
-    "nsqsube;": "\u22e2",
-    "nsqsupe;": "\u22e3",
-    "nsub;": "\u2284",
-    "nsubE;": "\u2ac5\u0338",
-    "nsube;": "\u2288",
-    "nsubset;": "\u2282\u20d2",
-    "nsubseteq;": "\u2288",
-    "nsubseteqq;": "\u2ac5\u0338",
-    "nsucc;": "\u2281",
-    "nsucceq;": "\u2ab0\u0338",
-    "nsup;": "\u2285",
-    "nsupE;": "\u2ac6\u0338",
-    "nsupe;": "\u2289",
-    "nsupset;": "\u2283\u20d2",
-    "nsupseteq;": "\u2289",
-    "nsupseteqq;": "\u2ac6\u0338",
-    "ntgl;": "\u2279",
-    "ntilde": "\xf1",
-    "ntilde;": "\xf1",
-    "ntlg;": "\u2278",
-    "ntriangleleft;": "\u22ea",
-    "ntrianglelefteq;": "\u22ec",
-    "ntriangleright;": "\u22eb",
-    "ntrianglerighteq;": "\u22ed",
-    "nu;": "\u03bd",
-    "num;": "#",
-    "numero;": "\u2116",
-    "numsp;": "\u2007",
-    "nvDash;": "\u22ad",
-    "nvHarr;": "\u2904",
-    "nvap;": "\u224d\u20d2",
-    "nvdash;": "\u22ac",
-    "nvge;": "\u2265\u20d2",
-    "nvgt;": ">\u20d2",
-    "nvinfin;": "\u29de",
-    "nvlArr;": "\u2902",
-    "nvle;": "\u2264\u20d2",
-    "nvlt;": "<\u20d2",
-    "nvltrie;": "\u22b4\u20d2",
-    "nvrArr;": "\u2903",
-    "nvrtrie;": "\u22b5\u20d2",
-    "nvsim;": "\u223c\u20d2",
-    "nwArr;": "\u21d6",
-    "nwarhk;": "\u2923",
-    "nwarr;": "\u2196",
-    "nwarrow;": "\u2196",
-    "nwnear;": "\u2927",
-    "oS;": "\u24c8",
-    "oacute": "\xf3",
-    "oacute;": "\xf3",
-    "oast;": "\u229b",
-    "ocir;": "\u229a",
-    "ocirc": "\xf4",
-    "ocirc;": "\xf4",
-    "ocy;": "\u043e",
-    "odash;": "\u229d",
-    "odblac;": "\u0151",
-    "odiv;": "\u2a38",
-    "odot;": "\u2299",
-    "odsold;": "\u29bc",
-    "oelig;": "\u0153",
-    "ofcir;": "\u29bf",
-    "ofr;": "\U0001d52c",
-    "ogon;": "\u02db",
-    "ograve": "\xf2",
-    "ograve;": "\xf2",
-    "ogt;": "\u29c1",
-    "ohbar;": "\u29b5",
-    "ohm;": "\u03a9",
-    "oint;": "\u222e",
-    "olarr;": "\u21ba",
-    "olcir;": "\u29be",
-    "olcross;": "\u29bb",
-    "oline;": "\u203e",
-    "olt;": "\u29c0",
-    "omacr;": "\u014d",
-    "omega;": "\u03c9",
-    "omicron;": "\u03bf",
-    "omid;": "\u29b6",
-    "ominus;": "\u2296",
-    "oopf;": "\U0001d560",
-    "opar;": "\u29b7",
-    "operp;": "\u29b9",
-    "oplus;": "\u2295",
-    "or;": "\u2228",
-    "orarr;": "\u21bb",
-    "ord;": "\u2a5d",
-    "order;": "\u2134",
-    "orderof;": "\u2134",
-    "ordf": "\xaa",
-    "ordf;": "\xaa",
-    "ordm": "\xba",
-    "ordm;": "\xba",
-    "origof;": "\u22b6",
-    "oror;": "\u2a56",
-    "orslope;": "\u2a57",
-    "orv;": "\u2a5b",
-    "oscr;": "\u2134",
-    "oslash": "\xf8",
-    "oslash;": "\xf8",
-    "osol;": "\u2298",
-    "otilde": "\xf5",
-    "otilde;": "\xf5",
-    "otimes;": "\u2297",
-    "otimesas;": "\u2a36",
-    "ouml": "\xf6",
-    "ouml;": "\xf6",
-    "ovbar;": "\u233d",
-    "par;": "\u2225",
-    "para": "\xb6",
-    "para;": "\xb6",
-    "parallel;": "\u2225",
-    "parsim;": "\u2af3",
-    "parsl;": "\u2afd",
-    "part;": "\u2202",
-    "pcy;": "\u043f",
-    "percnt;": "%",
-    "period;": ".",
-    "permil;": "\u2030",
-    "perp;": "\u22a5",
-    "pertenk;": "\u2031",
-    "pfr;": "\U0001d52d",
-    "phi;": "\u03c6",
-    "phiv;": "\u03d5",
-    "phmmat;": "\u2133",
-    "phone;": "\u260e",
-    "pi;": "\u03c0",
-    "pitchfork;": "\u22d4",
-    "piv;": "\u03d6",
-    "planck;": "\u210f",
-    "planckh;": "\u210e",
-    "plankv;": "\u210f",
-    "plus;": "+",
-    "plusacir;": "\u2a23",
-    "plusb;": "\u229e",
-    "pluscir;": "\u2a22",
-    "plusdo;": "\u2214",
-    "plusdu;": "\u2a25",
-    "pluse;": "\u2a72",
-    "plusmn": "\xb1",
-    "plusmn;": "\xb1",
-    "plussim;": "\u2a26",
-    "plustwo;": "\u2a27",
-    "pm;": "\xb1",
-    "pointint;": "\u2a15",
-    "popf;": "\U0001d561",
-    "pound": "\xa3",
-    "pound;": "\xa3",
-    "pr;": "\u227a",
-    "prE;": "\u2ab3",
-    "prap;": "\u2ab7",
-    "prcue;": "\u227c",
-    "pre;": "\u2aaf",
-    "prec;": "\u227a",
-    "precapprox;": "\u2ab7",
-    "preccurlyeq;": "\u227c",
-    "preceq;": "\u2aaf",
-    "precnapprox;": "\u2ab9",
-    "precneqq;": "\u2ab5",
-    "precnsim;": "\u22e8",
-    "precsim;": "\u227e",
-    "prime;": "\u2032",
-    "primes;": "\u2119",
-    "prnE;": "\u2ab5",
-    "prnap;": "\u2ab9",
-    "prnsim;": "\u22e8",
-    "prod;": "\u220f",
-    "profalar;": "\u232e",
-    "profline;": "\u2312",
-    "profsurf;": "\u2313",
-    "prop;": "\u221d",
-    "propto;": "\u221d",
-    "prsim;": "\u227e",
-    "prurel;": "\u22b0",
-    "pscr;": "\U0001d4c5",
-    "psi;": "\u03c8",
-    "puncsp;": "\u2008",
-    "qfr;": "\U0001d52e",
-    "qint;": "\u2a0c",
-    "qopf;": "\U0001d562",
-    "qprime;": "\u2057",
-    "qscr;": "\U0001d4c6",
-    "quaternions;": "\u210d",
-    "quatint;": "\u2a16",
-    "quest;": "?",
-    "questeq;": "\u225f",
-    "quot": "\"",
-    "quot;": "\"",
-    "rAarr;": "\u21db",
-    "rArr;": "\u21d2",
-    "rAtail;": "\u291c",
-    "rBarr;": "\u290f",
-    "rHar;": "\u2964",
-    "race;": "\u223d\u0331",
-    "racute;": "\u0155",
-    "radic;": "\u221a",
-    "raemptyv;": "\u29b3",
-    "rang;": "\u27e9",
-    "rangd;": "\u2992",
-    "range;": "\u29a5",
-    "rangle;": "\u27e9",
-    "raquo": "\xbb",
-    "raquo;": "\xbb",
-    "rarr;": "\u2192",
-    "rarrap;": "\u2975",
-    "rarrb;": "\u21e5",
-    "rarrbfs;": "\u2920",
-    "rarrc;": "\u2933",
-    "rarrfs;": "\u291e",
-    "rarrhk;": "\u21aa",
-    "rarrlp;": "\u21ac",
-    "rarrpl;": "\u2945",
-    "rarrsim;": "\u2974",
-    "rarrtl;": "\u21a3",
-    "rarrw;": "\u219d",
-    "ratail;": "\u291a",
-    "ratio;": "\u2236",
-    "rationals;": "\u211a",
-    "rbarr;": "\u290d",
-    "rbbrk;": "\u2773",
-    "rbrace;": "}",
-    "rbrack;": "]",
-    "rbrke;": "\u298c",
-    "rbrksld;": "\u298e",
-    "rbrkslu;": "\u2990",
-    "rcaron;": "\u0159",
-    "rcedil;": "\u0157",
-    "rceil;": "\u2309",
-    "rcub;": "}",
-    "rcy;": "\u0440",
-    "rdca;": "\u2937",
-    "rdldhar;": "\u2969",
-    "rdquo;": "\u201d",
-    "rdquor;": "\u201d",
-    "rdsh;": "\u21b3",
-    "real;": "\u211c",
-    "realine;": "\u211b",
-    "realpart;": "\u211c",
-    "reals;": "\u211d",
-    "rect;": "\u25ad",
-    "reg": "\xae",
-    "reg;": "\xae",
-    "rfisht;": "\u297d",
-    "rfloor;": "\u230b",
-    "rfr;": "\U0001d52f",
-    "rhard;": "\u21c1",
-    "rharu;": "\u21c0",
-    "rharul;": "\u296c",
-    "rho;": "\u03c1",
-    "rhov;": "\u03f1",
-    "rightarrow;": "\u2192",
-    "rightarrowtail;": "\u21a3",
-    "rightharpoondown;": "\u21c1",
-    "rightharpoonup;": "\u21c0",
-    "rightleftarrows;": "\u21c4",
-    "rightleftharpoons;": "\u21cc",
-    "rightrightarrows;": "\u21c9",
-    "rightsquigarrow;": "\u219d",
-    "rightthreetimes;": "\u22cc",
-    "ring;": "\u02da",
-    "risingdotseq;": "\u2253",
-    "rlarr;": "\u21c4",
-    "rlhar;": "\u21cc",
-    "rlm;": "\u200f",
-    "rmoust;": "\u23b1",
-    "rmoustache;": "\u23b1",
-    "rnmid;": "\u2aee",
-    "roang;": "\u27ed",
-    "roarr;": "\u21fe",
-    "robrk;": "\u27e7",
-    "ropar;": "\u2986",
-    "ropf;": "\U0001d563",
-    "roplus;": "\u2a2e",
-    "rotimes;": "\u2a35",
-    "rpar;": ")",
-    "rpargt;": "\u2994",
-    "rppolint;": "\u2a12",
-    "rrarr;": "\u21c9",
-    "rsaquo;": "\u203a",
-    "rscr;": "\U0001d4c7",
-    "rsh;": "\u21b1",
-    "rsqb;": "]",
-    "rsquo;": "\u2019",
-    "rsquor;": "\u2019",
-    "rthree;": "\u22cc",
-    "rtimes;": "\u22ca",
-    "rtri;": "\u25b9",
-    "rtrie;": "\u22b5",
-    "rtrif;": "\u25b8",
-    "rtriltri;": "\u29ce",
-    "ruluhar;": "\u2968",
-    "rx;": "\u211e",
-    "sacute;": "\u015b",
-    "sbquo;": "\u201a",
-    "sc;": "\u227b",
-    "scE;": "\u2ab4",
-    "scap;": "\u2ab8",
-    "scaron;": "\u0161",
-    "sccue;": "\u227d",
-    "sce;": "\u2ab0",
-    "scedil;": "\u015f",
-    "scirc;": "\u015d",
-    "scnE;": "\u2ab6",
-    "scnap;": "\u2aba",
-    "scnsim;": "\u22e9",
-    "scpolint;": "\u2a13",
-    "scsim;": "\u227f",
-    "scy;": "\u0441",
-    "sdot;": "\u22c5",
-    "sdotb;": "\u22a1",
-    "sdote;": "\u2a66",
-    "seArr;": "\u21d8",
-    "searhk;": "\u2925",
-    "searr;": "\u2198",
-    "searrow;": "\u2198",
-    "sect": "\xa7",
-    "sect;": "\xa7",
-    "semi;": ";",
-    "seswar;": "\u2929",
-    "setminus;": "\u2216",
-    "setmn;": "\u2216",
-    "sext;": "\u2736",
-    "sfr;": "\U0001d530",
-    "sfrown;": "\u2322",
-    "sharp;": "\u266f",
-    "shchcy;": "\u0449",
-    "shcy;": "\u0448",
-    "shortmid;": "\u2223",
-    "shortparallel;": "\u2225",
-    "shy": "\xad",
-    "shy;": "\xad",
-    "sigma;": "\u03c3",
-    "sigmaf;": "\u03c2",
-    "sigmav;": "\u03c2",
-    "sim;": "\u223c",
-    "simdot;": "\u2a6a",
-    "sime;": "\u2243",
-    "simeq;": "\u2243",
-    "simg;": "\u2a9e",
-    "simgE;": "\u2aa0",
-    "siml;": "\u2a9d",
-    "simlE;": "\u2a9f",
-    "simne;": "\u2246",
-    "simplus;": "\u2a24",
-    "simrarr;": "\u2972",
-    "slarr;": "\u2190",
-    "smallsetminus;": "\u2216",
-    "smashp;": "\u2a33",
-    "smeparsl;": "\u29e4",
-    "smid;": "\u2223",
-    "smile;": "\u2323",
-    "smt;": "\u2aaa",
-    "smte;": "\u2aac",
-    "smtes;": "\u2aac\ufe00",
-    "softcy;": "\u044c",
-    "sol;": "/",
-    "solb;": "\u29c4",
-    "solbar;": "\u233f",
-    "sopf;": "\U0001d564",
-    "spades;": "\u2660",
-    "spadesuit;": "\u2660",
-    "spar;": "\u2225",
-    "sqcap;": "\u2293",
-    "sqcaps;": "\u2293\ufe00",
-    "sqcup;": "\u2294",
-    "sqcups;": "\u2294\ufe00",
-    "sqsub;": "\u228f",
-    "sqsube;": "\u2291",
-    "sqsubset;": "\u228f",
-    "sqsubseteq;": "\u2291",
-    "sqsup;": "\u2290",
-    "sqsupe;": "\u2292",
-    "sqsupset;": "\u2290",
-    "sqsupseteq;": "\u2292",
-    "squ;": "\u25a1",
-    "square;": "\u25a1",
-    "squarf;": "\u25aa",
-    "squf;": "\u25aa",
-    "srarr;": "\u2192",
-    "sscr;": "\U0001d4c8",
-    "ssetmn;": "\u2216",
-    "ssmile;": "\u2323",
-    "sstarf;": "\u22c6",
-    "star;": "\u2606",
-    "starf;": "\u2605",
-    "straightepsilon;": "\u03f5",
-    "straightphi;": "\u03d5",
-    "strns;": "\xaf",
-    "sub;": "\u2282",
-    "subE;": "\u2ac5",
-    "subdot;": "\u2abd",
-    "sube;": "\u2286",
-    "subedot;": "\u2ac3",
-    "submult;": "\u2ac1",
-    "subnE;": "\u2acb",
-    "subne;": "\u228a",
-    "subplus;": "\u2abf",
-    "subrarr;": "\u2979",
-    "subset;": "\u2282",
-    "subseteq;": "\u2286",
-    "subseteqq;": "\u2ac5",
-    "subsetneq;": "\u228a",
-    "subsetneqq;": "\u2acb",
-    "subsim;": "\u2ac7",
-    "subsub;": "\u2ad5",
-    "subsup;": "\u2ad3",
-    "succ;": "\u227b",
-    "succapprox;": "\u2ab8",
-    "succcurlyeq;": "\u227d",
-    "succeq;": "\u2ab0",
-    "succnapprox;": "\u2aba",
-    "succneqq;": "\u2ab6",
-    "succnsim;": "\u22e9",
-    "succsim;": "\u227f",
-    "sum;": "\u2211",
-    "sung;": "\u266a",
-    "sup1": "\xb9",
-    "sup1;": "\xb9",
-    "sup2": "\xb2",
-    "sup2;": "\xb2",
-    "sup3": "\xb3",
-    "sup3;": "\xb3",
-    "sup;": "\u2283",
-    "supE;": "\u2ac6",
-    "supdot;": "\u2abe",
-    "supdsub;": "\u2ad8",
-    "supe;": "\u2287",
-    "supedot;": "\u2ac4",
-    "suphsol;": "\u27c9",
-    "suphsub;": "\u2ad7",
-    "suplarr;": "\u297b",
-    "supmult;": "\u2ac2",
-    "supnE;": "\u2acc",
-    "supne;": "\u228b",
-    "supplus;": "\u2ac0",
-    "supset;": "\u2283",
-    "supseteq;": "\u2287",
-    "supseteqq;": "\u2ac6",
-    "supsetneq;": "\u228b",
-    "supsetneqq;": "\u2acc",
-    "supsim;": "\u2ac8",
-    "supsub;": "\u2ad4",
-    "supsup;": "\u2ad6",
-    "swArr;": "\u21d9",
-    "swarhk;": "\u2926",
-    "swarr;": "\u2199",
-    "swarrow;": "\u2199",
-    "swnwar;": "\u292a",
-    "szlig": "\xdf",
-    "szlig;": "\xdf",
-    "target;": "\u2316",
-    "tau;": "\u03c4",
-    "tbrk;": "\u23b4",
-    "tcaron;": "\u0165",
-    "tcedil;": "\u0163",
-    "tcy;": "\u0442",
-    "tdot;": "\u20db",
-    "telrec;": "\u2315",
-    "tfr;": "\U0001d531",
-    "there4;": "\u2234",
-    "therefore;": "\u2234",
-    "theta;": "\u03b8",
-    "thetasym;": "\u03d1",
-    "thetav;": "\u03d1",
-    "thickapprox;": "\u2248",
-    "thicksim;": "\u223c",
-    "thinsp;": "\u2009",
-    "thkap;": "\u2248",
-    "thksim;": "\u223c",
-    "thorn": "\xfe",
-    "thorn;": "\xfe",
-    "tilde;": "\u02dc",
-    "times": "\xd7",
-    "times;": "\xd7",
-    "timesb;": "\u22a0",
-    "timesbar;": "\u2a31",
-    "timesd;": "\u2a30",
-    "tint;": "\u222d",
-    "toea;": "\u2928",
-    "top;": "\u22a4",
-    "topbot;": "\u2336",
-    "topcir;": "\u2af1",
-    "topf;": "\U0001d565",
-    "topfork;": "\u2ada",
-    "tosa;": "\u2929",
-    "tprime;": "\u2034",
-    "trade;": "\u2122",
-    "triangle;": "\u25b5",
-    "triangledown;": "\u25bf",
-    "triangleleft;": "\u25c3",
-    "trianglelefteq;": "\u22b4",
-    "triangleq;": "\u225c",
-    "triangleright;": "\u25b9",
-    "trianglerighteq;": "\u22b5",
-    "tridot;": "\u25ec",
-    "trie;": "\u225c",
-    "triminus;": "\u2a3a",
-    "triplus;": "\u2a39",
-    "trisb;": "\u29cd",
-    "tritime;": "\u2a3b",
-    "trpezium;": "\u23e2",
-    "tscr;": "\U0001d4c9",
-    "tscy;": "\u0446",
-    "tshcy;": "\u045b",
-    "tstrok;": "\u0167",
-    "twixt;": "\u226c",
-    "twoheadleftarrow;": "\u219e",
-    "twoheadrightarrow;": "\u21a0",
-    "uArr;": "\u21d1",
-    "uHar;": "\u2963",
-    "uacute": "\xfa",
-    "uacute;": "\xfa",
-    "uarr;": "\u2191",
-    "ubrcy;": "\u045e",
-    "ubreve;": "\u016d",
-    "ucirc": "\xfb",
-    "ucirc;": "\xfb",
-    "ucy;": "\u0443",
-    "udarr;": "\u21c5",
-    "udblac;": "\u0171",
-    "udhar;": "\u296e",
-    "ufisht;": "\u297e",
-    "ufr;": "\U0001d532",
-    "ugrave": "\xf9",
-    "ugrave;": "\xf9",
-    "uharl;": "\u21bf",
-    "uharr;": "\u21be",
-    "uhblk;": "\u2580",
-    "ulcorn;": "\u231c",
-    "ulcorner;": "\u231c",
-    "ulcrop;": "\u230f",
-    "ultri;": "\u25f8",
-    "umacr;": "\u016b",
-    "uml": "\xa8",
-    "uml;": "\xa8",
-    "uogon;": "\u0173",
-    "uopf;": "\U0001d566",
-    "uparrow;": "\u2191",
-    "updownarrow;": "\u2195",
-    "upharpoonleft;": "\u21bf",
-    "upharpoonright;": "\u21be",
-    "uplus;": "\u228e",
-    "upsi;": "\u03c5",
-    "upsih;": "\u03d2",
-    "upsilon;": "\u03c5",
-    "upuparrows;": "\u21c8",
-    "urcorn;": "\u231d",
-    "urcorner;": "\u231d",
-    "urcrop;": "\u230e",
-    "uring;": "\u016f",
-    "urtri;": "\u25f9",
-    "uscr;": "\U0001d4ca",
-    "utdot;": "\u22f0",
-    "utilde;": "\u0169",
-    "utri;": "\u25b5",
-    "utrif;": "\u25b4",
-    "uuarr;": "\u21c8",
-    "uuml": "\xfc",
-    "uuml;": "\xfc",
-    "uwangle;": "\u29a7",
-    "vArr;": "\u21d5",
-    "vBar;": "\u2ae8",
-    "vBarv;": "\u2ae9",
-    "vDash;": "\u22a8",
-    "vangrt;": "\u299c",
-    "varepsilon;": "\u03f5",
-    "varkappa;": "\u03f0",
-    "varnothing;": "\u2205",
-    "varphi;": "\u03d5",
-    "varpi;": "\u03d6",
-    "varpropto;": "\u221d",
-    "varr;": "\u2195",
-    "varrho;": "\u03f1",
-    "varsigma;": "\u03c2",
-    "varsubsetneq;": "\u228a\ufe00",
-    "varsubsetneqq;": "\u2acb\ufe00",
-    "varsupsetneq;": "\u228b\ufe00",
-    "varsupsetneqq;": "\u2acc\ufe00",
-    "vartheta;": "\u03d1",
-    "vartriangleleft;": "\u22b2",
-    "vartriangleright;": "\u22b3",
-    "vcy;": "\u0432",
-    "vdash;": "\u22a2",
-    "vee;": "\u2228",
-    "veebar;": "\u22bb",
-    "veeeq;": "\u225a",
-    "vellip;": "\u22ee",
-    "verbar;": "|",
-    "vert;": "|",
-    "vfr;": "\U0001d533",
-    "vltri;": "\u22b2",
-    "vnsub;": "\u2282\u20d2",
-    "vnsup;": "\u2283\u20d2",
-    "vopf;": "\U0001d567",
-    "vprop;": "\u221d",
-    "vrtri;": "\u22b3",
-    "vscr;": "\U0001d4cb",
-    "vsubnE;": "\u2acb\ufe00",
-    "vsubne;": "\u228a\ufe00",
-    "vsupnE;": "\u2acc\ufe00",
-    "vsupne;": "\u228b\ufe00",
-    "vzigzag;": "\u299a",
-    "wcirc;": "\u0175",
-    "wedbar;": "\u2a5f",
-    "wedge;": "\u2227",
-    "wedgeq;": "\u2259",
-    "weierp;": "\u2118",
-    "wfr;": "\U0001d534",
-    "wopf;": "\U0001d568",
-    "wp;": "\u2118",
-    "wr;": "\u2240",
-    "wreath;": "\u2240",
-    "wscr;": "\U0001d4cc",
-    "xcap;": "\u22c2",
-    "xcirc;": "\u25ef",
-    "xcup;": "\u22c3",
-    "xdtri;": "\u25bd",
-    "xfr;": "\U0001d535",
-    "xhArr;": "\u27fa",
-    "xharr;": "\u27f7",
-    "xi;": "\u03be",
-    "xlArr;": "\u27f8",
-    "xlarr;": "\u27f5",
-    "xmap;": "\u27fc",
-    "xnis;": "\u22fb",
-    "xodot;": "\u2a00",
-    "xopf;": "\U0001d569",
-    "xoplus;": "\u2a01",
-    "xotime;": "\u2a02",
-    "xrArr;": "\u27f9",
-    "xrarr;": "\u27f6",
-    "xscr;": "\U0001d4cd",
-    "xsqcup;": "\u2a06",
-    "xuplus;": "\u2a04",
-    "xutri;": "\u25b3",
-    "xvee;": "\u22c1",
-    "xwedge;": "\u22c0",
-    "yacute": "\xfd",
-    "yacute;": "\xfd",
-    "yacy;": "\u044f",
-    "ycirc;": "\u0177",
-    "ycy;": "\u044b",
-    "yen": "\xa5",
-    "yen;": "\xa5",
-    "yfr;": "\U0001d536",
-    "yicy;": "\u0457",
-    "yopf;": "\U0001d56a",
-    "yscr;": "\U0001d4ce",
-    "yucy;": "\u044e",
-    "yuml": "\xff",
-    "yuml;": "\xff",
-    "zacute;": "\u017a",
-    "zcaron;": "\u017e",
-    "zcy;": "\u0437",
-    "zdot;": "\u017c",
-    "zeetrf;": "\u2128",
-    "zeta;": "\u03b6",
-    "zfr;": "\U0001d537",
-    "zhcy;": "\u0436",
-    "zigrarr;": "\u21dd",
-    "zopf;": "\U0001d56b",
-    "zscr;": "\U0001d4cf",
-    "zwj;": "\u200d",
-    "zwnj;": "\u200c",
-}
-
-replacementCharacters = {
-    0x0: "\uFFFD",
-    0x0d: "\u000D",
-    0x80: "\u20AC",
-    0x81: "\u0081",
-    0x82: "\u201A",
-    0x83: "\u0192",
-    0x84: "\u201E",
-    0x85: "\u2026",
-    0x86: "\u2020",
-    0x87: "\u2021",
-    0x88: "\u02C6",
-    0x89: "\u2030",
-    0x8A: "\u0160",
-    0x8B: "\u2039",
-    0x8C: "\u0152",
-    0x8D: "\u008D",
-    0x8E: "\u017D",
-    0x8F: "\u008F",
-    0x90: "\u0090",
-    0x91: "\u2018",
-    0x92: "\u2019",
-    0x93: "\u201C",
-    0x94: "\u201D",
-    0x95: "\u2022",
-    0x96: "\u2013",
-    0x97: "\u2014",
-    0x98: "\u02DC",
-    0x99: "\u2122",
-    0x9A: "\u0161",
-    0x9B: "\u203A",
-    0x9C: "\u0153",
-    0x9D: "\u009D",
-    0x9E: "\u017E",
-    0x9F: "\u0178",
-}
-
-tokenTypes = {
-    "Doctype": 0,
-    "Characters": 1,
-    "SpaceCharacters": 2,
-    "StartTag": 3,
-    "EndTag": 4,
-    "EmptyTag": 5,
-    "Comment": 6,
-    "ParseError": 7
-}
-
-tagTokenTypes = frozenset([tokenTypes["StartTag"], tokenTypes["EndTag"],
-                           tokenTypes["EmptyTag"]])
-
-
-prefixes = {v: k for k, v in namespaces.items()}
-prefixes["http://www.w3.org/1998/Math/MathML"] = "math"
-
-
-class DataLossWarning(UserWarning):
-    """Raised when the current tree is unable to represent the input data"""
-    pass
-
-
-class _ReparseException(Exception):
-    pass
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 718e2e70bf2ce8b5ef9d1e61de9428309aebca01..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 228
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>U6e>
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk
yFVfE_$;~m%$xPBu%giZBEh^TJkI&4@EQycTE2zB1VUwGmQks)$2Xf+PkXHcO;ywZZ

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/alphabeticalattributes.cpython-39.pyc
deleted file mode 100644
index c2b49c9b2310db18662b205f1b6983c0b05a1c48..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1350
zcmYe~<>g{vU|^UdaWHi{GXuk85C<8vFfcGUFfcF_doeIDq%fo~<}l<kMlt3xMKR?v
zM=>)pq%fs0=dk3mMzJ!2<XLjqa@nKU85vSoQ`lM<qBz_cQrJ^CS{PC|QdzS&o0+3H
zQ#gYeG`U`aY|&)C#h;i|oS#!#k{X|xTaaH=a*HD+vn;bXGe7T^KxtlPa(+r`d`@Ob
zYEfcN@k>Sq1_n*WTP#V5#i^Q%x48X_Qc{ajQ(Q8WOOioyATvQ2#Aaq-U~mSxT!w*x
zp@t!aQ4)*`_)?glJZ4FTG^St%O_r*kL8&FBMR^K|c?yXI1x5J<MVW~usS4Stl?rM3
zMPT8QlA_F{(vnoLKyiLiNoHO;7ng#9f`TJVs#qZ-u`E>~Q6VoeH?_DRF*#MCBqOmz
zAvrNmAt_ZMHM1lmwMZc$!7o2AH6cL(WUxYUNl|8Ax}HLKD%h;##60y9h2;F)g2W<_
z?o@@6@_dD))a1m{Vlcl_y(m>7B{MB8wJ0^OM4_azAhlRWp*UZmJXIk%Kd&scs03^f
z+?JAjkn>Y>3rZ@XmMNrV78RH1K^$KM3aVQSMXU@A3@gE5n^;m(RK&@^zyKzGO?S46
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk
zFVfE_$;~m%$xPBu%giZBEh^Se%qhr7OiC@uOis)JxeOc!#d-ymw>aZL{P^tDN)Avg
zGlAlrqlkxrfgu^hM8+UFa3YpqU|>jPh+<4(h+;}%jA8~Q-WG-^mK2s?22IvmY;Is%
zt5h6ewpOJUD}bzlSPPE()ST4Z)Vz{nlmrI~J`e_3T^z%}z)-@F#khc}hG8M23q!0|
zEn^KMH~})1F%$)qFgG*QGL^8@Fs3j|GAv+S$WX$T!qUs+!VoJE!&J*$%TmKq!&Jj;
z!%%2e!vs=g!%)K*#=yu>$dkeVa;e`f7EsJ<GTq_`E=epZ2}w-9#o-EyV-SlaC9xz?
zlkpaFc50<2dl4HbE_oRk7;bUI$AfZGe0&i*h|2~_#;GZ{STjpfbBn=2r^$MYr8qSw
z?G|fEes*f!Emn}{i*K=jQuHm>vc#OyRB*C@5ZoY>g&7zaL_ski1PXFS0Y)B1Hbx#s
zrvH3QT#OuyRs4`Z)q~mXr^yO(2*||v_*-1@@wxdar8%kb@wa&5;|og@bD%Qp@$o77
z$?@?;APXS&!Bb@s*k+KQK$69vLW+Ztg|P@E;-|?4GBvHVq_ikCKE4PP`9+|@pa`U_
z2$WdBL2`>bIX@>SHMt}+Kd%@ZAm9)Hn}N-`TO2kJm)e1{OfkqD5hflc9%c@10PFQ&
AO8@`>

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index 237ff0f2f9385e15be45cdab5c341becd497d6ac..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 898
zcmYe~<>g{vU|^UdaWGYmk%8ech=Yt-7#J8F7#J9eH5eEeQW#Pga~N_NqZo6UqL^}-
zqnH^P+!<1sQkYv9QkYX&nwg_mQ&@r-G+AGQ%+O@M#h;i|oS#!#k{X|xTaaH=a*HD+
zvn;bXGe7T^KxtlPa(+r`d`@ObYEfcNaWY5`GG>C=t-`>-kjfCnn8Fanl){+8)WQ(O
zoWh*K(!vnMlERw8*1{0Qn!+B;pviHI%`G#hB(*3Rq!(ruhz-KdAb)_oTf<nx5YLdp
z5X`WW(NB}{7F%(CX;E^jCetmJ;?$h9B6bD_hLsFOoD2*MzgnHGVnT~ki;81Xb5b&k
zV*K+`U5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYs
zbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9B{N^)~db25|k
z)4<*+)=x?-PSq=@yu}e8pP83g5+BbB@&w2?42)I$5YOtt<dPX-US?om0I@;p;Jz+l
zsA0%rY-S8*C}Lw^U;z0R6!Ku-YBCmaFfc&84EA>sD4f8ymZTQN$Act`L8hVF3YNnN
zYi0%p2C%I>3=9kqTWc7bnGp7}r>B-AmXs7htY!jReTyY8F*g-rHz&v`U<Yu=$3xY|
z$8#h3TnO%SxU`=p8_2yNQ{v-qamB~y=BJeAq{heJ;)#zhEKSUT$P|H$DdGj$AOIr3
zb|DCmtwo?P1||GrP&jcgaxil+gT+8raK*=`m6ntirN+k>fdZrm<l7>U>RW92Nm;4M
bC19mU9swH;GWQmT4a7}$ptu1CrwB6up<Ks;

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/inject_meta_charset.cpython-39.pyc
deleted file mode 100644
index cdbe4c7f8665fa6279cfcbffcbe17c0d1a25e0b8..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1904
zcmYe~<>g{vU|^UdaWJ)!n}Ojmh=Yt-7#J8F7#J9e%@`OMQW#Pga~N_NqZo6UqL^}-
zqnH^PQkYVhb69d&qgWXk+!<0>QdnCUQdm=2v)G!Mqu5f|f*CZ~UxG~3WWL3pm{gpf
zQ(BT5pP5^bUsQ67BPFvevp6$9@0LJmUS@KBN@{#gW=U#MVovc(Mg|53O~zX+Nr}a&
z$shxeF%!&L3JeSksSHt!DGX6eDU4CfAm_9&M6o~|62%H}z%4en%$$<cqAFX@ysXsZ
zl46B~1e@H{l0=2%jKrei)Dl})KWBdzPd|6Ngan0>#B_zsypnu{jMT&wh5R&yl>Fq<
z+|<01WM(8cfY_kWaR!Bs1Oo#@2}2g+0;U><8pef8j0`nQH4O30DU87knoLzC&PAz-
zC8@;<i3$*haB(R>fmLErx<YY&X;E^jl|o5IDwM5IlAoQLr%+r{l$w}}raCn*IX@*c
zFCC&D##1QCS13*`L8$f9WGP}}U|=X>XJBBs#StH$nU`4-AAgGjrbCnY7E5tzPTDOt
zi2X&J3=9k_8H#uq7#My{akh#HElw>ej!Df)$t;TT&r5YF$}CG&&{YWa^9*wh3ib?f
z3|8>;bMg0c4fb@533l~$4GwV)QZS1N2=IwXG||n;PtPna$;^&P%`1!X$xMnV&MZmQ
zEl5nxPE1cNjw#42(2p-m%}dEI($6T#%`wf%OwvyS$5XL>CODqrL2(ohjU&B+$|4R1
z1_lr=28BEW2Onb<KO{i)VBSjxr5ji@fzmc82tetl_!1)nLkeRpV+}(VLkdGFLoHJ}
zLoIU&V;0i_<{E~Dj4lil7-QGevedAoFiA4hvevMsFlRFr`P8taut+j2U|GnJ!kW!g
z<dMQw%Q%5CFQtYxg*}^T0%MUEk_wJ&rlKDyoV9E<EGb-)3=3EnGPp3rM#M11Fx9fx
za@2Cxu%|GTG8Xj}mKB!OaDYwa&Somw267cdPYrtwM;en2LkdqV6C*?6H;}p%-fX6#
zvKmgXdOi?4g{PLSu&joy=vxXuL|++0(YF)<kU3%u5Rnvqh$(piNG@aryLm$m(*(xi
z4JphitWdRrbC|;z7#UL7Q#ewDK&E6erohC6Q&>|(<}iWfd1{#o<?_;MSW|?dCZUAS
z1jeEbHOvrl0b7dbLPn4-ux*pDnGIIEqJ|lvb^>GJB#_@z#A+F97*p85wj8TrUcg?%
zvXGIHp-`@d1!QKSTna-lgQmD&6h}c(YCI^j-eM`KEJ(e@5nPg3R1%Vyev2h9F*o%V
z3rH@CJu?rYh{H9vprjHk4N6~bw^&jVOA>FfL(^GE6<0<{Nr7%^VQFSr6;E=0UP)?R
zi7v=wO(wrv>`;L!(UR1P5^&13h8H8M#hT1Te4tDx03t*{Wf+rRktiq!vbpA^ge0bG
zG9f7dCDtg;g8bqVu+ua-z<CfY+m@sj#mC=b&B-rMExN^;S(2Jte2cjtzu*>IVnIP_
zUWz7H5h$VGVl6I7EJ=;x0(mMvEx$A`<rX_gJ~J=<7Av?s0oxoUosn1^5AtF>*o*N{
z55<Fgc#9JhV#NiC$*DykFWh1+OUx-v1(yjBf*0g5P<bZ|D){0+S&fl}k&BUqNr;hy
zk%Liyk%NhgQGkhsQG$_!k%f_mQHYU+k&RJ=k&Q`!QHYU^NrH)mk?lVR6AL59e-0)d
zMixdECN4$^CLTsMMu-?2qX1NthY2}{gG0hklMPgwf!rA%e~T+VJ~uz5G$%Da{uWPs
zd|_!~4pfFcK0YNsIX)g-XcU254DkS{c!RLOUICSkpfaKuM1UO3!3{1k{WRG@hNqR5
tloqAN#}|RBoFY)6Uj!<9ZZRMt31S$kv9~yEAkMM_MKQRz5@F(D1^^vF=Ai%p

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/lint.cpython-39.pyc
deleted file mode 100644
index 746c84a71069f3a21ac8990b00eb8980f522a672..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/optionaltags.cpython-39.pyc
deleted file mode 100644
index 97f1209672b7a0a158cbf078c5fbe40d3f56c5f0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2791
zcmYe~<>g{vU|^UdaWFMTlY!weh=Yt-7#J8F7#J9e%@`OMQW#Pga~N_NqZo6UqL^}-
zqnH^PQkYVhb69d&qgWXk+!<0>QdnCUQdm=2v)G!Mqu5f|f*CZ~UxG~3WWL3pm{gpf
zQ(BT5pP5^bUsQ67BPFvevp6$9@0LJmUS@KBN@{#gW=U#MVovc(Mg|53O~zX+Nr}a&
z$shxeF%!&L1`G@gsSHt!DGX6eDU4CfAm_9&M6o~|62+Rrmcrh`5XF|lk;2)+5XGLt
z70jT?eT&U4Gp8iAs7gC1H8;O3wOAp)pd>RtFEK}<Br&~MA+0DsSD_>$RiPw5J2g+C
zxTGjGF*h0HBA6pU;R3=Smlb<}!-j>Sma&$ph9Qf=g&|g<mbr#8g`t$ONUeschOve@
zjX8{gk)Z~pg1MHlkPj;B0+LN(fXJpW1T$zd`e`!WVk^!sElN(+WVyvsoSKss#aU34
zT9%n#T5O158r@<AJ8vaJ5jO(^!>?XvtC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1w
zFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJt
zq?qE&l2qM-#N_P6^wi>*g3JQ___EZzl>8$7jFQ|O)11sC{WNe$7VE=85EOuV1(mnh
zigPkkQj0i1iAMkwY>XU?T#OuyJd7-iY>XU?RlJZm(1WN$30+nO1_m|;1_p5G7BDa{
z)G#bySO^N&q!?yUDAzLAFr_d`GSsrvu%s|$GZneiFr_d{G8Eg?Ff3rKVM<|<WB`Tw
zLgwPE8YWQ47jo3Fq_Ac)6{XZLEMS7FU|z_CBo9>wjs-TqTP!7&1*x|<f=d#MN<tFT
zZ?U8#mL%R{$xF;ly~XC5mlBeguE|`)%fP^JOE9xI9_Ih}VvvSg{K!J7c`2H#MVug|
z9I%)y0%g2gEP1IFB}IG;43J0!$7B%?SYdoTC@aLr3xPsV3><<&j2vJn@SlkZ#1dfS
zV5;JWh9gXUGALbwl!GuRBte<Q8Dz*kP)ITt@zgMb!mfZX1r&aaDNJPyMG7@6Da>Vz
z!3;HwDJ<DcMP8uLDq|=z0p;KtmK64ErlMOl%qbj_3?TVnhP(+ij47PiOhpx7oeV{B
zpsZEHlER(MR8$02$pbPGWI|q24Py##HdE0osJT<1D)_RQf*C+M^BigzQ~1HQK+L#S
z!&Gz%63bxQL2Qui0%Z(Er$9QOCJ4ez0EuY|`GEuT77HkSu4KB!?wp^So0?a0i$Ay^
zF*(&aBe5tkxg@oy_!dh>YGTStrXqfDV7ulPlvIW!riT=Pg1bl%B*>DKpHk@tR-nmr
zi>)}hD6^pC7He@yWlriXj^zBD^rHOIf?LeV`8l^(OF)V>nTu3FI$29VhTmc>Nz2bK
zxy4jc1ddl&5@0V$Ob4Z+B2iGZgJKr!X0RFv0ZITx!VC-y@}Ot~6}=3M0*oBY9E=<+
z9E>cC9E^O79Bg0~3l9?;BL^!7jAj;K<oeIV#KOqK#KKr50Zkjoi4mMWlbJ!O1ByWj
z2A)V5m>3vpn2LBHK@UzOprQ<tNSG0cq>P~`poSTorEF@LQrJKl4iptN%%JEh@Ty@>
zVJKw?W|+X3x2A?Mg`<q2s0XS(2cjM%22OCGWYhxH*96lCip~j)c?C6$;3T!DhB<|&
zjG<@+R4;ECLofqW&o-Ez35?)m#Fx!f^ag6z4XAp4B=ygb)C<%wrU;ZVOkgZhfasXO
z2=+UhBm+nsX2%4^0vVXDygN0FDT3Kd6Bvs^YCs_Z(rp29FWdw_sI7w8%)tyPLct7q
zD{2^1gu(VqgR3fmsuBUajWI<OY~}=ruO=`S^ucTdnVpwb!<ZrlR&fe$!ZxT0qKJ^6
zz*uk$rZ3N^hA~APZ0jGmo>x#k;$U0Bu{D9Q;1^5}$SzF@NH)@BE|LJHQ5g^cN{dC3
zpjw&v7E?~<Esp$x5^xSEQU^(c@)0=SfOC*0(=Dcyl3PqEDMdOA3=D3!7z>JIL3(9w
zu_vaa6r~my-(pWJD#=XFNxj9ISe%)XdW$P5CqFs6ur$9U^%e)HuuU(@Ou5CDl9`y3
zpMHxuC9?=bl-*)V$+^XmmYJH9Qk+_Hiw%^=Qj2b}q~#ao-eSryyv3AZbc-p&_!d)!
z$t|V~(_2g#X1CZt88Wr#7E?yiEtcHWywY3Dd5LAWnDTRqbU`_mxu7WZ7JG4OGN>7F
zi?t*%DJS(7Q)$jEHb}Xy$yDSC@}(BY4@|e1ib`%V6%`aIF)%QMXfhS4g5*G1Uy})3
z0u-si1i&m%Xq2SfVk*f1=Wk6Ga9vQO0aAoB|BEm%Fhqdze+(#_!ty^C2O|%Y2sroi
zFmf;ofa(Eu4n`h!s2Gz7BNsatSPd5o7b6QJ7c;1Y;Ns?D<YDAu6k=jy<YI%$gVhN!
zR*7LLB~tTJ{4_akam2@iimLedTU_z+x%nxjIjQmSw|L^?3riDopfc?7@hSPq@$ulg
zut*%_DNxx}1o8mbzeohQWMhX`@5P`h5L}9Jaqx0j7J<b5G}%E`rInVH7Ny3=7lF#9
pB2Zyf1S+L&F%*H?1z?p(rh?i(&|1?5;z&DCW33pZMTCim831p`q6Po}

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/sanitizer.cpython-39.pyc
deleted file mode 100644
index 022692f3c500ebfdf162965f9026031a50e7d8be..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 16914
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
Z0WLl+AudBMEiP^@DK0J!ZkDesd;kW?^cesE

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/filters/__pycache__/whitespace.cpython-39.pyc
deleted file mode 100644
index 9758153889e21c84531717e3fdf67b592ef860de..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1396
zcmYe~<>g{vU|^UdaWHis3j@Pr5C<8vFfcGUFfcF_=P@uaq%fo~<}l<kMlt3xMKR?v
zM=>*k#F%neqF7RxQ&@6XbJ?QU7#UJnQ`mCYb2*|oayg?o85vU87jUI=E@X`2Ol4WX
zox+jIDaNpnF^b2XA%!!AtA!zjE0ryax0yMLH-$Ter-dPkFNG<XL6i3-$R(Q0xA+s2
zit}?yOH$)Aa|`l|N^WtaWR_(XXXfYK5-82fOwLb9jnBy}Ni9muDfWBG$iTp$$#{z;
zDX}>9B@>9lbc?SjIVG_q(KRPEH#M)M_!fV0L1J>Mb4FrOVsc4pQSmK?D%NP#;#lou
zkd??79soKF3=F9ZQH&`JQA{a}QOv0<DNHHM=}f7tscg-R;tb7<QS2!!DXc9FQ5-33
z!3>)0x7ge=b4pT+svMp3b8-?3ic^af$}=)cQo)uhq*f%S7L+Jt<|z~urRpe@q*jz9
z7NsWYC?w{kC=@3bWfqhuq{1A`Tu_vHivy-68RSQpD?u&<VUW{{=YXP#v6iufA&YSV
zQw_sHMi++IwpykdrW7VghFazt<`m{^rXq(L#$vM?rW6)Qh8l(}<}wD5ND8YtLoH)o
zKn-&WTQ*ZsSPdfxr?6UpM6GHVi%V*lQ`obaib`sjQaB_Tib_&AK`a}FJeeBC;t4g(
zDO}l1MH5O`K%$Zi&5R)0hM|TjjDeA%P#}dNm_d`<uL$J$TP!7&1*x|<f=d#MN<tFT
zZ?WVh=B5_0GB7aQVsp()0SWO3qeT)6C=P!yD%|2i#GEE;5gP*oLlHMfCr5ldC>g}Z
z-x39faX?XOacWUnDk9#Kp)nB;mM_+1xy4ePnv-^mqX4S(7Hdg<c4}S`9|Hr!N`@jC
z1_p*--Og4qp~b01#WATlDVaqv{&}e`MVV!(3c3oRex6~jLBXCOj=>6^elGrguECy;
zF~P3BuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$
z1^V%2sd*{+Mfw>fxjCjenMwL-;M7yBk4Q6m1(ii&3=9kcpd6_HN&t*3i~@`tj2w(i
z|Ctzh{xdOgG4U{RF^Pa_0j4T`ND|b81&p62=Pi!-cu-)+$KT?LkI&6dDa}cZkH5te
zA75CSm;;qzkB?8uPmYhj#hF%=UzM6yoLX{=B`34Eq=*9)+TtJr<PvZIArZ152~b?{
zfSd@584gAkMiC}({GcRTP$~c=TW63$km?eK1&k?-H4F<ud7sIzNCc8~d4dBRon3?D
zgIwKRBW^JlmnMNSHz+5dTPwl9z@Q2;4V38_7>huBO@5Fk(@IN9i&Ep`i$F3(%pf;{
ztiHumlv)HT|G-J;7H4vPUU5lcUP&>;lboO=#gdhunRkmlIX|}`Gbgo31*8|`Kd|XY
mE&wHzB9QNIao9k@)DGmsVo*8~Vd7xoVH9BGV&Y>Kk^}%{M`Vux

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py
deleted file mode 100644
index 5ba926e3..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/alphabeticalattributes.py
+++ /dev/null
@@ -1,29 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from . import base
-
-from collections import OrderedDict
-
-
-def _attr_key(attr):
-    """Return an appropriate key for an attribute for sorting
-
-    Attributes have a namespace that can be either ``None`` or a string. We
-    can't compare the two because they're different types, so we convert
-    ``None`` to an empty string first.
-
-    """
-    return (attr[0][0] or ''), attr[0][1]
-
-
-class Filter(base.Filter):
-    """Alphabetizes attributes for elements"""
-    def __iter__(self):
-        for token in base.Filter.__iter__(self):
-            if token["type"] in ("StartTag", "EmptyTag"):
-                attrs = OrderedDict()
-                for name, value in sorted(token["data"].items(),
-                                          key=_attr_key):
-                    attrs[name] = value
-                token["data"] = attrs
-            yield token
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py
deleted file mode 100644
index c7dbaed0..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/base.py
+++ /dev/null
@@ -1,12 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-
-class Filter(object):
-    def __init__(self, source):
-        self.source = source
-
-    def __iter__(self):
-        return iter(self.source)
-
-    def __getattr__(self, name):
-        return getattr(self.source, name)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py
deleted file mode 100644
index aefb5c84..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/inject_meta_charset.py
+++ /dev/null
@@ -1,73 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from . import base
-
-
-class Filter(base.Filter):
-    """Injects ``<meta charset=ENCODING>`` tag into head of document"""
-    def __init__(self, source, encoding):
-        """Creates a Filter
-
-        :arg source: the source token stream
-
-        :arg encoding: the encoding to set
-
-        """
-        base.Filter.__init__(self, source)
-        self.encoding = encoding
-
-    def __iter__(self):
-        state = "pre_head"
-        meta_found = (self.encoding is None)
-        pending = []
-
-        for token in base.Filter.__iter__(self):
-            type = token["type"]
-            if type == "StartTag":
-                if token["name"].lower() == "head":
-                    state = "in_head"
-
-            elif type == "EmptyTag":
-                if token["name"].lower() == "meta":
-                    # replace charset with actual encoding
-                    has_http_equiv_content_type = False
-                    for (namespace, name), value in token["data"].items():
-                        if namespace is not None:
-                            continue
-                        elif name.lower() == 'charset':
-                            token["data"][(namespace, name)] = self.encoding
-                            meta_found = True
-                            break
-                        elif name == 'http-equiv' and value.lower() == 'content-type':
-                            has_http_equiv_content_type = True
-                    else:
-                        if has_http_equiv_content_type and (None, "content") in token["data"]:
-                            token["data"][(None, "content")] = 'text/html; charset=%s' % self.encoding
-                            meta_found = True
-
-                elif token["name"].lower() == "head" and not meta_found:
-                    # insert meta into empty head
-                    yield {"type": "StartTag", "name": "head",
-                           "data": token["data"]}
-                    yield {"type": "EmptyTag", "name": "meta",
-                           "data": {(None, "charset"): self.encoding}}
-                    yield {"type": "EndTag", "name": "head"}
-                    meta_found = True
-                    continue
-
-            elif type == "EndTag":
-                if token["name"].lower() == "head" and pending:
-                    # insert meta into head (if necessary) and flush pending queue
-                    yield pending.pop(0)
-                    if not meta_found:
-                        yield {"type": "EmptyTag", "name": "meta",
-                               "data": {(None, "charset"): self.encoding}}
-                    while pending:
-                        yield pending.pop(0)
-                    meta_found = True
-                    state = "post_head"
-
-            if state == "in_head":
-                pending.append(token)
-            else:
-                yield token
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py
deleted file mode 100644
index fcc07eec..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/lint.py
+++ /dev/null
@@ -1,93 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from pip._vendor.six import text_type
-
-from . import base
-from ..constants import namespaces, voidElements
-
-from ..constants import spaceCharacters
-spaceCharacters = "".join(spaceCharacters)
-
-
-class Filter(base.Filter):
-    """Lints the token stream for errors
-
-    If it finds any errors, it'll raise an ``AssertionError``.
-
-    """
-    def __init__(self, source, require_matching_tags=True):
-        """Creates a Filter
-
-        :arg source: the source token stream
-
-        :arg require_matching_tags: whether or not to require matching tags
-
-        """
-        super(Filter, self).__init__(source)
-        self.require_matching_tags = require_matching_tags
-
-    def __iter__(self):
-        open_elements = []
-        for token in base.Filter.__iter__(self):
-            type = token["type"]
-            if type in ("StartTag", "EmptyTag"):
-                namespace = token["namespace"]
-                name = token["name"]
-                assert namespace is None or isinstance(namespace, text_type)
-                assert namespace != ""
-                assert isinstance(name, text_type)
-                assert name != ""
-                assert isinstance(token["data"], dict)
-                if (not namespace or namespace == namespaces["html"]) and name in voidElements:
-                    assert type == "EmptyTag"
-                else:
-                    assert type == "StartTag"
-                if type == "StartTag" and self.require_matching_tags:
-                    open_elements.append((namespace, name))
-                for (namespace, name), value in token["data"].items():
-                    assert namespace is None or isinstance(namespace, text_type)
-                    assert namespace != ""
-                    assert isinstance(name, text_type)
-                    assert name != ""
-                    assert isinstance(value, text_type)
-
-            elif type == "EndTag":
-                namespace = token["namespace"]
-                name = token["name"]
-                assert namespace is None or isinstance(namespace, text_type)
-                assert namespace != ""
-                assert isinstance(name, text_type)
-                assert name != ""
-                if (not namespace or namespace == namespaces["html"]) and name in voidElements:
-                    assert False, "Void element reported as EndTag token: %(tag)s" % {"tag": name}
-                elif self.require_matching_tags:
-                    start = open_elements.pop()
-                    assert start == (namespace, name)
-
-            elif type == "Comment":
-                data = token["data"]
-                assert isinstance(data, text_type)
-
-            elif type in ("Characters", "SpaceCharacters"):
-                data = token["data"]
-                assert isinstance(data, text_type)
-                assert data != ""
-                if type == "SpaceCharacters":
-                    assert data.strip(spaceCharacters) == ""
-
-            elif type == "Doctype":
-                name = token["name"]
-                assert name is None or isinstance(name, text_type)
-                assert token["publicId"] is None or isinstance(name, text_type)
-                assert token["systemId"] is None or isinstance(name, text_type)
-
-            elif type == "Entity":
-                assert isinstance(token["name"], text_type)
-
-            elif type == "SerializerError":
-                assert isinstance(token["data"], text_type)
-
-            else:
-                assert False, "Unknown token type: %(type)s" % {"type": type}
-
-            yield token
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py
deleted file mode 100644
index 4a865012..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/optionaltags.py
+++ /dev/null
@@ -1,207 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from . import base
-
-
-class Filter(base.Filter):
-    """Removes optional tags from the token stream"""
-    def slider(self):
-        previous1 = previous2 = None
-        for token in self.source:
-            if previous1 is not None:
-                yield previous2, previous1, token
-            previous2 = previous1
-            previous1 = token
-        if previous1 is not None:
-            yield previous2, previous1, None
-
-    def __iter__(self):
-        for previous, token, next in self.slider():
-            type = token["type"]
-            if type == "StartTag":
-                if (token["data"] or
-                        not self.is_optional_start(token["name"], previous, next)):
-                    yield token
-            elif type == "EndTag":
-                if not self.is_optional_end(token["name"], next):
-                    yield token
-            else:
-                yield token
-
-    def is_optional_start(self, tagname, previous, next):
-        type = next and next["type"] or None
-        if tagname in 'html':
-            # An html element's start tag may be omitted if the first thing
-            # inside the html element is not a space character or a comment.
-            return type not in ("Comment", "SpaceCharacters")
-        elif tagname == 'head':
-            # A head element's start tag may be omitted if the first thing
-            # inside the head element is an element.
-            # XXX: we also omit the start tag if the head element is empty
-            if type in ("StartTag", "EmptyTag"):
-                return True
-            elif type == "EndTag":
-                return next["name"] == "head"
-        elif tagname == 'body':
-            # A body element's start tag may be omitted if the first thing
-            # inside the body element is not a space character or a comment,
-            # except if the first thing inside the body element is a script
-            # or style element and the node immediately preceding the body
-            # element is a head element whose end tag has been omitted.
-            if type in ("Comment", "SpaceCharacters"):
-                return False
-            elif type == "StartTag":
-                # XXX: we do not look at the preceding event, so we never omit
-                # the body element's start tag if it's followed by a script or
-                # a style element.
-                return next["name"] not in ('script', 'style')
-            else:
-                return True
-        elif tagname == 'colgroup':
-            # A colgroup element's start tag may be omitted if the first thing
-            # inside the colgroup element is a col element, and if the element
-            # is not immediately preceded by another colgroup element whose
-            # end tag has been omitted.
-            if type in ("StartTag", "EmptyTag"):
-                # XXX: we do not look at the preceding event, so instead we never
-                # omit the colgroup element's end tag when it is immediately
-                # followed by another colgroup element. See is_optional_end.
-                return next["name"] == "col"
-            else:
-                return False
-        elif tagname == 'tbody':
-            # A tbody element's start tag may be omitted if the first thing
-            # inside the tbody element is a tr element, and if the element is
-            # not immediately preceded by a tbody, thead, or tfoot element
-            # whose end tag has been omitted.
-            if type == "StartTag":
-                # omit the thead and tfoot elements' end tag when they are
-                # immediately followed by a tbody element. See is_optional_end.
-                if previous and previous['type'] == 'EndTag' and \
-                        previous['name'] in ('tbody', 'thead', 'tfoot'):
-                    return False
-                return next["name"] == 'tr'
-            else:
-                return False
-        return False
-
-    def is_optional_end(self, tagname, next):
-        type = next and next["type"] or None
-        if tagname in ('html', 'head', 'body'):
-            # An html element's end tag may be omitted if the html element
-            # is not immediately followed by a space character or a comment.
-            return type not in ("Comment", "SpaceCharacters")
-        elif tagname in ('li', 'optgroup', 'tr'):
-            # A li element's end tag may be omitted if the li element is
-            # immediately followed by another li element or if there is
-            # no more content in the parent element.
-            # An optgroup element's end tag may be omitted if the optgroup
-            # element is immediately followed by another optgroup element,
-            # or if there is no more content in the parent element.
-            # A tr element's end tag may be omitted if the tr element is
-            # immediately followed by another tr element, or if there is
-            # no more content in the parent element.
-            if type == "StartTag":
-                return next["name"] == tagname
-            else:
-                return type == "EndTag" or type is None
-        elif tagname in ('dt', 'dd'):
-            # A dt element's end tag may be omitted if the dt element is
-            # immediately followed by another dt element or a dd element.
-            # A dd element's end tag may be omitted if the dd element is
-            # immediately followed by another dd element or a dt element,
-            # or if there is no more content in the parent element.
-            if type == "StartTag":
-                return next["name"] in ('dt', 'dd')
-            elif tagname == 'dd':
-                return type == "EndTag" or type is None
-            else:
-                return False
-        elif tagname == 'p':
-            # A p element's end tag may be omitted if the p element is
-            # immediately followed by an address, article, aside,
-            # blockquote, datagrid, dialog, dir, div, dl, fieldset,
-            # footer, form, h1, h2, h3, h4, h5, h6, header, hr, menu,
-            # nav, ol, p, pre, section, table, or ul, element, or if
-            # there is no more content in the parent element.
-            if type in ("StartTag", "EmptyTag"):
-                return next["name"] in ('address', 'article', 'aside',
-                                        'blockquote', 'datagrid', 'dialog',
-                                        'dir', 'div', 'dl', 'fieldset', 'footer',
-                                        'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6',
-                                        'header', 'hr', 'menu', 'nav', 'ol',
-                                        'p', 'pre', 'section', 'table', 'ul')
-            else:
-                return type == "EndTag" or type is None
-        elif tagname == 'option':
-            # An option element's end tag may be omitted if the option
-            # element is immediately followed by another option element,
-            # or if it is immediately followed by an <code>optgroup</code>
-            # element, or if there is no more content in the parent
-            # element.
-            if type == "StartTag":
-                return next["name"] in ('option', 'optgroup')
-            else:
-                return type == "EndTag" or type is None
-        elif tagname in ('rt', 'rp'):
-            # An rt element's end tag may be omitted if the rt element is
-            # immediately followed by an rt or rp element, or if there is
-            # no more content in the parent element.
-            # An rp element's end tag may be omitted if the rp element is
-            # immediately followed by an rt or rp element, or if there is
-            # no more content in the parent element.
-            if type == "StartTag":
-                return next["name"] in ('rt', 'rp')
-            else:
-                return type == "EndTag" or type is None
-        elif tagname == 'colgroup':
-            # A colgroup element's end tag may be omitted if the colgroup
-            # element is not immediately followed by a space character or
-            # a comment.
-            if type in ("Comment", "SpaceCharacters"):
-                return False
-            elif type == "StartTag":
-                # XXX: we also look for an immediately following colgroup
-                # element. See is_optional_start.
-                return next["name"] != 'colgroup'
-            else:
-                return True
-        elif tagname in ('thead', 'tbody'):
-            # A thead element's end tag may be omitted if the thead element
-            # is immediately followed by a tbody or tfoot element.
-            # A tbody element's end tag may be omitted if the tbody element
-            # is immediately followed by a tbody or tfoot element, or if
-            # there is no more content in the parent element.
-            # A tfoot element's end tag may be omitted if the tfoot element
-            # is immediately followed by a tbody element, or if there is no
-            # more content in the parent element.
-            # XXX: we never omit the end tag when the following element is
-            # a tbody. See is_optional_start.
-            if type == "StartTag":
-                return next["name"] in ['tbody', 'tfoot']
-            elif tagname == 'tbody':
-                return type == "EndTag" or type is None
-            else:
-                return False
-        elif tagname == 'tfoot':
-            # A tfoot element's end tag may be omitted if the tfoot element
-            # is immediately followed by a tbody element, or if there is no
-            # more content in the parent element.
-            # XXX: we never omit the end tag when the following element is
-            # a tbody. See is_optional_start.
-            if type == "StartTag":
-                return next["name"] == 'tbody'
-            else:
-                return type == "EndTag" or type is None
-        elif tagname in ('td', 'th'):
-            # A td element's end tag may be omitted if the td element is
-            # immediately followed by a td or th element, or if there is
-            # no more content in the parent element.
-            # A th element's end tag may be omitted if the th element is
-            # immediately followed by a td or th element, or if there is
-            # no more content in the parent element.
-            if type == "StartTag":
-                return next["name"] in ('td', 'th')
-            else:
-                return type == "EndTag" or type is None
-        return False
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py
deleted file mode 100644
index aa7431d1..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/sanitizer.py
+++ /dev/null
@@ -1,916 +0,0 @@
-"""Deprecated from html5lib 1.1.
-
-See `here <https://github.com/html5lib/html5lib-python/issues/443>`_ for
-information about its deprecation; `Bleach <https://github.com/mozilla/bleach>`_
-is recommended as a replacement. Please let us know in the aforementioned issue
-if Bleach is unsuitable for your needs.
-
-"""
-from __future__ import absolute_import, division, unicode_literals
-
-import re
-import warnings
-from xml.sax.saxutils import escape, unescape
-
-from pip._vendor.six.moves import urllib_parse as urlparse
-
-from . import base
-from ..constants import namespaces, prefixes
-
-__all__ = ["Filter"]
-
-
-_deprecation_msg = (
-    "html5lib's sanitizer is deprecated; see " +
-    "https://github.com/html5lib/html5lib-python/issues/443 and please let " +
-    "us know if Bleach is unsuitable for your needs"
-)
-
-warnings.warn(_deprecation_msg, DeprecationWarning)
-
-allowed_elements = frozenset((
-    (namespaces['html'], 'a'),
-    (namespaces['html'], 'abbr'),
-    (namespaces['html'], 'acronym'),
-    (namespaces['html'], 'address'),
-    (namespaces['html'], 'area'),
-    (namespaces['html'], 'article'),
-    (namespaces['html'], 'aside'),
-    (namespaces['html'], 'audio'),
-    (namespaces['html'], 'b'),
-    (namespaces['html'], 'big'),
-    (namespaces['html'], 'blockquote'),
-    (namespaces['html'], 'br'),
-    (namespaces['html'], 'button'),
-    (namespaces['html'], 'canvas'),
-    (namespaces['html'], 'caption'),
-    (namespaces['html'], 'center'),
-    (namespaces['html'], 'cite'),
-    (namespaces['html'], 'code'),
-    (namespaces['html'], 'col'),
-    (namespaces['html'], 'colgroup'),
-    (namespaces['html'], 'command'),
-    (namespaces['html'], 'datagrid'),
-    (namespaces['html'], 'datalist'),
-    (namespaces['html'], 'dd'),
-    (namespaces['html'], 'del'),
-    (namespaces['html'], 'details'),
-    (namespaces['html'], 'dfn'),
-    (namespaces['html'], 'dialog'),
-    (namespaces['html'], 'dir'),
-    (namespaces['html'], 'div'),
-    (namespaces['html'], 'dl'),
-    (namespaces['html'], 'dt'),
-    (namespaces['html'], 'em'),
-    (namespaces['html'], 'event-source'),
-    (namespaces['html'], 'fieldset'),
-    (namespaces['html'], 'figcaption'),
-    (namespaces['html'], 'figure'),
-    (namespaces['html'], 'footer'),
-    (namespaces['html'], 'font'),
-    (namespaces['html'], 'form'),
-    (namespaces['html'], 'header'),
-    (namespaces['html'], 'h1'),
-    (namespaces['html'], 'h2'),
-    (namespaces['html'], 'h3'),
-    (namespaces['html'], 'h4'),
-    (namespaces['html'], 'h5'),
-    (namespaces['html'], 'h6'),
-    (namespaces['html'], 'hr'),
-    (namespaces['html'], 'i'),
-    (namespaces['html'], 'img'),
-    (namespaces['html'], 'input'),
-    (namespaces['html'], 'ins'),
-    (namespaces['html'], 'keygen'),
-    (namespaces['html'], 'kbd'),
-    (namespaces['html'], 'label'),
-    (namespaces['html'], 'legend'),
-    (namespaces['html'], 'li'),
-    (namespaces['html'], 'm'),
-    (namespaces['html'], 'map'),
-    (namespaces['html'], 'menu'),
-    (namespaces['html'], 'meter'),
-    (namespaces['html'], 'multicol'),
-    (namespaces['html'], 'nav'),
-    (namespaces['html'], 'nextid'),
-    (namespaces['html'], 'ol'),
-    (namespaces['html'], 'output'),
-    (namespaces['html'], 'optgroup'),
-    (namespaces['html'], 'option'),
-    (namespaces['html'], 'p'),
-    (namespaces['html'], 'pre'),
-    (namespaces['html'], 'progress'),
-    (namespaces['html'], 'q'),
-    (namespaces['html'], 's'),
-    (namespaces['html'], 'samp'),
-    (namespaces['html'], 'section'),
-    (namespaces['html'], 'select'),
-    (namespaces['html'], 'small'),
-    (namespaces['html'], 'sound'),
-    (namespaces['html'], 'source'),
-    (namespaces['html'], 'spacer'),
-    (namespaces['html'], 'span'),
-    (namespaces['html'], 'strike'),
-    (namespaces['html'], 'strong'),
-    (namespaces['html'], 'sub'),
-    (namespaces['html'], 'sup'),
-    (namespaces['html'], 'table'),
-    (namespaces['html'], 'tbody'),
-    (namespaces['html'], 'td'),
-    (namespaces['html'], 'textarea'),
-    (namespaces['html'], 'time'),
-    (namespaces['html'], 'tfoot'),
-    (namespaces['html'], 'th'),
-    (namespaces['html'], 'thead'),
-    (namespaces['html'], 'tr'),
-    (namespaces['html'], 'tt'),
-    (namespaces['html'], 'u'),
-    (namespaces['html'], 'ul'),
-    (namespaces['html'], 'var'),
-    (namespaces['html'], 'video'),
-    (namespaces['mathml'], 'maction'),
-    (namespaces['mathml'], 'math'),
-    (namespaces['mathml'], 'merror'),
-    (namespaces['mathml'], 'mfrac'),
-    (namespaces['mathml'], 'mi'),
-    (namespaces['mathml'], 'mmultiscripts'),
-    (namespaces['mathml'], 'mn'),
-    (namespaces['mathml'], 'mo'),
-    (namespaces['mathml'], 'mover'),
-    (namespaces['mathml'], 'mpadded'),
-    (namespaces['mathml'], 'mphantom'),
-    (namespaces['mathml'], 'mprescripts'),
-    (namespaces['mathml'], 'mroot'),
-    (namespaces['mathml'], 'mrow'),
-    (namespaces['mathml'], 'mspace'),
-    (namespaces['mathml'], 'msqrt'),
-    (namespaces['mathml'], 'mstyle'),
-    (namespaces['mathml'], 'msub'),
-    (namespaces['mathml'], 'msubsup'),
-    (namespaces['mathml'], 'msup'),
-    (namespaces['mathml'], 'mtable'),
-    (namespaces['mathml'], 'mtd'),
-    (namespaces['mathml'], 'mtext'),
-    (namespaces['mathml'], 'mtr'),
-    (namespaces['mathml'], 'munder'),
-    (namespaces['mathml'], 'munderover'),
-    (namespaces['mathml'], 'none'),
-    (namespaces['svg'], 'a'),
-    (namespaces['svg'], 'animate'),
-    (namespaces['svg'], 'animateColor'),
-    (namespaces['svg'], 'animateMotion'),
-    (namespaces['svg'], 'animateTransform'),
-    (namespaces['svg'], 'clipPath'),
-    (namespaces['svg'], 'circle'),
-    (namespaces['svg'], 'defs'),
-    (namespaces['svg'], 'desc'),
-    (namespaces['svg'], 'ellipse'),
-    (namespaces['svg'], 'font-face'),
-    (namespaces['svg'], 'font-face-name'),
-    (namespaces['svg'], 'font-face-src'),
-    (namespaces['svg'], 'g'),
-    (namespaces['svg'], 'glyph'),
-    (namespaces['svg'], 'hkern'),
-    (namespaces['svg'], 'linearGradient'),
-    (namespaces['svg'], 'line'),
-    (namespaces['svg'], 'marker'),
-    (namespaces['svg'], 'metadata'),
-    (namespaces['svg'], 'missing-glyph'),
-    (namespaces['svg'], 'mpath'),
-    (namespaces['svg'], 'path'),
-    (namespaces['svg'], 'polygon'),
-    (namespaces['svg'], 'polyline'),
-    (namespaces['svg'], 'radialGradient'),
-    (namespaces['svg'], 'rect'),
-    (namespaces['svg'], 'set'),
-    (namespaces['svg'], 'stop'),
-    (namespaces['svg'], 'svg'),
-    (namespaces['svg'], 'switch'),
-    (namespaces['svg'], 'text'),
-    (namespaces['svg'], 'title'),
-    (namespaces['svg'], 'tspan'),
-    (namespaces['svg'], 'use'),
-))
-
-allowed_attributes = frozenset((
-    # HTML attributes
-    (None, 'abbr'),
-    (None, 'accept'),
-    (None, 'accept-charset'),
-    (None, 'accesskey'),
-    (None, 'action'),
-    (None, 'align'),
-    (None, 'alt'),
-    (None, 'autocomplete'),
-    (None, 'autofocus'),
-    (None, 'axis'),
-    (None, 'background'),
-    (None, 'balance'),
-    (None, 'bgcolor'),
-    (None, 'bgproperties'),
-    (None, 'border'),
-    (None, 'bordercolor'),
-    (None, 'bordercolordark'),
-    (None, 'bordercolorlight'),
-    (None, 'bottompadding'),
-    (None, 'cellpadding'),
-    (None, 'cellspacing'),
-    (None, 'ch'),
-    (None, 'challenge'),
-    (None, 'char'),
-    (None, 'charoff'),
-    (None, 'choff'),
-    (None, 'charset'),
-    (None, 'checked'),
-    (None, 'cite'),
-    (None, 'class'),
-    (None, 'clear'),
-    (None, 'color'),
-    (None, 'cols'),
-    (None, 'colspan'),
-    (None, 'compact'),
-    (None, 'contenteditable'),
-    (None, 'controls'),
-    (None, 'coords'),
-    (None, 'data'),
-    (None, 'datafld'),
-    (None, 'datapagesize'),
-    (None, 'datasrc'),
-    (None, 'datetime'),
-    (None, 'default'),
-    (None, 'delay'),
-    (None, 'dir'),
-    (None, 'disabled'),
-    (None, 'draggable'),
-    (None, 'dynsrc'),
-    (None, 'enctype'),
-    (None, 'end'),
-    (None, 'face'),
-    (None, 'for'),
-    (None, 'form'),
-    (None, 'frame'),
-    (None, 'galleryimg'),
-    (None, 'gutter'),
-    (None, 'headers'),
-    (None, 'height'),
-    (None, 'hidefocus'),
-    (None, 'hidden'),
-    (None, 'high'),
-    (None, 'href'),
-    (None, 'hreflang'),
-    (None, 'hspace'),
-    (None, 'icon'),
-    (None, 'id'),
-    (None, 'inputmode'),
-    (None, 'ismap'),
-    (None, 'keytype'),
-    (None, 'label'),
-    (None, 'leftspacing'),
-    (None, 'lang'),
-    (None, 'list'),
-    (None, 'longdesc'),
-    (None, 'loop'),
-    (None, 'loopcount'),
-    (None, 'loopend'),
-    (None, 'loopstart'),
-    (None, 'low'),
-    (None, 'lowsrc'),
-    (None, 'max'),
-    (None, 'maxlength'),
-    (None, 'media'),
-    (None, 'method'),
-    (None, 'min'),
-    (None, 'multiple'),
-    (None, 'name'),
-    (None, 'nohref'),
-    (None, 'noshade'),
-    (None, 'nowrap'),
-    (None, 'open'),
-    (None, 'optimum'),
-    (None, 'pattern'),
-    (None, 'ping'),
-    (None, 'point-size'),
-    (None, 'poster'),
-    (None, 'pqg'),
-    (None, 'preload'),
-    (None, 'prompt'),
-    (None, 'radiogroup'),
-    (None, 'readonly'),
-    (None, 'rel'),
-    (None, 'repeat-max'),
-    (None, 'repeat-min'),
-    (None, 'replace'),
-    (None, 'required'),
-    (None, 'rev'),
-    (None, 'rightspacing'),
-    (None, 'rows'),
-    (None, 'rowspan'),
-    (None, 'rules'),
-    (None, 'scope'),
-    (None, 'selected'),
-    (None, 'shape'),
-    (None, 'size'),
-    (None, 'span'),
-    (None, 'src'),
-    (None, 'start'),
-    (None, 'step'),
-    (None, 'style'),
-    (None, 'summary'),
-    (None, 'suppress'),
-    (None, 'tabindex'),
-    (None, 'target'),
-    (None, 'template'),
-    (None, 'title'),
-    (None, 'toppadding'),
-    (None, 'type'),
-    (None, 'unselectable'),
-    (None, 'usemap'),
-    (None, 'urn'),
-    (None, 'valign'),
-    (None, 'value'),
-    (None, 'variable'),
-    (None, 'volume'),
-    (None, 'vspace'),
-    (None, 'vrml'),
-    (None, 'width'),
-    (None, 'wrap'),
-    (namespaces['xml'], 'lang'),
-    # MathML attributes
-    (None, 'actiontype'),
-    (None, 'align'),
-    (None, 'columnalign'),
-    (None, 'columnalign'),
-    (None, 'columnalign'),
-    (None, 'columnlines'),
-    (None, 'columnspacing'),
-    (None, 'columnspan'),
-    (None, 'depth'),
-    (None, 'display'),
-    (None, 'displaystyle'),
-    (None, 'equalcolumns'),
-    (None, 'equalrows'),
-    (None, 'fence'),
-    (None, 'fontstyle'),
-    (None, 'fontweight'),
-    (None, 'frame'),
-    (None, 'height'),
-    (None, 'linethickness'),
-    (None, 'lspace'),
-    (None, 'mathbackground'),
-    (None, 'mathcolor'),
-    (None, 'mathvariant'),
-    (None, 'mathvariant'),
-    (None, 'maxsize'),
-    (None, 'minsize'),
-    (None, 'other'),
-    (None, 'rowalign'),
-    (None, 'rowalign'),
-    (None, 'rowalign'),
-    (None, 'rowlines'),
-    (None, 'rowspacing'),
-    (None, 'rowspan'),
-    (None, 'rspace'),
-    (None, 'scriptlevel'),
-    (None, 'selection'),
-    (None, 'separator'),
-    (None, 'stretchy'),
-    (None, 'width'),
-    (None, 'width'),
-    (namespaces['xlink'], 'href'),
-    (namespaces['xlink'], 'show'),
-    (namespaces['xlink'], 'type'),
-    # SVG attributes
-    (None, 'accent-height'),
-    (None, 'accumulate'),
-    (None, 'additive'),
-    (None, 'alphabetic'),
-    (None, 'arabic-form'),
-    (None, 'ascent'),
-    (None, 'attributeName'),
-    (None, 'attributeType'),
-    (None, 'baseProfile'),
-    (None, 'bbox'),
-    (None, 'begin'),
-    (None, 'by'),
-    (None, 'calcMode'),
-    (None, 'cap-height'),
-    (None, 'class'),
-    (None, 'clip-path'),
-    (None, 'color'),
-    (None, 'color-rendering'),
-    (None, 'content'),
-    (None, 'cx'),
-    (None, 'cy'),
-    (None, 'd'),
-    (None, 'dx'),
-    (None, 'dy'),
-    (None, 'descent'),
-    (None, 'display'),
-    (None, 'dur'),
-    (None, 'end'),
-    (None, 'fill'),
-    (None, 'fill-opacity'),
-    (None, 'fill-rule'),
-    (None, 'font-family'),
-    (None, 'font-size'),
-    (None, 'font-stretch'),
-    (None, 'font-style'),
-    (None, 'font-variant'),
-    (None, 'font-weight'),
-    (None, 'from'),
-    (None, 'fx'),
-    (None, 'fy'),
-    (None, 'g1'),
-    (None, 'g2'),
-    (None, 'glyph-name'),
-    (None, 'gradientUnits'),
-    (None, 'hanging'),
-    (None, 'height'),
-    (None, 'horiz-adv-x'),
-    (None, 'horiz-origin-x'),
-    (None, 'id'),
-    (None, 'ideographic'),
-    (None, 'k'),
-    (None, 'keyPoints'),
-    (None, 'keySplines'),
-    (None, 'keyTimes'),
-    (None, 'lang'),
-    (None, 'marker-end'),
-    (None, 'marker-mid'),
-    (None, 'marker-start'),
-    (None, 'markerHeight'),
-    (None, 'markerUnits'),
-    (None, 'markerWidth'),
-    (None, 'mathematical'),
-    (None, 'max'),
-    (None, 'min'),
-    (None, 'name'),
-    (None, 'offset'),
-    (None, 'opacity'),
-    (None, 'orient'),
-    (None, 'origin'),
-    (None, 'overline-position'),
-    (None, 'overline-thickness'),
-    (None, 'panose-1'),
-    (None, 'path'),
-    (None, 'pathLength'),
-    (None, 'points'),
-    (None, 'preserveAspectRatio'),
-    (None, 'r'),
-    (None, 'refX'),
-    (None, 'refY'),
-    (None, 'repeatCount'),
-    (None, 'repeatDur'),
-    (None, 'requiredExtensions'),
-    (None, 'requiredFeatures'),
-    (None, 'restart'),
-    (None, 'rotate'),
-    (None, 'rx'),
-    (None, 'ry'),
-    (None, 'slope'),
-    (None, 'stemh'),
-    (None, 'stemv'),
-    (None, 'stop-color'),
-    (None, 'stop-opacity'),
-    (None, 'strikethrough-position'),
-    (None, 'strikethrough-thickness'),
-    (None, 'stroke'),
-    (None, 'stroke-dasharray'),
-    (None, 'stroke-dashoffset'),
-    (None, 'stroke-linecap'),
-    (None, 'stroke-linejoin'),
-    (None, 'stroke-miterlimit'),
-    (None, 'stroke-opacity'),
-    (None, 'stroke-width'),
-    (None, 'systemLanguage'),
-    (None, 'target'),
-    (None, 'text-anchor'),
-    (None, 'to'),
-    (None, 'transform'),
-    (None, 'type'),
-    (None, 'u1'),
-    (None, 'u2'),
-    (None, 'underline-position'),
-    (None, 'underline-thickness'),
-    (None, 'unicode'),
-    (None, 'unicode-range'),
-    (None, 'units-per-em'),
-    (None, 'values'),
-    (None, 'version'),
-    (None, 'viewBox'),
-    (None, 'visibility'),
-    (None, 'width'),
-    (None, 'widths'),
-    (None, 'x'),
-    (None, 'x-height'),
-    (None, 'x1'),
-    (None, 'x2'),
-    (namespaces['xlink'], 'actuate'),
-    (namespaces['xlink'], 'arcrole'),
-    (namespaces['xlink'], 'href'),
-    (namespaces['xlink'], 'role'),
-    (namespaces['xlink'], 'show'),
-    (namespaces['xlink'], 'title'),
-    (namespaces['xlink'], 'type'),
-    (namespaces['xml'], 'base'),
-    (namespaces['xml'], 'lang'),
-    (namespaces['xml'], 'space'),
-    (None, 'y'),
-    (None, 'y1'),
-    (None, 'y2'),
-    (None, 'zoomAndPan'),
-))
-
-attr_val_is_uri = frozenset((
-    (None, 'href'),
-    (None, 'src'),
-    (None, 'cite'),
-    (None, 'action'),
-    (None, 'longdesc'),
-    (None, 'poster'),
-    (None, 'background'),
-    (None, 'datasrc'),
-    (None, 'dynsrc'),
-    (None, 'lowsrc'),
-    (None, 'ping'),
-    (namespaces['xlink'], 'href'),
-    (namespaces['xml'], 'base'),
-))
-
-svg_attr_val_allows_ref = frozenset((
-    (None, 'clip-path'),
-    (None, 'color-profile'),
-    (None, 'cursor'),
-    (None, 'fill'),
-    (None, 'filter'),
-    (None, 'marker'),
-    (None, 'marker-start'),
-    (None, 'marker-mid'),
-    (None, 'marker-end'),
-    (None, 'mask'),
-    (None, 'stroke'),
-))
-
-svg_allow_local_href = frozenset((
-    (None, 'altGlyph'),
-    (None, 'animate'),
-    (None, 'animateColor'),
-    (None, 'animateMotion'),
-    (None, 'animateTransform'),
-    (None, 'cursor'),
-    (None, 'feImage'),
-    (None, 'filter'),
-    (None, 'linearGradient'),
-    (None, 'pattern'),
-    (None, 'radialGradient'),
-    (None, 'textpath'),
-    (None, 'tref'),
-    (None, 'set'),
-    (None, 'use')
-))
-
-allowed_css_properties = frozenset((
-    'azimuth',
-    'background-color',
-    'border-bottom-color',
-    'border-collapse',
-    'border-color',
-    'border-left-color',
-    'border-right-color',
-    'border-top-color',
-    'clear',
-    'color',
-    'cursor',
-    'direction',
-    'display',
-    'elevation',
-    'float',
-    'font',
-    'font-family',
-    'font-size',
-    'font-style',
-    'font-variant',
-    'font-weight',
-    'height',
-    'letter-spacing',
-    'line-height',
-    'overflow',
-    'pause',
-    'pause-after',
-    'pause-before',
-    'pitch',
-    'pitch-range',
-    'richness',
-    'speak',
-    'speak-header',
-    'speak-numeral',
-    'speak-punctuation',
-    'speech-rate',
-    'stress',
-    'text-align',
-    'text-decoration',
-    'text-indent',
-    'unicode-bidi',
-    'vertical-align',
-    'voice-family',
-    'volume',
-    'white-space',
-    'width',
-))
-
-allowed_css_keywords = frozenset((
-    'auto',
-    'aqua',
-    'black',
-    'block',
-    'blue',
-    'bold',
-    'both',
-    'bottom',
-    'brown',
-    'center',
-    'collapse',
-    'dashed',
-    'dotted',
-    'fuchsia',
-    'gray',
-    'green',
-    '!important',
-    'italic',
-    'left',
-    'lime',
-    'maroon',
-    'medium',
-    'none',
-    'navy',
-    'normal',
-    'nowrap',
-    'olive',
-    'pointer',
-    'purple',
-    'red',
-    'right',
-    'solid',
-    'silver',
-    'teal',
-    'top',
-    'transparent',
-    'underline',
-    'white',
-    'yellow',
-))
-
-allowed_svg_properties = frozenset((
-    'fill',
-    'fill-opacity',
-    'fill-rule',
-    'stroke',
-    'stroke-width',
-    'stroke-linecap',
-    'stroke-linejoin',
-    'stroke-opacity',
-))
-
-allowed_protocols = frozenset((
-    'ed2k',
-    'ftp',
-    'http',
-    'https',
-    'irc',
-    'mailto',
-    'news',
-    'gopher',
-    'nntp',
-    'telnet',
-    'webcal',
-    'xmpp',
-    'callto',
-    'feed',
-    'urn',
-    'aim',
-    'rsync',
-    'tag',
-    'ssh',
-    'sftp',
-    'rtsp',
-    'afs',
-    'data',
-))
-
-allowed_content_types = frozenset((
-    'image/png',
-    'image/jpeg',
-    'image/gif',
-    'image/webp',
-    'image/bmp',
-    'text/plain',
-))
-
-
-data_content_type = re.compile(r'''
-                                ^
-                                # Match a content type <application>/<type>
-                                (?P<content_type>[-a-zA-Z0-9.]+/[-a-zA-Z0-9.]+)
-                                # Match any character set and encoding
-                                (?:(?:;charset=(?:[-a-zA-Z0-9]+)(?:;(?:base64))?)
-                                  |(?:;(?:base64))?(?:;charset=(?:[-a-zA-Z0-9]+))?)
-                                # Assume the rest is data
-                                ,.*
-                                $
-                                ''',
-                               re.VERBOSE)
-
-
-class Filter(base.Filter):
-    """Sanitizes token stream of XHTML+MathML+SVG and of inline style attributes"""
-    def __init__(self,
-                 source,
-                 allowed_elements=allowed_elements,
-                 allowed_attributes=allowed_attributes,
-                 allowed_css_properties=allowed_css_properties,
-                 allowed_css_keywords=allowed_css_keywords,
-                 allowed_svg_properties=allowed_svg_properties,
-                 allowed_protocols=allowed_protocols,
-                 allowed_content_types=allowed_content_types,
-                 attr_val_is_uri=attr_val_is_uri,
-                 svg_attr_val_allows_ref=svg_attr_val_allows_ref,
-                 svg_allow_local_href=svg_allow_local_href):
-        """Creates a Filter
-
-        :arg allowed_elements: set of elements to allow--everything else will
-            be escaped
-
-        :arg allowed_attributes: set of attributes to allow in
-            elements--everything else will be stripped
-
-        :arg allowed_css_properties: set of CSS properties to allow--everything
-            else will be stripped
-
-        :arg allowed_css_keywords: set of CSS keywords to allow--everything
-            else will be stripped
-
-        :arg allowed_svg_properties: set of SVG properties to allow--everything
-            else will be removed
-
-        :arg allowed_protocols: set of allowed protocols for URIs
-
-        :arg allowed_content_types: set of allowed content types for ``data`` URIs.
-
-        :arg attr_val_is_uri: set of attributes that have URI values--values
-            that have a scheme not listed in ``allowed_protocols`` are removed
-
-        :arg svg_attr_val_allows_ref: set of SVG attributes that can have
-            references
-
-        :arg svg_allow_local_href: set of SVG elements that can have local
-            hrefs--these are removed
-
-        """
-        super(Filter, self).__init__(source)
-
-        warnings.warn(_deprecation_msg, DeprecationWarning)
-
-        self.allowed_elements = allowed_elements
-        self.allowed_attributes = allowed_attributes
-        self.allowed_css_properties = allowed_css_properties
-        self.allowed_css_keywords = allowed_css_keywords
-        self.allowed_svg_properties = allowed_svg_properties
-        self.allowed_protocols = allowed_protocols
-        self.allowed_content_types = allowed_content_types
-        self.attr_val_is_uri = attr_val_is_uri
-        self.svg_attr_val_allows_ref = svg_attr_val_allows_ref
-        self.svg_allow_local_href = svg_allow_local_href
-
-    def __iter__(self):
-        for token in base.Filter.__iter__(self):
-            token = self.sanitize_token(token)
-            if token:
-                yield token
-
-    # Sanitize the +html+, escaping all elements not in ALLOWED_ELEMENTS, and
-    # stripping out all attributes not in ALLOWED_ATTRIBUTES. Style attributes
-    # are parsed, and a restricted set, specified by ALLOWED_CSS_PROPERTIES and
-    # ALLOWED_CSS_KEYWORDS, are allowed through. attributes in ATTR_VAL_IS_URI
-    # are scanned, and only URI schemes specified in ALLOWED_PROTOCOLS are
-    # allowed.
-    #
-    #   sanitize_html('<script> do_nasty_stuff() </script>')
-    #    => &lt;script> do_nasty_stuff() &lt;/script>
-    #   sanitize_html('<a href="javascript: sucker();">Click here for $100</a>')
-    #    => <a>Click here for $100</a>
-    def sanitize_token(self, token):
-
-        # accommodate filters which use token_type differently
-        token_type = token["type"]
-        if token_type in ("StartTag", "EndTag", "EmptyTag"):
-            name = token["name"]
-            namespace = token["namespace"]
-            if ((namespace, name) in self.allowed_elements or
-                (namespace is None and
-                 (namespaces["html"], name) in self.allowed_elements)):
-                return self.allowed_token(token)
-            else:
-                return self.disallowed_token(token)
-        elif token_type == "Comment":
-            pass
-        else:
-            return token
-
-    def allowed_token(self, token):
-        if "data" in token:
-            attrs = token["data"]
-            attr_names = set(attrs.keys())
-
-            # Remove forbidden attributes
-            for to_remove in (attr_names - self.allowed_attributes):
-                del token["data"][to_remove]
-                attr_names.remove(to_remove)
-
-            # Remove attributes with disallowed URL values
-            for attr in (attr_names & self.attr_val_is_uri):
-                assert attr in attrs
-                # I don't have a clue where this regexp comes from or why it matches those
-                # characters, nor why we call unescape. I just know it's always been here.
-                # Should you be worried by this comment in a sanitizer? Yes. On the other hand, all
-                # this will do is remove *more* than it otherwise would.
-                val_unescaped = re.sub("[`\x00-\x20\x7f-\xa0\\s]+", '',
-                                       unescape(attrs[attr])).lower()
-                # remove replacement characters from unescaped characters
-                val_unescaped = val_unescaped.replace("\ufffd", "")
-                try:
-                    uri = urlparse.urlparse(val_unescaped)
-                except ValueError:
-                    uri = None
-                    del attrs[attr]
-                if uri and uri.scheme:
-                    if uri.scheme not in self.allowed_protocols:
-                        del attrs[attr]
-                    if uri.scheme == 'data':
-                        m = data_content_type.match(uri.path)
-                        if not m:
-                            del attrs[attr]
-                        elif m.group('content_type') not in self.allowed_content_types:
-                            del attrs[attr]
-
-            for attr in self.svg_attr_val_allows_ref:
-                if attr in attrs:
-                    attrs[attr] = re.sub(r'url\s*\(\s*[^#\s][^)]+?\)',
-                                         ' ',
-                                         unescape(attrs[attr]))
-            if (token["name"] in self.svg_allow_local_href and
-                (namespaces['xlink'], 'href') in attrs and re.search(r'^\s*[^#\s].*',
-                                                                     attrs[(namespaces['xlink'], 'href')])):
-                del attrs[(namespaces['xlink'], 'href')]
-            if (None, 'style') in attrs:
-                attrs[(None, 'style')] = self.sanitize_css(attrs[(None, 'style')])
-            token["data"] = attrs
-        return token
-
-    def disallowed_token(self, token):
-        token_type = token["type"]
-        if token_type == "EndTag":
-            token["data"] = "</%s>" % token["name"]
-        elif token["data"]:
-            assert token_type in ("StartTag", "EmptyTag")
-            attrs = []
-            for (ns, name), v in token["data"].items():
-                attrs.append(' %s="%s"' % (name if ns is None else "%s:%s" % (prefixes[ns], name), escape(v)))
-            token["data"] = "<%s%s>" % (token["name"], ''.join(attrs))
-        else:
-            token["data"] = "<%s>" % token["name"]
-        if token.get("selfClosing"):
-            token["data"] = token["data"][:-1] + "/>"
-
-        token["type"] = "Characters"
-
-        del token["name"]
-        return token
-
-    def sanitize_css(self, style):
-        # disallow urls
-        style = re.compile(r'url\s*\(\s*[^\s)]+?\s*\)\s*').sub(' ', style)
-
-        # gauntlet
-        if not re.match(r"""^([:,;#%.\sa-zA-Z0-9!]|\w-\w|'[\s\w]+'|"[\s\w]+"|\([\d,\s]+\))*$""", style):
-            return ''
-        if not re.match(r"^\s*([-\w]+\s*:[^:;]*(;\s*|$))*$", style):
-            return ''
-
-        clean = []
-        for prop, value in re.findall(r"([-\w]+)\s*:\s*([^:;]*)", style):
-            if not value:
-                continue
-            if prop.lower() in self.allowed_css_properties:
-                clean.append(prop + ': ' + value + ';')
-            elif prop.split('-')[0].lower() in ['background', 'border', 'margin',
-                                                'padding']:
-                for keyword in value.split():
-                    if keyword not in self.allowed_css_keywords and \
-                            not re.match(r"^(#[0-9a-fA-F]+|rgb\(\d+%?,\d*%?,?\d*%?\)?|\d{0,2}\.?\d{0,2}(cm|em|ex|in|mm|pc|pt|px|%|,|\))?)$", keyword):  # noqa
-                        break
-                else:
-                    clean.append(prop + ': ' + value + ';')
-            elif prop.lower() in self.allowed_svg_properties:
-                clean.append(prop + ': ' + value + ';')
-
-        return ' '.join(clean)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py b/env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py
deleted file mode 100644
index 0d12584b..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/filters/whitespace.py
+++ /dev/null
@@ -1,38 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-import re
-
-from . import base
-from ..constants import rcdataElements, spaceCharacters
-spaceCharacters = "".join(spaceCharacters)
-
-SPACES_REGEX = re.compile("[%s]+" % spaceCharacters)
-
-
-class Filter(base.Filter):
-    """Collapses whitespace except in pre, textarea, and script elements"""
-    spacePreserveElements = frozenset(["pre", "textarea"] + list(rcdataElements))
-
-    def __iter__(self):
-        preserve = 0
-        for token in base.Filter.__iter__(self):
-            type = token["type"]
-            if type == "StartTag" \
-                    and (preserve or token["name"] in self.spacePreserveElements):
-                preserve += 1
-
-            elif type == "EndTag" and preserve:
-                preserve -= 1
-
-            elif not preserve and type == "SpaceCharacters" and token["data"]:
-                # Test on token["data"] above to not introduce spaces where there were not
-                token["data"] = " "
-
-            elif not preserve and type == "Characters":
-                token["data"] = collapse_spaces(token["data"])
-
-            yield token
-
-
-def collapse_spaces(text):
-    return SPACES_REGEX.sub(' ', text)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py b/env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py
deleted file mode 100644
index d06784f3..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/html5parser.py
+++ /dev/null
@@ -1,2795 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-from pip._vendor.six import with_metaclass, viewkeys
-
-import types
-
-from . import _inputstream
-from . import _tokenizer
-
-from . import treebuilders
-from .treebuilders.base import Marker
-
-from . import _utils
-from .constants import (
-    spaceCharacters, asciiUpper2Lower,
-    specialElements, headingElements, cdataElements, rcdataElements,
-    tokenTypes, tagTokenTypes,
-    namespaces,
-    htmlIntegrationPointElements, mathmlTextIntegrationPointElements,
-    adjustForeignAttributes as adjustForeignAttributesMap,
-    adjustMathMLAttributes, adjustSVGAttributes,
-    E,
-    _ReparseException
-)
-
-
-def parse(doc, treebuilder="etree", namespaceHTMLElements=True, **kwargs):
-    """Parse an HTML document as a string or file-like object into a tree
-
-    :arg doc: the document to parse as a string or file-like object
-
-    :arg treebuilder: the treebuilder to use when parsing
-
-    :arg namespaceHTMLElements: whether or not to namespace HTML elements
-
-    :returns: parsed tree
-
-    Example:
-
-    >>> from html5lib.html5parser import parse
-    >>> parse('<html><body><p>This is a doc</p></body></html>')
-    <Element u'{http://www.w3.org/1999/xhtml}html' at 0x7feac4909db0>
-
-    """
-    tb = treebuilders.getTreeBuilder(treebuilder)
-    p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements)
-    return p.parse(doc, **kwargs)
-
-
-def parseFragment(doc, container="div", treebuilder="etree", namespaceHTMLElements=True, **kwargs):
-    """Parse an HTML fragment as a string or file-like object into a tree
-
-    :arg doc: the fragment to parse as a string or file-like object
-
-    :arg container: the container context to parse the fragment in
-
-    :arg treebuilder: the treebuilder to use when parsing
-
-    :arg namespaceHTMLElements: whether or not to namespace HTML elements
-
-    :returns: parsed tree
-
-    Example:
-
-    >>> from html5lib.html5libparser import parseFragment
-    >>> parseFragment('<b>this is a fragment</b>')
-    <Element u'DOCUMENT_FRAGMENT' at 0x7feac484b090>
-
-    """
-    tb = treebuilders.getTreeBuilder(treebuilder)
-    p = HTMLParser(tb, namespaceHTMLElements=namespaceHTMLElements)
-    return p.parseFragment(doc, container=container, **kwargs)
-
-
-def method_decorator_metaclass(function):
-    class Decorated(type):
-        def __new__(meta, classname, bases, classDict):
-            for attributeName, attribute in classDict.items():
-                if isinstance(attribute, types.FunctionType):
-                    attribute = function(attribute)
-
-                classDict[attributeName] = attribute
-            return type.__new__(meta, classname, bases, classDict)
-    return Decorated
-
-
-class HTMLParser(object):
-    """HTML parser
-
-    Generates a tree structure from a stream of (possibly malformed) HTML.
-
-    """
-
-    def __init__(self, tree=None, strict=False, namespaceHTMLElements=True, debug=False):
-        """
-        :arg tree: a treebuilder class controlling the type of tree that will be
-            returned. Built in treebuilders can be accessed through
-            html5lib.treebuilders.getTreeBuilder(treeType)
-
-        :arg strict: raise an exception when a parse error is encountered
-
-        :arg namespaceHTMLElements: whether or not to namespace HTML elements
-
-        :arg debug: whether or not to enable debug mode which logs things
-
-        Example:
-
-        >>> from html5lib.html5parser import HTMLParser
-        >>> parser = HTMLParser()                     # generates parser with etree builder
-        >>> parser = HTMLParser('lxml', strict=True)  # generates parser with lxml builder which is strict
-
-        """
-
-        # Raise an exception on the first error encountered
-        self.strict = strict
-
-        if tree is None:
-            tree = treebuilders.getTreeBuilder("etree")
-        self.tree = tree(namespaceHTMLElements)
-        self.errors = []
-
-        self.phases = {name: cls(self, self.tree) for name, cls in
-                       getPhases(debug).items()}
-
-    def _parse(self, stream, innerHTML=False, container="div", scripting=False, **kwargs):
-
-        self.innerHTMLMode = innerHTML
-        self.container = container
-        self.scripting = scripting
-        self.tokenizer = _tokenizer.HTMLTokenizer(stream, parser=self, **kwargs)
-        self.reset()
-
-        try:
-            self.mainLoop()
-        except _ReparseException:
-            self.reset()
-            self.mainLoop()
-
-    def reset(self):
-        self.tree.reset()
-        self.firstStartTag = False
-        self.errors = []
-        self.log = []  # only used with debug mode
-        # "quirks" / "limited quirks" / "no quirks"
-        self.compatMode = "no quirks"
-
-        if self.innerHTMLMode:
-            self.innerHTML = self.container.lower()
-
-            if self.innerHTML in cdataElements:
-                self.tokenizer.state = self.tokenizer.rcdataState
-            elif self.innerHTML in rcdataElements:
-                self.tokenizer.state = self.tokenizer.rawtextState
-            elif self.innerHTML == 'plaintext':
-                self.tokenizer.state = self.tokenizer.plaintextState
-            else:
-                # state already is data state
-                # self.tokenizer.state = self.tokenizer.dataState
-                pass
-            self.phase = self.phases["beforeHtml"]
-            self.phase.insertHtmlElement()
-            self.resetInsertionMode()
-        else:
-            self.innerHTML = False  # pylint:disable=redefined-variable-type
-            self.phase = self.phases["initial"]
-
-        self.lastPhase = None
-
-        self.beforeRCDataPhase = None
-
-        self.framesetOK = True
-
-    @property
-    def documentEncoding(self):
-        """Name of the character encoding that was used to decode the input stream, or
-        :obj:`None` if that is not determined yet
-
-        """
-        if not hasattr(self, 'tokenizer'):
-            return None
-        return self.tokenizer.stream.charEncoding[0].name
-
-    def isHTMLIntegrationPoint(self, element):
-        if (element.name == "annotation-xml" and
-                element.namespace == namespaces["mathml"]):
-            return ("encoding" in element.attributes and
-                    element.attributes["encoding"].translate(
-                        asciiUpper2Lower) in
-                    ("text/html", "application/xhtml+xml"))
-        else:
-            return (element.namespace, element.name) in htmlIntegrationPointElements
-
-    def isMathMLTextIntegrationPoint(self, element):
-        return (element.namespace, element.name) in mathmlTextIntegrationPointElements
-
-    def mainLoop(self):
-        CharactersToken = tokenTypes["Characters"]
-        SpaceCharactersToken = tokenTypes["SpaceCharacters"]
-        StartTagToken = tokenTypes["StartTag"]
-        EndTagToken = tokenTypes["EndTag"]
-        CommentToken = tokenTypes["Comment"]
-        DoctypeToken = tokenTypes["Doctype"]
-        ParseErrorToken = tokenTypes["ParseError"]
-
-        for token in self.tokenizer:
-            prev_token = None
-            new_token = token
-            while new_token is not None:
-                prev_token = new_token
-                currentNode = self.tree.openElements[-1] if self.tree.openElements else None
-                currentNodeNamespace = currentNode.namespace if currentNode else None
-                currentNodeName = currentNode.name if currentNode else None
-
-                type = new_token["type"]
-
-                if type == ParseErrorToken:
-                    self.parseError(new_token["data"], new_token.get("datavars", {}))
-                    new_token = None
-                else:
-                    if (len(self.tree.openElements) == 0 or
-                        currentNodeNamespace == self.tree.defaultNamespace or
-                        (self.isMathMLTextIntegrationPoint(currentNode) and
-                         ((type == StartTagToken and
-                           token["name"] not in frozenset(["mglyph", "malignmark"])) or
-                          type in (CharactersToken, SpaceCharactersToken))) or
-                        (currentNodeNamespace == namespaces["mathml"] and
-                         currentNodeName == "annotation-xml" and
-                         type == StartTagToken and
-                         token["name"] == "svg") or
-                        (self.isHTMLIntegrationPoint(currentNode) and
-                         type in (StartTagToken, CharactersToken, SpaceCharactersToken))):
-                        phase = self.phase
-                    else:
-                        phase = self.phases["inForeignContent"]
-
-                    if type == CharactersToken:
-                        new_token = phase.processCharacters(new_token)
-                    elif type == SpaceCharactersToken:
-                        new_token = phase.processSpaceCharacters(new_token)
-                    elif type == StartTagToken:
-                        new_token = phase.processStartTag(new_token)
-                    elif type == EndTagToken:
-                        new_token = phase.processEndTag(new_token)
-                    elif type == CommentToken:
-                        new_token = phase.processComment(new_token)
-                    elif type == DoctypeToken:
-                        new_token = phase.processDoctype(new_token)
-
-            if (type == StartTagToken and prev_token["selfClosing"] and
-                    not prev_token["selfClosingAcknowledged"]):
-                self.parseError("non-void-element-with-trailing-solidus",
-                                {"name": prev_token["name"]})
-
-        # When the loop finishes it's EOF
-        reprocess = True
-        phases = []
-        while reprocess:
-            phases.append(self.phase)
-            reprocess = self.phase.processEOF()
-            if reprocess:
-                assert self.phase not in phases
-
-    def parse(self, stream, *args, **kwargs):
-        """Parse a HTML document into a well-formed tree
-
-        :arg stream: a file-like object or string containing the HTML to be parsed
-
-            The optional encoding parameter must be a string that indicates
-            the encoding.  If specified, that encoding will be used,
-            regardless of any BOM or later declaration (such as in a meta
-            element).
-
-        :arg scripting: treat noscript elements as if JavaScript was turned on
-
-        :returns: parsed tree
-
-        Example:
-
-        >>> from html5lib.html5parser import HTMLParser
-        >>> parser = HTMLParser()
-        >>> parser.parse('<html><body><p>This is a doc</p></body></html>')
-        <Element u'{http://www.w3.org/1999/xhtml}html' at 0x7feac4909db0>
-
-        """
-        self._parse(stream, False, None, *args, **kwargs)
-        return self.tree.getDocument()
-
-    def parseFragment(self, stream, *args, **kwargs):
-        """Parse a HTML fragment into a well-formed tree fragment
-
-        :arg container: name of the element we're setting the innerHTML
-            property if set to None, default to 'div'
-
-        :arg stream: a file-like object or string containing the HTML to be parsed
-
-            The optional encoding parameter must be a string that indicates
-            the encoding.  If specified, that encoding will be used,
-            regardless of any BOM or later declaration (such as in a meta
-            element)
-
-        :arg scripting: treat noscript elements as if JavaScript was turned on
-
-        :returns: parsed tree
-
-        Example:
-
-        >>> from html5lib.html5libparser import HTMLParser
-        >>> parser = HTMLParser()
-        >>> parser.parseFragment('<b>this is a fragment</b>')
-        <Element u'DOCUMENT_FRAGMENT' at 0x7feac484b090>
-
-        """
-        self._parse(stream, True, *args, **kwargs)
-        return self.tree.getFragment()
-
-    def parseError(self, errorcode="XXX-undefined-error", datavars=None):
-        # XXX The idea is to make errorcode mandatory.
-        if datavars is None:
-            datavars = {}
-        self.errors.append((self.tokenizer.stream.position(), errorcode, datavars))
-        if self.strict:
-            raise ParseError(E[errorcode] % datavars)
-
-    def adjustMathMLAttributes(self, token):
-        adjust_attributes(token, adjustMathMLAttributes)
-
-    def adjustSVGAttributes(self, token):
-        adjust_attributes(token, adjustSVGAttributes)
-
-    def adjustForeignAttributes(self, token):
-        adjust_attributes(token, adjustForeignAttributesMap)
-
-    def reparseTokenNormal(self, token):
-        # pylint:disable=unused-argument
-        self.parser.phase()
-
-    def resetInsertionMode(self):
-        # The name of this method is mostly historical. (It's also used in the
-        # specification.)
-        last = False
-        newModes = {
-            "select": "inSelect",
-            "td": "inCell",
-            "th": "inCell",
-            "tr": "inRow",
-            "tbody": "inTableBody",
-            "thead": "inTableBody",
-            "tfoot": "inTableBody",
-            "caption": "inCaption",
-            "colgroup": "inColumnGroup",
-            "table": "inTable",
-            "head": "inBody",
-            "body": "inBody",
-            "frameset": "inFrameset",
-            "html": "beforeHead"
-        }
-        for node in self.tree.openElements[::-1]:
-            nodeName = node.name
-            new_phase = None
-            if node == self.tree.openElements[0]:
-                assert self.innerHTML
-                last = True
-                nodeName = self.innerHTML
-            # Check for conditions that should only happen in the innerHTML
-            # case
-            if nodeName in ("select", "colgroup", "head", "html"):
-                assert self.innerHTML
-
-            if not last and node.namespace != self.tree.defaultNamespace:
-                continue
-
-            if nodeName in newModes:
-                new_phase = self.phases[newModes[nodeName]]
-                break
-            elif last:
-                new_phase = self.phases["inBody"]
-                break
-
-        self.phase = new_phase
-
-    def parseRCDataRawtext(self, token, contentType):
-        # Generic RCDATA/RAWTEXT Parsing algorithm
-        assert contentType in ("RAWTEXT", "RCDATA")
-
-        self.tree.insertElement(token)
-
-        if contentType == "RAWTEXT":
-            self.tokenizer.state = self.tokenizer.rawtextState
-        else:
-            self.tokenizer.state = self.tokenizer.rcdataState
-
-        self.originalPhase = self.phase
-
-        self.phase = self.phases["text"]
-
-
-@_utils.memoize
-def getPhases(debug):
-    def log(function):
-        """Logger that records which phase processes each token"""
-        type_names = {value: key for key, value in tokenTypes.items()}
-
-        def wrapped(self, *args, **kwargs):
-            if function.__name__.startswith("process") and len(args) > 0:
-                token = args[0]
-                info = {"type": type_names[token['type']]}
-                if token['type'] in tagTokenTypes:
-                    info["name"] = token['name']
-
-                self.parser.log.append((self.parser.tokenizer.state.__name__,
-                                        self.parser.phase.__class__.__name__,
-                                        self.__class__.__name__,
-                                        function.__name__,
-                                        info))
-                return function(self, *args, **kwargs)
-            else:
-                return function(self, *args, **kwargs)
-        return wrapped
-
-    def getMetaclass(use_metaclass, metaclass_func):
-        if use_metaclass:
-            return method_decorator_metaclass(metaclass_func)
-        else:
-            return type
-
-    # pylint:disable=unused-argument
-    class Phase(with_metaclass(getMetaclass(debug, log))):
-        """Base class for helper object that implements each phase of processing
-        """
-        __slots__ = ("parser", "tree", "__startTagCache", "__endTagCache")
-
-        def __init__(self, parser, tree):
-            self.parser = parser
-            self.tree = tree
-            self.__startTagCache = {}
-            self.__endTagCache = {}
-
-        def processEOF(self):
-            raise NotImplementedError
-
-        def processComment(self, token):
-            # For most phases the following is correct. Where it's not it will be
-            # overridden.
-            self.tree.insertComment(token, self.tree.openElements[-1])
-
-        def processDoctype(self, token):
-            self.parser.parseError("unexpected-doctype")
-
-        def processCharacters(self, token):
-            self.tree.insertText(token["data"])
-
-        def processSpaceCharacters(self, token):
-            self.tree.insertText(token["data"])
-
-        def processStartTag(self, token):
-            # Note the caching is done here rather than BoundMethodDispatcher as doing it there
-            # requires a circular reference to the Phase, and this ends up with a significant
-            # (CPython 2.7, 3.8) GC cost when parsing many short inputs
-            name = token["name"]
-            # In Py2, using `in` is quicker in general than try/except KeyError
-            # In Py3, `in` is quicker when there are few cache hits (typically short inputs)
-            if name in self.__startTagCache:
-                func = self.__startTagCache[name]
-            else:
-                func = self.__startTagCache[name] = self.startTagHandler[name]
-                # bound the cache size in case we get loads of unknown tags
-                while len(self.__startTagCache) > len(self.startTagHandler) * 1.1:
-                    # this makes the eviction policy random on Py < 3.7 and FIFO >= 3.7
-                    self.__startTagCache.pop(next(iter(self.__startTagCache)))
-            return func(token)
-
-        def startTagHtml(self, token):
-            if not self.parser.firstStartTag and token["name"] == "html":
-                self.parser.parseError("non-html-root")
-            # XXX Need a check here to see if the first start tag token emitted is
-            # this token... If it's not, invoke self.parser.parseError().
-            for attr, value in token["data"].items():
-                if attr not in self.tree.openElements[0].attributes:
-                    self.tree.openElements[0].attributes[attr] = value
-            self.parser.firstStartTag = False
-
-        def processEndTag(self, token):
-            # Note the caching is done here rather than BoundMethodDispatcher as doing it there
-            # requires a circular reference to the Phase, and this ends up with a significant
-            # (CPython 2.7, 3.8) GC cost when parsing many short inputs
-            name = token["name"]
-            # In Py2, using `in` is quicker in general than try/except KeyError
-            # In Py3, `in` is quicker when there are few cache hits (typically short inputs)
-            if name in self.__endTagCache:
-                func = self.__endTagCache[name]
-            else:
-                func = self.__endTagCache[name] = self.endTagHandler[name]
-                # bound the cache size in case we get loads of unknown tags
-                while len(self.__endTagCache) > len(self.endTagHandler) * 1.1:
-                    # this makes the eviction policy random on Py < 3.7 and FIFO >= 3.7
-                    self.__endTagCache.pop(next(iter(self.__endTagCache)))
-            return func(token)
-
-    class InitialPhase(Phase):
-        __slots__ = tuple()
-
-        def processSpaceCharacters(self, token):
-            pass
-
-        def processComment(self, token):
-            self.tree.insertComment(token, self.tree.document)
-
-        def processDoctype(self, token):
-            name = token["name"]
-            publicId = token["publicId"]
-            systemId = token["systemId"]
-            correct = token["correct"]
-
-            if (name != "html" or publicId is not None or
-                    systemId is not None and systemId != "about:legacy-compat"):
-                self.parser.parseError("unknown-doctype")
-
-            if publicId is None:
-                publicId = ""
-
-            self.tree.insertDoctype(token)
-
-            if publicId != "":
-                publicId = publicId.translate(asciiUpper2Lower)
-
-            if (not correct or token["name"] != "html" or
-                    publicId.startswith(
-                        ("+//silmaril//dtd html pro v0r11 19970101//",
-                         "-//advasoft ltd//dtd html 3.0 aswedit + extensions//",
-                         "-//as//dtd html 3.0 aswedit + extensions//",
-                         "-//ietf//dtd html 2.0 level 1//",
-                         "-//ietf//dtd html 2.0 level 2//",
-                         "-//ietf//dtd html 2.0 strict level 1//",
-                         "-//ietf//dtd html 2.0 strict level 2//",
-                         "-//ietf//dtd html 2.0 strict//",
-                         "-//ietf//dtd html 2.0//",
-                         "-//ietf//dtd html 2.1e//",
-                         "-//ietf//dtd html 3.0//",
-                         "-//ietf//dtd html 3.2 final//",
-                         "-//ietf//dtd html 3.2//",
-                         "-//ietf//dtd html 3//",
-                         "-//ietf//dtd html level 0//",
-                         "-//ietf//dtd html level 1//",
-                         "-//ietf//dtd html level 2//",
-                         "-//ietf//dtd html level 3//",
-                         "-//ietf//dtd html strict level 0//",
-                         "-//ietf//dtd html strict level 1//",
-                         "-//ietf//dtd html strict level 2//",
-                         "-//ietf//dtd html strict level 3//",
-                         "-//ietf//dtd html strict//",
-                         "-//ietf//dtd html//",
-                         "-//metrius//dtd metrius presentational//",
-                         "-//microsoft//dtd internet explorer 2.0 html strict//",
-                         "-//microsoft//dtd internet explorer 2.0 html//",
-                         "-//microsoft//dtd internet explorer 2.0 tables//",
-                         "-//microsoft//dtd internet explorer 3.0 html strict//",
-                         "-//microsoft//dtd internet explorer 3.0 html//",
-                         "-//microsoft//dtd internet explorer 3.0 tables//",
-                         "-//netscape comm. corp.//dtd html//",
-                         "-//netscape comm. corp.//dtd strict html//",
-                         "-//o'reilly and associates//dtd html 2.0//",
-                         "-//o'reilly and associates//dtd html extended 1.0//",
-                         "-//o'reilly and associates//dtd html extended relaxed 1.0//",
-                         "-//softquad software//dtd hotmetal pro 6.0::19990601::extensions to html 4.0//",
-                         "-//softquad//dtd hotmetal pro 4.0::19971010::extensions to html 4.0//",
-                         "-//spyglass//dtd html 2.0 extended//",
-                         "-//sq//dtd html 2.0 hotmetal + extensions//",
-                         "-//sun microsystems corp.//dtd hotjava html//",
-                         "-//sun microsystems corp.//dtd hotjava strict html//",
-                         "-//w3c//dtd html 3 1995-03-24//",
-                         "-//w3c//dtd html 3.2 draft//",
-                         "-//w3c//dtd html 3.2 final//",
-                         "-//w3c//dtd html 3.2//",
-                         "-//w3c//dtd html 3.2s draft//",
-                         "-//w3c//dtd html 4.0 frameset//",
-                         "-//w3c//dtd html 4.0 transitional//",
-                         "-//w3c//dtd html experimental 19960712//",
-                         "-//w3c//dtd html experimental 970421//",
-                         "-//w3c//dtd w3 html//",
-                         "-//w3o//dtd w3 html 3.0//",
-                         "-//webtechs//dtd mozilla html 2.0//",
-                         "-//webtechs//dtd mozilla html//")) or
-                    publicId in ("-//w3o//dtd w3 html strict 3.0//en//",
-                                 "-/w3c/dtd html 4.0 transitional/en",
-                                 "html") or
-                    publicId.startswith(
-                        ("-//w3c//dtd html 4.01 frameset//",
-                         "-//w3c//dtd html 4.01 transitional//")) and
-                    systemId is None or
-                    systemId and systemId.lower() == "http://www.ibm.com/data/dtd/v11/ibmxhtml1-transitional.dtd"):
-                self.parser.compatMode = "quirks"
-            elif (publicId.startswith(
-                    ("-//w3c//dtd xhtml 1.0 frameset//",
-                     "-//w3c//dtd xhtml 1.0 transitional//")) or
-                  publicId.startswith(
-                      ("-//w3c//dtd html 4.01 frameset//",
-                       "-//w3c//dtd html 4.01 transitional//")) and
-                  systemId is not None):
-                self.parser.compatMode = "limited quirks"
-
-            self.parser.phase = self.parser.phases["beforeHtml"]
-
-        def anythingElse(self):
-            self.parser.compatMode = "quirks"
-            self.parser.phase = self.parser.phases["beforeHtml"]
-
-        def processCharacters(self, token):
-            self.parser.parseError("expected-doctype-but-got-chars")
-            self.anythingElse()
-            return token
-
-        def processStartTag(self, token):
-            self.parser.parseError("expected-doctype-but-got-start-tag",
-                                   {"name": token["name"]})
-            self.anythingElse()
-            return token
-
-        def processEndTag(self, token):
-            self.parser.parseError("expected-doctype-but-got-end-tag",
-                                   {"name": token["name"]})
-            self.anythingElse()
-            return token
-
-        def processEOF(self):
-            self.parser.parseError("expected-doctype-but-got-eof")
-            self.anythingElse()
-            return True
-
-    class BeforeHtmlPhase(Phase):
-        __slots__ = tuple()
-
-        # helper methods
-        def insertHtmlElement(self):
-            self.tree.insertRoot(impliedTagToken("html", "StartTag"))
-            self.parser.phase = self.parser.phases["beforeHead"]
-
-        # other
-        def processEOF(self):
-            self.insertHtmlElement()
-            return True
-
-        def processComment(self, token):
-            self.tree.insertComment(token, self.tree.document)
-
-        def processSpaceCharacters(self, token):
-            pass
-
-        def processCharacters(self, token):
-            self.insertHtmlElement()
-            return token
-
-        def processStartTag(self, token):
-            if token["name"] == "html":
-                self.parser.firstStartTag = True
-            self.insertHtmlElement()
-            return token
-
-        def processEndTag(self, token):
-            if token["name"] not in ("head", "body", "html", "br"):
-                self.parser.parseError("unexpected-end-tag-before-html",
-                                       {"name": token["name"]})
-            else:
-                self.insertHtmlElement()
-                return token
-
-    class BeforeHeadPhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            self.startTagHead(impliedTagToken("head", "StartTag"))
-            return True
-
-        def processSpaceCharacters(self, token):
-            pass
-
-        def processCharacters(self, token):
-            self.startTagHead(impliedTagToken("head", "StartTag"))
-            return token
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagHead(self, token):
-            self.tree.insertElement(token)
-            self.tree.headPointer = self.tree.openElements[-1]
-            self.parser.phase = self.parser.phases["inHead"]
-
-        def startTagOther(self, token):
-            self.startTagHead(impliedTagToken("head", "StartTag"))
-            return token
-
-        def endTagImplyHead(self, token):
-            self.startTagHead(impliedTagToken("head", "StartTag"))
-            return token
-
-        def endTagOther(self, token):
-            self.parser.parseError("end-tag-after-implied-root",
-                                   {"name": token["name"]})
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml),
-            ("head", startTagHead)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            (("head", "body", "html", "br"), endTagImplyHead)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InHeadPhase(Phase):
-        __slots__ = tuple()
-
-        # the real thing
-        def processEOF(self):
-            self.anythingElse()
-            return True
-
-        def processCharacters(self, token):
-            self.anythingElse()
-            return token
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagHead(self, token):
-            self.parser.parseError("two-heads-are-not-better-than-one")
-
-        def startTagBaseLinkCommand(self, token):
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-            token["selfClosingAcknowledged"] = True
-
-        def startTagMeta(self, token):
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-            token["selfClosingAcknowledged"] = True
-
-            attributes = token["data"]
-            if self.parser.tokenizer.stream.charEncoding[1] == "tentative":
-                if "charset" in attributes:
-                    self.parser.tokenizer.stream.changeEncoding(attributes["charset"])
-                elif ("content" in attributes and
-                      "http-equiv" in attributes and
-                      attributes["http-equiv"].lower() == "content-type"):
-                    # Encoding it as UTF-8 here is a hack, as really we should pass
-                    # the abstract Unicode string, and just use the
-                    # ContentAttrParser on that, but using UTF-8 allows all chars
-                    # to be encoded and as a ASCII-superset works.
-                    data = _inputstream.EncodingBytes(attributes["content"].encode("utf-8"))
-                    parser = _inputstream.ContentAttrParser(data)
-                    codec = parser.parse()
-                    self.parser.tokenizer.stream.changeEncoding(codec)
-
-        def startTagTitle(self, token):
-            self.parser.parseRCDataRawtext(token, "RCDATA")
-
-        def startTagNoFramesStyle(self, token):
-            # Need to decide whether to implement the scripting-disabled case
-            self.parser.parseRCDataRawtext(token, "RAWTEXT")
-
-        def startTagNoscript(self, token):
-            if self.parser.scripting:
-                self.parser.parseRCDataRawtext(token, "RAWTEXT")
-            else:
-                self.tree.insertElement(token)
-                self.parser.phase = self.parser.phases["inHeadNoscript"]
-
-        def startTagScript(self, token):
-            self.tree.insertElement(token)
-            self.parser.tokenizer.state = self.parser.tokenizer.scriptDataState
-            self.parser.originalPhase = self.parser.phase
-            self.parser.phase = self.parser.phases["text"]
-
-        def startTagOther(self, token):
-            self.anythingElse()
-            return token
-
-        def endTagHead(self, token):
-            node = self.parser.tree.openElements.pop()
-            assert node.name == "head", "Expected head got %s" % node.name
-            self.parser.phase = self.parser.phases["afterHead"]
-
-        def endTagHtmlBodyBr(self, token):
-            self.anythingElse()
-            return token
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def anythingElse(self):
-            self.endTagHead(impliedTagToken("head"))
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml),
-            ("title", startTagTitle),
-            (("noframes", "style"), startTagNoFramesStyle),
-            ("noscript", startTagNoscript),
-            ("script", startTagScript),
-            (("base", "basefont", "bgsound", "command", "link"),
-             startTagBaseLinkCommand),
-            ("meta", startTagMeta),
-            ("head", startTagHead)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("head", endTagHead),
-            (("br", "html", "body"), endTagHtmlBodyBr)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InHeadNoscriptPhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            self.parser.parseError("eof-in-head-noscript")
-            self.anythingElse()
-            return True
-
-        def processComment(self, token):
-            return self.parser.phases["inHead"].processComment(token)
-
-        def processCharacters(self, token):
-            self.parser.parseError("char-in-head-noscript")
-            self.anythingElse()
-            return token
-
-        def processSpaceCharacters(self, token):
-            return self.parser.phases["inHead"].processSpaceCharacters(token)
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagBaseLinkCommand(self, token):
-            return self.parser.phases["inHead"].processStartTag(token)
-
-        def startTagHeadNoscript(self, token):
-            self.parser.parseError("unexpected-start-tag", {"name": token["name"]})
-
-        def startTagOther(self, token):
-            self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]})
-            self.anythingElse()
-            return token
-
-        def endTagNoscript(self, token):
-            node = self.parser.tree.openElements.pop()
-            assert node.name == "noscript", "Expected noscript got %s" % node.name
-            self.parser.phase = self.parser.phases["inHead"]
-
-        def endTagBr(self, token):
-            self.parser.parseError("unexpected-inhead-noscript-tag", {"name": token["name"]})
-            self.anythingElse()
-            return token
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def anythingElse(self):
-            # Caller must raise parse error first!
-            self.endTagNoscript(impliedTagToken("noscript"))
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml),
-            (("basefont", "bgsound", "link", "meta", "noframes", "style"), startTagBaseLinkCommand),
-            (("head", "noscript"), startTagHeadNoscript),
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("noscript", endTagNoscript),
-            ("br", endTagBr),
-        ])
-        endTagHandler.default = endTagOther
-
-    class AfterHeadPhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            self.anythingElse()
-            return True
-
-        def processCharacters(self, token):
-            self.anythingElse()
-            return token
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagBody(self, token):
-            self.parser.framesetOK = False
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inBody"]
-
-        def startTagFrameset(self, token):
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inFrameset"]
-
-        def startTagFromHead(self, token):
-            self.parser.parseError("unexpected-start-tag-out-of-my-head",
-                                   {"name": token["name"]})
-            self.tree.openElements.append(self.tree.headPointer)
-            self.parser.phases["inHead"].processStartTag(token)
-            for node in self.tree.openElements[::-1]:
-                if node.name == "head":
-                    self.tree.openElements.remove(node)
-                    break
-
-        def startTagHead(self, token):
-            self.parser.parseError("unexpected-start-tag", {"name": token["name"]})
-
-        def startTagOther(self, token):
-            self.anythingElse()
-            return token
-
-        def endTagHtmlBodyBr(self, token):
-            self.anythingElse()
-            return token
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def anythingElse(self):
-            self.tree.insertElement(impliedTagToken("body", "StartTag"))
-            self.parser.phase = self.parser.phases["inBody"]
-            self.parser.framesetOK = True
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml),
-            ("body", startTagBody),
-            ("frameset", startTagFrameset),
-            (("base", "basefont", "bgsound", "link", "meta", "noframes", "script",
-              "style", "title"),
-             startTagFromHead),
-            ("head", startTagHead)
-        ])
-        startTagHandler.default = startTagOther
-        endTagHandler = _utils.MethodDispatcher([(("body", "html", "br"),
-                                                  endTagHtmlBodyBr)])
-        endTagHandler.default = endTagOther
-
-    class InBodyPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#parsing-main-inbody
-        # the really-really-really-very crazy mode
-        __slots__ = ("processSpaceCharacters",)
-
-        def __init__(self, *args, **kwargs):
-            super(InBodyPhase, self).__init__(*args, **kwargs)
-            # Set this to the default handler
-            self.processSpaceCharacters = self.processSpaceCharactersNonPre
-
-        def isMatchingFormattingElement(self, node1, node2):
-            return (node1.name == node2.name and
-                    node1.namespace == node2.namespace and
-                    node1.attributes == node2.attributes)
-
-        # helper
-        def addFormattingElement(self, token):
-            self.tree.insertElement(token)
-            element = self.tree.openElements[-1]
-
-            matchingElements = []
-            for node in self.tree.activeFormattingElements[::-1]:
-                if node is Marker:
-                    break
-                elif self.isMatchingFormattingElement(node, element):
-                    matchingElements.append(node)
-
-            assert len(matchingElements) <= 3
-            if len(matchingElements) == 3:
-                self.tree.activeFormattingElements.remove(matchingElements[-1])
-            self.tree.activeFormattingElements.append(element)
-
-        # the real deal
-        def processEOF(self):
-            allowed_elements = frozenset(("dd", "dt", "li", "p", "tbody", "td",
-                                          "tfoot", "th", "thead", "tr", "body",
-                                          "html"))
-            for node in self.tree.openElements[::-1]:
-                if node.name not in allowed_elements:
-                    self.parser.parseError("expected-closing-tag-but-got-eof")
-                    break
-            # Stop parsing
-
-        def processSpaceCharactersDropNewline(self, token):
-            # Sometimes (start of <pre>, <listing>, and <textarea> blocks) we
-            # want to drop leading newlines
-            data = token["data"]
-            self.processSpaceCharacters = self.processSpaceCharactersNonPre
-            if (data.startswith("\n") and
-                self.tree.openElements[-1].name in ("pre", "listing", "textarea") and
-                    not self.tree.openElements[-1].hasContent()):
-                data = data[1:]
-            if data:
-                self.tree.reconstructActiveFormattingElements()
-                self.tree.insertText(data)
-
-        def processCharacters(self, token):
-            if token["data"] == "\u0000":
-                # The tokenizer should always emit null on its own
-                return
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertText(token["data"])
-            # This must be bad for performance
-            if (self.parser.framesetOK and
-                any([char not in spaceCharacters
-                     for char in token["data"]])):
-                self.parser.framesetOK = False
-
-        def processSpaceCharactersNonPre(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertText(token["data"])
-
-        def startTagProcessInHead(self, token):
-            return self.parser.phases["inHead"].processStartTag(token)
-
-        def startTagBody(self, token):
-            self.parser.parseError("unexpected-start-tag", {"name": "body"})
-            if (len(self.tree.openElements) == 1 or
-                    self.tree.openElements[1].name != "body"):
-                assert self.parser.innerHTML
-            else:
-                self.parser.framesetOK = False
-                for attr, value in token["data"].items():
-                    if attr not in self.tree.openElements[1].attributes:
-                        self.tree.openElements[1].attributes[attr] = value
-
-        def startTagFrameset(self, token):
-            self.parser.parseError("unexpected-start-tag", {"name": "frameset"})
-            if (len(self.tree.openElements) == 1 or self.tree.openElements[1].name != "body"):
-                assert self.parser.innerHTML
-            elif not self.parser.framesetOK:
-                pass
-            else:
-                if self.tree.openElements[1].parent:
-                    self.tree.openElements[1].parent.removeChild(self.tree.openElements[1])
-                while self.tree.openElements[-1].name != "html":
-                    self.tree.openElements.pop()
-                self.tree.insertElement(token)
-                self.parser.phase = self.parser.phases["inFrameset"]
-
-        def startTagCloseP(self, token):
-            if self.tree.elementInScope("p", variant="button"):
-                self.endTagP(impliedTagToken("p"))
-            self.tree.insertElement(token)
-
-        def startTagPreListing(self, token):
-            if self.tree.elementInScope("p", variant="button"):
-                self.endTagP(impliedTagToken("p"))
-            self.tree.insertElement(token)
-            self.parser.framesetOK = False
-            self.processSpaceCharacters = self.processSpaceCharactersDropNewline
-
-        def startTagForm(self, token):
-            if self.tree.formPointer:
-                self.parser.parseError("unexpected-start-tag", {"name": "form"})
-            else:
-                if self.tree.elementInScope("p", variant="button"):
-                    self.endTagP(impliedTagToken("p"))
-                self.tree.insertElement(token)
-                self.tree.formPointer = self.tree.openElements[-1]
-
-        def startTagListItem(self, token):
-            self.parser.framesetOK = False
-
-            stopNamesMap = {"li": ["li"],
-                            "dt": ["dt", "dd"],
-                            "dd": ["dt", "dd"]}
-            stopNames = stopNamesMap[token["name"]]
-            for node in reversed(self.tree.openElements):
-                if node.name in stopNames:
-                    self.parser.phase.processEndTag(
-                        impliedTagToken(node.name, "EndTag"))
-                    break
-                if (node.nameTuple in specialElements and
-                        node.name not in ("address", "div", "p")):
-                    break
-
-            if self.tree.elementInScope("p", variant="button"):
-                self.parser.phase.processEndTag(
-                    impliedTagToken("p", "EndTag"))
-
-            self.tree.insertElement(token)
-
-        def startTagPlaintext(self, token):
-            if self.tree.elementInScope("p", variant="button"):
-                self.endTagP(impliedTagToken("p"))
-            self.tree.insertElement(token)
-            self.parser.tokenizer.state = self.parser.tokenizer.plaintextState
-
-        def startTagHeading(self, token):
-            if self.tree.elementInScope("p", variant="button"):
-                self.endTagP(impliedTagToken("p"))
-            if self.tree.openElements[-1].name in headingElements:
-                self.parser.parseError("unexpected-start-tag", {"name": token["name"]})
-                self.tree.openElements.pop()
-            self.tree.insertElement(token)
-
-        def startTagA(self, token):
-            afeAElement = self.tree.elementInActiveFormattingElements("a")
-            if afeAElement:
-                self.parser.parseError("unexpected-start-tag-implies-end-tag",
-                                       {"startName": "a", "endName": "a"})
-                self.endTagFormatting(impliedTagToken("a"))
-                if afeAElement in self.tree.openElements:
-                    self.tree.openElements.remove(afeAElement)
-                if afeAElement in self.tree.activeFormattingElements:
-                    self.tree.activeFormattingElements.remove(afeAElement)
-            self.tree.reconstructActiveFormattingElements()
-            self.addFormattingElement(token)
-
-        def startTagFormatting(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.addFormattingElement(token)
-
-        def startTagNobr(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            if self.tree.elementInScope("nobr"):
-                self.parser.parseError("unexpected-start-tag-implies-end-tag",
-                                       {"startName": "nobr", "endName": "nobr"})
-                self.processEndTag(impliedTagToken("nobr"))
-                # XXX Need tests that trigger the following
-                self.tree.reconstructActiveFormattingElements()
-            self.addFormattingElement(token)
-
-        def startTagButton(self, token):
-            if self.tree.elementInScope("button"):
-                self.parser.parseError("unexpected-start-tag-implies-end-tag",
-                                       {"startName": "button", "endName": "button"})
-                self.processEndTag(impliedTagToken("button"))
-                return token
-            else:
-                self.tree.reconstructActiveFormattingElements()
-                self.tree.insertElement(token)
-                self.parser.framesetOK = False
-
-        def startTagAppletMarqueeObject(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertElement(token)
-            self.tree.activeFormattingElements.append(Marker)
-            self.parser.framesetOK = False
-
-        def startTagXmp(self, token):
-            if self.tree.elementInScope("p", variant="button"):
-                self.endTagP(impliedTagToken("p"))
-            self.tree.reconstructActiveFormattingElements()
-            self.parser.framesetOK = False
-            self.parser.parseRCDataRawtext(token, "RAWTEXT")
-
-        def startTagTable(self, token):
-            if self.parser.compatMode != "quirks":
-                if self.tree.elementInScope("p", variant="button"):
-                    self.processEndTag(impliedTagToken("p"))
-            self.tree.insertElement(token)
-            self.parser.framesetOK = False
-            self.parser.phase = self.parser.phases["inTable"]
-
-        def startTagVoidFormatting(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-            token["selfClosingAcknowledged"] = True
-            self.parser.framesetOK = False
-
-        def startTagInput(self, token):
-            framesetOK = self.parser.framesetOK
-            self.startTagVoidFormatting(token)
-            if ("type" in token["data"] and
-                    token["data"]["type"].translate(asciiUpper2Lower) == "hidden"):
-                # input type=hidden doesn't change framesetOK
-                self.parser.framesetOK = framesetOK
-
-        def startTagParamSource(self, token):
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-            token["selfClosingAcknowledged"] = True
-
-        def startTagHr(self, token):
-            if self.tree.elementInScope("p", variant="button"):
-                self.endTagP(impliedTagToken("p"))
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-            token["selfClosingAcknowledged"] = True
-            self.parser.framesetOK = False
-
-        def startTagImage(self, token):
-            # No really...
-            self.parser.parseError("unexpected-start-tag-treated-as",
-                                   {"originalName": "image", "newName": "img"})
-            self.processStartTag(impliedTagToken("img", "StartTag",
-                                                 attributes=token["data"],
-                                                 selfClosing=token["selfClosing"]))
-
-        def startTagIsIndex(self, token):
-            self.parser.parseError("deprecated-tag", {"name": "isindex"})
-            if self.tree.formPointer:
-                return
-            form_attrs = {}
-            if "action" in token["data"]:
-                form_attrs["action"] = token["data"]["action"]
-            self.processStartTag(impliedTagToken("form", "StartTag",
-                                                 attributes=form_attrs))
-            self.processStartTag(impliedTagToken("hr", "StartTag"))
-            self.processStartTag(impliedTagToken("label", "StartTag"))
-            # XXX Localization ...
-            if "prompt" in token["data"]:
-                prompt = token["data"]["prompt"]
-            else:
-                prompt = "This is a searchable index. Enter search keywords: "
-            self.processCharacters(
-                {"type": tokenTypes["Characters"], "data": prompt})
-            attributes = token["data"].copy()
-            if "action" in attributes:
-                del attributes["action"]
-            if "prompt" in attributes:
-                del attributes["prompt"]
-            attributes["name"] = "isindex"
-            self.processStartTag(impliedTagToken("input", "StartTag",
-                                                 attributes=attributes,
-                                                 selfClosing=token["selfClosing"]))
-            self.processEndTag(impliedTagToken("label"))
-            self.processStartTag(impliedTagToken("hr", "StartTag"))
-            self.processEndTag(impliedTagToken("form"))
-
-        def startTagTextarea(self, token):
-            self.tree.insertElement(token)
-            self.parser.tokenizer.state = self.parser.tokenizer.rcdataState
-            self.processSpaceCharacters = self.processSpaceCharactersDropNewline
-            self.parser.framesetOK = False
-
-        def startTagIFrame(self, token):
-            self.parser.framesetOK = False
-            self.startTagRawtext(token)
-
-        def startTagNoscript(self, token):
-            if self.parser.scripting:
-                self.startTagRawtext(token)
-            else:
-                self.startTagOther(token)
-
-        def startTagRawtext(self, token):
-            """iframe, noembed noframes, noscript(if scripting enabled)"""
-            self.parser.parseRCDataRawtext(token, "RAWTEXT")
-
-        def startTagOpt(self, token):
-            if self.tree.openElements[-1].name == "option":
-                self.parser.phase.processEndTag(impliedTagToken("option"))
-            self.tree.reconstructActiveFormattingElements()
-            self.parser.tree.insertElement(token)
-
-        def startTagSelect(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertElement(token)
-            self.parser.framesetOK = False
-            if self.parser.phase in (self.parser.phases["inTable"],
-                                     self.parser.phases["inCaption"],
-                                     self.parser.phases["inColumnGroup"],
-                                     self.parser.phases["inTableBody"],
-                                     self.parser.phases["inRow"],
-                                     self.parser.phases["inCell"]):
-                self.parser.phase = self.parser.phases["inSelectInTable"]
-            else:
-                self.parser.phase = self.parser.phases["inSelect"]
-
-        def startTagRpRt(self, token):
-            if self.tree.elementInScope("ruby"):
-                self.tree.generateImpliedEndTags()
-                if self.tree.openElements[-1].name != "ruby":
-                    self.parser.parseError()
-            self.tree.insertElement(token)
-
-        def startTagMath(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.parser.adjustMathMLAttributes(token)
-            self.parser.adjustForeignAttributes(token)
-            token["namespace"] = namespaces["mathml"]
-            self.tree.insertElement(token)
-            # Need to get the parse error right for the case where the token
-            # has a namespace not equal to the xmlns attribute
-            if token["selfClosing"]:
-                self.tree.openElements.pop()
-                token["selfClosingAcknowledged"] = True
-
-        def startTagSvg(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.parser.adjustSVGAttributes(token)
-            self.parser.adjustForeignAttributes(token)
-            token["namespace"] = namespaces["svg"]
-            self.tree.insertElement(token)
-            # Need to get the parse error right for the case where the token
-            # has a namespace not equal to the xmlns attribute
-            if token["selfClosing"]:
-                self.tree.openElements.pop()
-                token["selfClosingAcknowledged"] = True
-
-        def startTagMisplaced(self, token):
-            """ Elements that should be children of other elements that have a
-            different insertion mode; here they are ignored
-            "caption", "col", "colgroup", "frame", "frameset", "head",
-            "option", "optgroup", "tbody", "td", "tfoot", "th", "thead",
-            "tr", "noscript"
-            """
-            self.parser.parseError("unexpected-start-tag-ignored", {"name": token["name"]})
-
-        def startTagOther(self, token):
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertElement(token)
-
-        def endTagP(self, token):
-            if not self.tree.elementInScope("p", variant="button"):
-                self.startTagCloseP(impliedTagToken("p", "StartTag"))
-                self.parser.parseError("unexpected-end-tag", {"name": "p"})
-                self.endTagP(impliedTagToken("p", "EndTag"))
-            else:
-                self.tree.generateImpliedEndTags("p")
-                if self.tree.openElements[-1].name != "p":
-                    self.parser.parseError("unexpected-end-tag", {"name": "p"})
-                node = self.tree.openElements.pop()
-                while node.name != "p":
-                    node = self.tree.openElements.pop()
-
-        def endTagBody(self, token):
-            if not self.tree.elementInScope("body"):
-                self.parser.parseError()
-                return
-            elif self.tree.openElements[-1].name != "body":
-                for node in self.tree.openElements[2:]:
-                    if node.name not in frozenset(("dd", "dt", "li", "optgroup",
-                                                   "option", "p", "rp", "rt",
-                                                   "tbody", "td", "tfoot",
-                                                   "th", "thead", "tr", "body",
-                                                   "html")):
-                        # Not sure this is the correct name for the parse error
-                        self.parser.parseError(
-                            "expected-one-end-tag-but-got-another",
-                            {"gotName": "body", "expectedName": node.name})
-                        break
-            self.parser.phase = self.parser.phases["afterBody"]
-
-        def endTagHtml(self, token):
-            # We repeat the test for the body end tag token being ignored here
-            if self.tree.elementInScope("body"):
-                self.endTagBody(impliedTagToken("body"))
-                return token
-
-        def endTagBlock(self, token):
-            # Put us back in the right whitespace handling mode
-            if token["name"] == "pre":
-                self.processSpaceCharacters = self.processSpaceCharactersNonPre
-            inScope = self.tree.elementInScope(token["name"])
-            if inScope:
-                self.tree.generateImpliedEndTags()
-            if self.tree.openElements[-1].name != token["name"]:
-                self.parser.parseError("end-tag-too-early", {"name": token["name"]})
-            if inScope:
-                node = self.tree.openElements.pop()
-                while node.name != token["name"]:
-                    node = self.tree.openElements.pop()
-
-        def endTagForm(self, token):
-            node = self.tree.formPointer
-            self.tree.formPointer = None
-            if node is None or not self.tree.elementInScope(node):
-                self.parser.parseError("unexpected-end-tag",
-                                       {"name": "form"})
-            else:
-                self.tree.generateImpliedEndTags()
-                if self.tree.openElements[-1] != node:
-                    self.parser.parseError("end-tag-too-early-ignored",
-                                           {"name": "form"})
-                self.tree.openElements.remove(node)
-
-        def endTagListItem(self, token):
-            if token["name"] == "li":
-                variant = "list"
-            else:
-                variant = None
-            if not self.tree.elementInScope(token["name"], variant=variant):
-                self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-            else:
-                self.tree.generateImpliedEndTags(exclude=token["name"])
-                if self.tree.openElements[-1].name != token["name"]:
-                    self.parser.parseError(
-                        "end-tag-too-early",
-                        {"name": token["name"]})
-                node = self.tree.openElements.pop()
-                while node.name != token["name"]:
-                    node = self.tree.openElements.pop()
-
-        def endTagHeading(self, token):
-            for item in headingElements:
-                if self.tree.elementInScope(item):
-                    self.tree.generateImpliedEndTags()
-                    break
-            if self.tree.openElements[-1].name != token["name"]:
-                self.parser.parseError("end-tag-too-early", {"name": token["name"]})
-
-            for item in headingElements:
-                if self.tree.elementInScope(item):
-                    item = self.tree.openElements.pop()
-                    while item.name not in headingElements:
-                        item = self.tree.openElements.pop()
-                    break
-
-        def endTagFormatting(self, token):
-            """The much-feared adoption agency algorithm"""
-            # http://svn.whatwg.org/webapps/complete.html#adoptionAgency revision 7867
-            # XXX Better parseError messages appreciated.
-
-            # Step 1
-            outerLoopCounter = 0
-
-            # Step 2
-            while outerLoopCounter < 8:
-
-                # Step 3
-                outerLoopCounter += 1
-
-                # Step 4:
-
-                # Let the formatting element be the last element in
-                # the list of active formatting elements that:
-                # - is between the end of the list and the last scope
-                # marker in the list, if any, or the start of the list
-                # otherwise, and
-                # - has the same tag name as the token.
-                formattingElement = self.tree.elementInActiveFormattingElements(
-                    token["name"])
-                if (not formattingElement or
-                    (formattingElement in self.tree.openElements and
-                     not self.tree.elementInScope(formattingElement.name))):
-                    # If there is no such node, then abort these steps
-                    # and instead act as described in the "any other
-                    # end tag" entry below.
-                    self.endTagOther(token)
-                    return
-
-                # Otherwise, if there is such a node, but that node is
-                # not in the stack of open elements, then this is a
-                # parse error; remove the element from the list, and
-                # abort these steps.
-                elif formattingElement not in self.tree.openElements:
-                    self.parser.parseError("adoption-agency-1.2", {"name": token["name"]})
-                    self.tree.activeFormattingElements.remove(formattingElement)
-                    return
-
-                # Otherwise, if there is such a node, and that node is
-                # also in the stack of open elements, but the element
-                # is not in scope, then this is a parse error; ignore
-                # the token, and abort these steps.
-                elif not self.tree.elementInScope(formattingElement.name):
-                    self.parser.parseError("adoption-agency-4.4", {"name": token["name"]})
-                    return
-
-                # Otherwise, there is a formatting element and that
-                # element is in the stack and is in scope. If the
-                # element is not the current node, this is a parse
-                # error. In any case, proceed with the algorithm as
-                # written in the following steps.
-                else:
-                    if formattingElement != self.tree.openElements[-1]:
-                        self.parser.parseError("adoption-agency-1.3", {"name": token["name"]})
-
-                # Step 5:
-
-                # Let the furthest block be the topmost node in the
-                # stack of open elements that is lower in the stack
-                # than the formatting element, and is an element in
-                # the special category. There might not be one.
-                afeIndex = self.tree.openElements.index(formattingElement)
-                furthestBlock = None
-                for element in self.tree.openElements[afeIndex:]:
-                    if element.nameTuple in specialElements:
-                        furthestBlock = element
-                        break
-
-                # Step 6:
-
-                # If there is no furthest block, then the UA must
-                # first pop all the nodes from the bottom of the stack
-                # of open elements, from the current node up to and
-                # including the formatting element, then remove the
-                # formatting element from the list of active
-                # formatting elements, and finally abort these steps.
-                if furthestBlock is None:
-                    element = self.tree.openElements.pop()
-                    while element != formattingElement:
-                        element = self.tree.openElements.pop()
-                    self.tree.activeFormattingElements.remove(element)
-                    return
-
-                # Step 7
-                commonAncestor = self.tree.openElements[afeIndex - 1]
-
-                # Step 8:
-                # The bookmark is supposed to help us identify where to reinsert
-                # nodes in step 15. We have to ensure that we reinsert nodes after
-                # the node before the active formatting element. Note the bookmark
-                # can move in step 9.7
-                bookmark = self.tree.activeFormattingElements.index(formattingElement)
-
-                # Step 9
-                lastNode = node = furthestBlock
-                innerLoopCounter = 0
-
-                index = self.tree.openElements.index(node)
-                while innerLoopCounter < 3:
-                    innerLoopCounter += 1
-                    # Node is element before node in open elements
-                    index -= 1
-                    node = self.tree.openElements[index]
-                    if node not in self.tree.activeFormattingElements:
-                        self.tree.openElements.remove(node)
-                        continue
-                    # Step 9.6
-                    if node == formattingElement:
-                        break
-                    # Step 9.7
-                    if lastNode == furthestBlock:
-                        bookmark = self.tree.activeFormattingElements.index(node) + 1
-                    # Step 9.8
-                    clone = node.cloneNode()
-                    # Replace node with clone
-                    self.tree.activeFormattingElements[
-                        self.tree.activeFormattingElements.index(node)] = clone
-                    self.tree.openElements[
-                        self.tree.openElements.index(node)] = clone
-                    node = clone
-                    # Step 9.9
-                    # Remove lastNode from its parents, if any
-                    if lastNode.parent:
-                        lastNode.parent.removeChild(lastNode)
-                    node.appendChild(lastNode)
-                    # Step 9.10
-                    lastNode = node
-
-                # Step 10
-                # Foster parent lastNode if commonAncestor is a
-                # table, tbody, tfoot, thead, or tr we need to foster
-                # parent the lastNode
-                if lastNode.parent:
-                    lastNode.parent.removeChild(lastNode)
-
-                if commonAncestor.name in frozenset(("table", "tbody", "tfoot", "thead", "tr")):
-                    parent, insertBefore = self.tree.getTableMisnestedNodePosition()
-                    parent.insertBefore(lastNode, insertBefore)
-                else:
-                    commonAncestor.appendChild(lastNode)
-
-                # Step 11
-                clone = formattingElement.cloneNode()
-
-                # Step 12
-                furthestBlock.reparentChildren(clone)
-
-                # Step 13
-                furthestBlock.appendChild(clone)
-
-                # Step 14
-                self.tree.activeFormattingElements.remove(formattingElement)
-                self.tree.activeFormattingElements.insert(bookmark, clone)
-
-                # Step 15
-                self.tree.openElements.remove(formattingElement)
-                self.tree.openElements.insert(
-                    self.tree.openElements.index(furthestBlock) + 1, clone)
-
-        def endTagAppletMarqueeObject(self, token):
-            if self.tree.elementInScope(token["name"]):
-                self.tree.generateImpliedEndTags()
-            if self.tree.openElements[-1].name != token["name"]:
-                self.parser.parseError("end-tag-too-early", {"name": token["name"]})
-
-            if self.tree.elementInScope(token["name"]):
-                element = self.tree.openElements.pop()
-                while element.name != token["name"]:
-                    element = self.tree.openElements.pop()
-                self.tree.clearActiveFormattingElements()
-
-        def endTagBr(self, token):
-            self.parser.parseError("unexpected-end-tag-treated-as",
-                                   {"originalName": "br", "newName": "br element"})
-            self.tree.reconstructActiveFormattingElements()
-            self.tree.insertElement(impliedTagToken("br", "StartTag"))
-            self.tree.openElements.pop()
-
-        def endTagOther(self, token):
-            for node in self.tree.openElements[::-1]:
-                if node.name == token["name"]:
-                    self.tree.generateImpliedEndTags(exclude=token["name"])
-                    if self.tree.openElements[-1].name != token["name"]:
-                        self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-                    while self.tree.openElements.pop() != node:
-                        pass
-                    break
-                else:
-                    if node.nameTuple in specialElements:
-                        self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-                        break
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            (("base", "basefont", "bgsound", "command", "link", "meta",
-              "script", "style", "title"),
-             startTagProcessInHead),
-            ("body", startTagBody),
-            ("frameset", startTagFrameset),
-            (("address", "article", "aside", "blockquote", "center", "details",
-              "dir", "div", "dl", "fieldset", "figcaption", "figure",
-              "footer", "header", "hgroup", "main", "menu", "nav", "ol", "p",
-              "section", "summary", "ul"),
-             startTagCloseP),
-            (headingElements, startTagHeading),
-            (("pre", "listing"), startTagPreListing),
-            ("form", startTagForm),
-            (("li", "dd", "dt"), startTagListItem),
-            ("plaintext", startTagPlaintext),
-            ("a", startTagA),
-            (("b", "big", "code", "em", "font", "i", "s", "small", "strike",
-              "strong", "tt", "u"), startTagFormatting),
-            ("nobr", startTagNobr),
-            ("button", startTagButton),
-            (("applet", "marquee", "object"), startTagAppletMarqueeObject),
-            ("xmp", startTagXmp),
-            ("table", startTagTable),
-            (("area", "br", "embed", "img", "keygen", "wbr"),
-             startTagVoidFormatting),
-            (("param", "source", "track"), startTagParamSource),
-            ("input", startTagInput),
-            ("hr", startTagHr),
-            ("image", startTagImage),
-            ("isindex", startTagIsIndex),
-            ("textarea", startTagTextarea),
-            ("iframe", startTagIFrame),
-            ("noscript", startTagNoscript),
-            (("noembed", "noframes"), startTagRawtext),
-            ("select", startTagSelect),
-            (("rp", "rt"), startTagRpRt),
-            (("option", "optgroup"), startTagOpt),
-            (("math"), startTagMath),
-            (("svg"), startTagSvg),
-            (("caption", "col", "colgroup", "frame", "head",
-              "tbody", "td", "tfoot", "th", "thead",
-              "tr"), startTagMisplaced)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("body", endTagBody),
-            ("html", endTagHtml),
-            (("address", "article", "aside", "blockquote", "button", "center",
-              "details", "dialog", "dir", "div", "dl", "fieldset", "figcaption", "figure",
-              "footer", "header", "hgroup", "listing", "main", "menu", "nav", "ol", "pre",
-              "section", "summary", "ul"), endTagBlock),
-            ("form", endTagForm),
-            ("p", endTagP),
-            (("dd", "dt", "li"), endTagListItem),
-            (headingElements, endTagHeading),
-            (("a", "b", "big", "code", "em", "font", "i", "nobr", "s", "small",
-              "strike", "strong", "tt", "u"), endTagFormatting),
-            (("applet", "marquee", "object"), endTagAppletMarqueeObject),
-            ("br", endTagBr),
-        ])
-        endTagHandler.default = endTagOther
-
-    class TextPhase(Phase):
-        __slots__ = tuple()
-
-        def processCharacters(self, token):
-            self.tree.insertText(token["data"])
-
-        def processEOF(self):
-            self.parser.parseError("expected-named-closing-tag-but-got-eof",
-                                   {"name": self.tree.openElements[-1].name})
-            self.tree.openElements.pop()
-            self.parser.phase = self.parser.originalPhase
-            return True
-
-        def startTagOther(self, token):
-            assert False, "Tried to process start tag %s in RCDATA/RAWTEXT mode" % token['name']
-
-        def endTagScript(self, token):
-            node = self.tree.openElements.pop()
-            assert node.name == "script"
-            self.parser.phase = self.parser.originalPhase
-            # The rest of this method is all stuff that only happens if
-            # document.write works
-
-        def endTagOther(self, token):
-            self.tree.openElements.pop()
-            self.parser.phase = self.parser.originalPhase
-
-        startTagHandler = _utils.MethodDispatcher([])
-        startTagHandler.default = startTagOther
-        endTagHandler = _utils.MethodDispatcher([
-            ("script", endTagScript)])
-        endTagHandler.default = endTagOther
-
-    class InTablePhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-table
-        __slots__ = tuple()
-
-        # helper methods
-        def clearStackToTableContext(self):
-            # "clear the stack back to a table context"
-            while self.tree.openElements[-1].name not in ("table", "html"):
-                # self.parser.parseError("unexpected-implied-end-tag-in-table",
-                #  {"name":  self.tree.openElements[-1].name})
-                self.tree.openElements.pop()
-            # When the current node is <html> it's an innerHTML case
-
-        # processing methods
-        def processEOF(self):
-            if self.tree.openElements[-1].name != "html":
-                self.parser.parseError("eof-in-table")
-            else:
-                assert self.parser.innerHTML
-            # Stop parsing
-
-        def processSpaceCharacters(self, token):
-            originalPhase = self.parser.phase
-            self.parser.phase = self.parser.phases["inTableText"]
-            self.parser.phase.originalPhase = originalPhase
-            self.parser.phase.processSpaceCharacters(token)
-
-        def processCharacters(self, token):
-            originalPhase = self.parser.phase
-            self.parser.phase = self.parser.phases["inTableText"]
-            self.parser.phase.originalPhase = originalPhase
-            self.parser.phase.processCharacters(token)
-
-        def insertText(self, token):
-            # If we get here there must be at least one non-whitespace character
-            # Do the table magic!
-            self.tree.insertFromTable = True
-            self.parser.phases["inBody"].processCharacters(token)
-            self.tree.insertFromTable = False
-
-        def startTagCaption(self, token):
-            self.clearStackToTableContext()
-            self.tree.activeFormattingElements.append(Marker)
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inCaption"]
-
-        def startTagColgroup(self, token):
-            self.clearStackToTableContext()
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inColumnGroup"]
-
-        def startTagCol(self, token):
-            self.startTagColgroup(impliedTagToken("colgroup", "StartTag"))
-            return token
-
-        def startTagRowGroup(self, token):
-            self.clearStackToTableContext()
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inTableBody"]
-
-        def startTagImplyTbody(self, token):
-            self.startTagRowGroup(impliedTagToken("tbody", "StartTag"))
-            return token
-
-        def startTagTable(self, token):
-            self.parser.parseError("unexpected-start-tag-implies-end-tag",
-                                   {"startName": "table", "endName": "table"})
-            self.parser.phase.processEndTag(impliedTagToken("table"))
-            if not self.parser.innerHTML:
-                return token
-
-        def startTagStyleScript(self, token):
-            return self.parser.phases["inHead"].processStartTag(token)
-
-        def startTagInput(self, token):
-            if ("type" in token["data"] and
-                    token["data"]["type"].translate(asciiUpper2Lower) == "hidden"):
-                self.parser.parseError("unexpected-hidden-input-in-table")
-                self.tree.insertElement(token)
-                # XXX associate with form
-                self.tree.openElements.pop()
-            else:
-                self.startTagOther(token)
-
-        def startTagForm(self, token):
-            self.parser.parseError("unexpected-form-in-table")
-            if self.tree.formPointer is None:
-                self.tree.insertElement(token)
-                self.tree.formPointer = self.tree.openElements[-1]
-                self.tree.openElements.pop()
-
-        def startTagOther(self, token):
-            self.parser.parseError("unexpected-start-tag-implies-table-voodoo", {"name": token["name"]})
-            # Do the table magic!
-            self.tree.insertFromTable = True
-            self.parser.phases["inBody"].processStartTag(token)
-            self.tree.insertFromTable = False
-
-        def endTagTable(self, token):
-            if self.tree.elementInScope("table", variant="table"):
-                self.tree.generateImpliedEndTags()
-                if self.tree.openElements[-1].name != "table":
-                    self.parser.parseError("end-tag-too-early-named",
-                                           {"gotName": "table",
-                                            "expectedName": self.tree.openElements[-1].name})
-                while self.tree.openElements[-1].name != "table":
-                    self.tree.openElements.pop()
-                self.tree.openElements.pop()
-                self.parser.resetInsertionMode()
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def endTagIgnore(self, token):
-            self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag-implies-table-voodoo", {"name": token["name"]})
-            # Do the table magic!
-            self.tree.insertFromTable = True
-            self.parser.phases["inBody"].processEndTag(token)
-            self.tree.insertFromTable = False
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            ("caption", startTagCaption),
-            ("colgroup", startTagColgroup),
-            ("col", startTagCol),
-            (("tbody", "tfoot", "thead"), startTagRowGroup),
-            (("td", "th", "tr"), startTagImplyTbody),
-            ("table", startTagTable),
-            (("style", "script"), startTagStyleScript),
-            ("input", startTagInput),
-            ("form", startTagForm)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("table", endTagTable),
-            (("body", "caption", "col", "colgroup", "html", "tbody", "td",
-              "tfoot", "th", "thead", "tr"), endTagIgnore)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InTableTextPhase(Phase):
-        __slots__ = ("originalPhase", "characterTokens")
-
-        def __init__(self, *args, **kwargs):
-            super(InTableTextPhase, self).__init__(*args, **kwargs)
-            self.originalPhase = None
-            self.characterTokens = []
-
-        def flushCharacters(self):
-            data = "".join([item["data"] for item in self.characterTokens])
-            if any([item not in spaceCharacters for item in data]):
-                token = {"type": tokenTypes["Characters"], "data": data}
-                self.parser.phases["inTable"].insertText(token)
-            elif data:
-                self.tree.insertText(data)
-            self.characterTokens = []
-
-        def processComment(self, token):
-            self.flushCharacters()
-            self.parser.phase = self.originalPhase
-            return token
-
-        def processEOF(self):
-            self.flushCharacters()
-            self.parser.phase = self.originalPhase
-            return True
-
-        def processCharacters(self, token):
-            if token["data"] == "\u0000":
-                return
-            self.characterTokens.append(token)
-
-        def processSpaceCharacters(self, token):
-            # pretty sure we should never reach here
-            self.characterTokens.append(token)
-    #        assert False
-
-        def processStartTag(self, token):
-            self.flushCharacters()
-            self.parser.phase = self.originalPhase
-            return token
-
-        def processEndTag(self, token):
-            self.flushCharacters()
-            self.parser.phase = self.originalPhase
-            return token
-
-    class InCaptionPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-caption
-        __slots__ = tuple()
-
-        def ignoreEndTagCaption(self):
-            return not self.tree.elementInScope("caption", variant="table")
-
-        def processEOF(self):
-            self.parser.phases["inBody"].processEOF()
-
-        def processCharacters(self, token):
-            return self.parser.phases["inBody"].processCharacters(token)
-
-        def startTagTableElement(self, token):
-            self.parser.parseError()
-            # XXX Have to duplicate logic here to find out if the tag is ignored
-            ignoreEndTag = self.ignoreEndTagCaption()
-            self.parser.phase.processEndTag(impliedTagToken("caption"))
-            if not ignoreEndTag:
-                return token
-
-        def startTagOther(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def endTagCaption(self, token):
-            if not self.ignoreEndTagCaption():
-                # AT this code is quite similar to endTagTable in "InTable"
-                self.tree.generateImpliedEndTags()
-                if self.tree.openElements[-1].name != "caption":
-                    self.parser.parseError("expected-one-end-tag-but-got-another",
-                                           {"gotName": "caption",
-                                            "expectedName": self.tree.openElements[-1].name})
-                while self.tree.openElements[-1].name != "caption":
-                    self.tree.openElements.pop()
-                self.tree.openElements.pop()
-                self.tree.clearActiveFormattingElements()
-                self.parser.phase = self.parser.phases["inTable"]
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def endTagTable(self, token):
-            self.parser.parseError()
-            ignoreEndTag = self.ignoreEndTagCaption()
-            self.parser.phase.processEndTag(impliedTagToken("caption"))
-            if not ignoreEndTag:
-                return token
-
-        def endTagIgnore(self, token):
-            self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def endTagOther(self, token):
-            return self.parser.phases["inBody"].processEndTag(token)
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th",
-              "thead", "tr"), startTagTableElement)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("caption", endTagCaption),
-            ("table", endTagTable),
-            (("body", "col", "colgroup", "html", "tbody", "td", "tfoot", "th",
-              "thead", "tr"), endTagIgnore)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InColumnGroupPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-column
-        __slots__ = tuple()
-
-        def ignoreEndTagColgroup(self):
-            return self.tree.openElements[-1].name == "html"
-
-        def processEOF(self):
-            if self.tree.openElements[-1].name == "html":
-                assert self.parser.innerHTML
-                return
-            else:
-                ignoreEndTag = self.ignoreEndTagColgroup()
-                self.endTagColgroup(impliedTagToken("colgroup"))
-                if not ignoreEndTag:
-                    return True
-
-        def processCharacters(self, token):
-            ignoreEndTag = self.ignoreEndTagColgroup()
-            self.endTagColgroup(impliedTagToken("colgroup"))
-            if not ignoreEndTag:
-                return token
-
-        def startTagCol(self, token):
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-            token["selfClosingAcknowledged"] = True
-
-        def startTagOther(self, token):
-            ignoreEndTag = self.ignoreEndTagColgroup()
-            self.endTagColgroup(impliedTagToken("colgroup"))
-            if not ignoreEndTag:
-                return token
-
-        def endTagColgroup(self, token):
-            if self.ignoreEndTagColgroup():
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-            else:
-                self.tree.openElements.pop()
-                self.parser.phase = self.parser.phases["inTable"]
-
-        def endTagCol(self, token):
-            self.parser.parseError("no-end-tag", {"name": "col"})
-
-        def endTagOther(self, token):
-            ignoreEndTag = self.ignoreEndTagColgroup()
-            self.endTagColgroup(impliedTagToken("colgroup"))
-            if not ignoreEndTag:
-                return token
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            ("col", startTagCol)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("colgroup", endTagColgroup),
-            ("col", endTagCol)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InTableBodyPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-table0
-        __slots__ = tuple()
-
-        # helper methods
-        def clearStackToTableBodyContext(self):
-            while self.tree.openElements[-1].name not in ("tbody", "tfoot",
-                                                          "thead", "html"):
-                # self.parser.parseError("unexpected-implied-end-tag-in-table",
-                #  {"name": self.tree.openElements[-1].name})
-                self.tree.openElements.pop()
-            if self.tree.openElements[-1].name == "html":
-                assert self.parser.innerHTML
-
-        # the rest
-        def processEOF(self):
-            self.parser.phases["inTable"].processEOF()
-
-        def processSpaceCharacters(self, token):
-            return self.parser.phases["inTable"].processSpaceCharacters(token)
-
-        def processCharacters(self, token):
-            return self.parser.phases["inTable"].processCharacters(token)
-
-        def startTagTr(self, token):
-            self.clearStackToTableBodyContext()
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inRow"]
-
-        def startTagTableCell(self, token):
-            self.parser.parseError("unexpected-cell-in-table-body",
-                                   {"name": token["name"]})
-            self.startTagTr(impliedTagToken("tr", "StartTag"))
-            return token
-
-        def startTagTableOther(self, token):
-            # XXX AT Any ideas on how to share this with endTagTable?
-            if (self.tree.elementInScope("tbody", variant="table") or
-                self.tree.elementInScope("thead", variant="table") or
-                    self.tree.elementInScope("tfoot", variant="table")):
-                self.clearStackToTableBodyContext()
-                self.endTagTableRowGroup(
-                    impliedTagToken(self.tree.openElements[-1].name))
-                return token
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def startTagOther(self, token):
-            return self.parser.phases["inTable"].processStartTag(token)
-
-        def endTagTableRowGroup(self, token):
-            if self.tree.elementInScope(token["name"], variant="table"):
-                self.clearStackToTableBodyContext()
-                self.tree.openElements.pop()
-                self.parser.phase = self.parser.phases["inTable"]
-            else:
-                self.parser.parseError("unexpected-end-tag-in-table-body",
-                                       {"name": token["name"]})
-
-        def endTagTable(self, token):
-            if (self.tree.elementInScope("tbody", variant="table") or
-                self.tree.elementInScope("thead", variant="table") or
-                    self.tree.elementInScope("tfoot", variant="table")):
-                self.clearStackToTableBodyContext()
-                self.endTagTableRowGroup(
-                    impliedTagToken(self.tree.openElements[-1].name))
-                return token
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def endTagIgnore(self, token):
-            self.parser.parseError("unexpected-end-tag-in-table-body",
-                                   {"name": token["name"]})
-
-        def endTagOther(self, token):
-            return self.parser.phases["inTable"].processEndTag(token)
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            ("tr", startTagTr),
-            (("td", "th"), startTagTableCell),
-            (("caption", "col", "colgroup", "tbody", "tfoot", "thead"),
-             startTagTableOther)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            (("tbody", "tfoot", "thead"), endTagTableRowGroup),
-            ("table", endTagTable),
-            (("body", "caption", "col", "colgroup", "html", "td", "th",
-              "tr"), endTagIgnore)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InRowPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-row
-        __slots__ = tuple()
-
-        # helper methods (XXX unify this with other table helper methods)
-        def clearStackToTableRowContext(self):
-            while self.tree.openElements[-1].name not in ("tr", "html"):
-                self.parser.parseError("unexpected-implied-end-tag-in-table-row",
-                                       {"name": self.tree.openElements[-1].name})
-                self.tree.openElements.pop()
-
-        def ignoreEndTagTr(self):
-            return not self.tree.elementInScope("tr", variant="table")
-
-        # the rest
-        def processEOF(self):
-            self.parser.phases["inTable"].processEOF()
-
-        def processSpaceCharacters(self, token):
-            return self.parser.phases["inTable"].processSpaceCharacters(token)
-
-        def processCharacters(self, token):
-            return self.parser.phases["inTable"].processCharacters(token)
-
-        def startTagTableCell(self, token):
-            self.clearStackToTableRowContext()
-            self.tree.insertElement(token)
-            self.parser.phase = self.parser.phases["inCell"]
-            self.tree.activeFormattingElements.append(Marker)
-
-        def startTagTableOther(self, token):
-            ignoreEndTag = self.ignoreEndTagTr()
-            self.endTagTr(impliedTagToken("tr"))
-            # XXX how are we sure it's always ignored in the innerHTML case?
-            if not ignoreEndTag:
-                return token
-
-        def startTagOther(self, token):
-            return self.parser.phases["inTable"].processStartTag(token)
-
-        def endTagTr(self, token):
-            if not self.ignoreEndTagTr():
-                self.clearStackToTableRowContext()
-                self.tree.openElements.pop()
-                self.parser.phase = self.parser.phases["inTableBody"]
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def endTagTable(self, token):
-            ignoreEndTag = self.ignoreEndTagTr()
-            self.endTagTr(impliedTagToken("tr"))
-            # Reprocess the current tag if the tr end tag was not ignored
-            # XXX how are we sure it's always ignored in the innerHTML case?
-            if not ignoreEndTag:
-                return token
-
-        def endTagTableRowGroup(self, token):
-            if self.tree.elementInScope(token["name"], variant="table"):
-                self.endTagTr(impliedTagToken("tr"))
-                return token
-            else:
-                self.parser.parseError()
-
-        def endTagIgnore(self, token):
-            self.parser.parseError("unexpected-end-tag-in-table-row",
-                                   {"name": token["name"]})
-
-        def endTagOther(self, token):
-            return self.parser.phases["inTable"].processEndTag(token)
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            (("td", "th"), startTagTableCell),
-            (("caption", "col", "colgroup", "tbody", "tfoot", "thead",
-              "tr"), startTagTableOther)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("tr", endTagTr),
-            ("table", endTagTable),
-            (("tbody", "tfoot", "thead"), endTagTableRowGroup),
-            (("body", "caption", "col", "colgroup", "html", "td", "th"),
-             endTagIgnore)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InCellPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-cell
-        __slots__ = tuple()
-
-        # helper
-        def closeCell(self):
-            if self.tree.elementInScope("td", variant="table"):
-                self.endTagTableCell(impliedTagToken("td"))
-            elif self.tree.elementInScope("th", variant="table"):
-                self.endTagTableCell(impliedTagToken("th"))
-
-        # the rest
-        def processEOF(self):
-            self.parser.phases["inBody"].processEOF()
-
-        def processCharacters(self, token):
-            return self.parser.phases["inBody"].processCharacters(token)
-
-        def startTagTableOther(self, token):
-            if (self.tree.elementInScope("td", variant="table") or
-                    self.tree.elementInScope("th", variant="table")):
-                self.closeCell()
-                return token
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def startTagOther(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def endTagTableCell(self, token):
-            if self.tree.elementInScope(token["name"], variant="table"):
-                self.tree.generateImpliedEndTags(token["name"])
-                if self.tree.openElements[-1].name != token["name"]:
-                    self.parser.parseError("unexpected-cell-end-tag",
-                                           {"name": token["name"]})
-                    while True:
-                        node = self.tree.openElements.pop()
-                        if node.name == token["name"]:
-                            break
-                else:
-                    self.tree.openElements.pop()
-                self.tree.clearActiveFormattingElements()
-                self.parser.phase = self.parser.phases["inRow"]
-            else:
-                self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def endTagIgnore(self, token):
-            self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-        def endTagImply(self, token):
-            if self.tree.elementInScope(token["name"], variant="table"):
-                self.closeCell()
-                return token
-            else:
-                # sometimes innerHTML case
-                self.parser.parseError()
-
-        def endTagOther(self, token):
-            return self.parser.phases["inBody"].processEndTag(token)
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            (("caption", "col", "colgroup", "tbody", "td", "tfoot", "th",
-              "thead", "tr"), startTagTableOther)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            (("td", "th"), endTagTableCell),
-            (("body", "caption", "col", "colgroup", "html"), endTagIgnore),
-            (("table", "tbody", "tfoot", "thead", "tr"), endTagImply)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InSelectPhase(Phase):
-        __slots__ = tuple()
-
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-select
-        def processEOF(self):
-            if self.tree.openElements[-1].name != "html":
-                self.parser.parseError("eof-in-select")
-            else:
-                assert self.parser.innerHTML
-
-        def processCharacters(self, token):
-            if token["data"] == "\u0000":
-                return
-            self.tree.insertText(token["data"])
-
-        def startTagOption(self, token):
-            # We need to imply </option> if <option> is the current node.
-            if self.tree.openElements[-1].name == "option":
-                self.tree.openElements.pop()
-            self.tree.insertElement(token)
-
-        def startTagOptgroup(self, token):
-            if self.tree.openElements[-1].name == "option":
-                self.tree.openElements.pop()
-            if self.tree.openElements[-1].name == "optgroup":
-                self.tree.openElements.pop()
-            self.tree.insertElement(token)
-
-        def startTagSelect(self, token):
-            self.parser.parseError("unexpected-select-in-select")
-            self.endTagSelect(impliedTagToken("select"))
-
-        def startTagInput(self, token):
-            self.parser.parseError("unexpected-input-in-select")
-            if self.tree.elementInScope("select", variant="select"):
-                self.endTagSelect(impliedTagToken("select"))
-                return token
-            else:
-                assert self.parser.innerHTML
-
-        def startTagScript(self, token):
-            return self.parser.phases["inHead"].processStartTag(token)
-
-        def startTagOther(self, token):
-            self.parser.parseError("unexpected-start-tag-in-select",
-                                   {"name": token["name"]})
-
-        def endTagOption(self, token):
-            if self.tree.openElements[-1].name == "option":
-                self.tree.openElements.pop()
-            else:
-                self.parser.parseError("unexpected-end-tag-in-select",
-                                       {"name": "option"})
-
-        def endTagOptgroup(self, token):
-            # </optgroup> implicitly closes <option>
-            if (self.tree.openElements[-1].name == "option" and
-                    self.tree.openElements[-2].name == "optgroup"):
-                self.tree.openElements.pop()
-            # It also closes </optgroup>
-            if self.tree.openElements[-1].name == "optgroup":
-                self.tree.openElements.pop()
-            # But nothing else
-            else:
-                self.parser.parseError("unexpected-end-tag-in-select",
-                                       {"name": "optgroup"})
-
-        def endTagSelect(self, token):
-            if self.tree.elementInScope("select", variant="select"):
-                node = self.tree.openElements.pop()
-                while node.name != "select":
-                    node = self.tree.openElements.pop()
-                self.parser.resetInsertionMode()
-            else:
-                # innerHTML case
-                assert self.parser.innerHTML
-                self.parser.parseError()
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag-in-select",
-                                   {"name": token["name"]})
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            ("option", startTagOption),
-            ("optgroup", startTagOptgroup),
-            ("select", startTagSelect),
-            (("input", "keygen", "textarea"), startTagInput),
-            ("script", startTagScript)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("option", endTagOption),
-            ("optgroup", endTagOptgroup),
-            ("select", endTagSelect)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InSelectInTablePhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            self.parser.phases["inSelect"].processEOF()
-
-        def processCharacters(self, token):
-            return self.parser.phases["inSelect"].processCharacters(token)
-
-        def startTagTable(self, token):
-            self.parser.parseError("unexpected-table-element-start-tag-in-select-in-table", {"name": token["name"]})
-            self.endTagOther(impliedTagToken("select"))
-            return token
-
-        def startTagOther(self, token):
-            return self.parser.phases["inSelect"].processStartTag(token)
-
-        def endTagTable(self, token):
-            self.parser.parseError("unexpected-table-element-end-tag-in-select-in-table", {"name": token["name"]})
-            if self.tree.elementInScope(token["name"], variant="table"):
-                self.endTagOther(impliedTagToken("select"))
-                return token
-
-        def endTagOther(self, token):
-            return self.parser.phases["inSelect"].processEndTag(token)
-
-        startTagHandler = _utils.MethodDispatcher([
-            (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"),
-             startTagTable)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            (("caption", "table", "tbody", "tfoot", "thead", "tr", "td", "th"),
-             endTagTable)
-        ])
-        endTagHandler.default = endTagOther
-
-    class InForeignContentPhase(Phase):
-        __slots__ = tuple()
-
-        breakoutElements = frozenset(["b", "big", "blockquote", "body", "br",
-                                      "center", "code", "dd", "div", "dl", "dt",
-                                      "em", "embed", "h1", "h2", "h3",
-                                      "h4", "h5", "h6", "head", "hr", "i", "img",
-                                      "li", "listing", "menu", "meta", "nobr",
-                                      "ol", "p", "pre", "ruby", "s", "small",
-                                      "span", "strong", "strike", "sub", "sup",
-                                      "table", "tt", "u", "ul", "var"])
-
-        def adjustSVGTagNames(self, token):
-            replacements = {"altglyph": "altGlyph",
-                            "altglyphdef": "altGlyphDef",
-                            "altglyphitem": "altGlyphItem",
-                            "animatecolor": "animateColor",
-                            "animatemotion": "animateMotion",
-                            "animatetransform": "animateTransform",
-                            "clippath": "clipPath",
-                            "feblend": "feBlend",
-                            "fecolormatrix": "feColorMatrix",
-                            "fecomponenttransfer": "feComponentTransfer",
-                            "fecomposite": "feComposite",
-                            "feconvolvematrix": "feConvolveMatrix",
-                            "fediffuselighting": "feDiffuseLighting",
-                            "fedisplacementmap": "feDisplacementMap",
-                            "fedistantlight": "feDistantLight",
-                            "feflood": "feFlood",
-                            "fefunca": "feFuncA",
-                            "fefuncb": "feFuncB",
-                            "fefuncg": "feFuncG",
-                            "fefuncr": "feFuncR",
-                            "fegaussianblur": "feGaussianBlur",
-                            "feimage": "feImage",
-                            "femerge": "feMerge",
-                            "femergenode": "feMergeNode",
-                            "femorphology": "feMorphology",
-                            "feoffset": "feOffset",
-                            "fepointlight": "fePointLight",
-                            "fespecularlighting": "feSpecularLighting",
-                            "fespotlight": "feSpotLight",
-                            "fetile": "feTile",
-                            "feturbulence": "feTurbulence",
-                            "foreignobject": "foreignObject",
-                            "glyphref": "glyphRef",
-                            "lineargradient": "linearGradient",
-                            "radialgradient": "radialGradient",
-                            "textpath": "textPath"}
-
-            if token["name"] in replacements:
-                token["name"] = replacements[token["name"]]
-
-        def processCharacters(self, token):
-            if token["data"] == "\u0000":
-                token["data"] = "\uFFFD"
-            elif (self.parser.framesetOK and
-                  any(char not in spaceCharacters for char in token["data"])):
-                self.parser.framesetOK = False
-            Phase.processCharacters(self, token)
-
-        def processStartTag(self, token):
-            currentNode = self.tree.openElements[-1]
-            if (token["name"] in self.breakoutElements or
-                (token["name"] == "font" and
-                 set(token["data"].keys()) & {"color", "face", "size"})):
-                self.parser.parseError("unexpected-html-element-in-foreign-content",
-                                       {"name": token["name"]})
-                while (self.tree.openElements[-1].namespace !=
-                       self.tree.defaultNamespace and
-                       not self.parser.isHTMLIntegrationPoint(self.tree.openElements[-1]) and
-                       not self.parser.isMathMLTextIntegrationPoint(self.tree.openElements[-1])):
-                    self.tree.openElements.pop()
-                return token
-
-            else:
-                if currentNode.namespace == namespaces["mathml"]:
-                    self.parser.adjustMathMLAttributes(token)
-                elif currentNode.namespace == namespaces["svg"]:
-                    self.adjustSVGTagNames(token)
-                    self.parser.adjustSVGAttributes(token)
-                self.parser.adjustForeignAttributes(token)
-                token["namespace"] = currentNode.namespace
-                self.tree.insertElement(token)
-                if token["selfClosing"]:
-                    self.tree.openElements.pop()
-                    token["selfClosingAcknowledged"] = True
-
-        def processEndTag(self, token):
-            nodeIndex = len(self.tree.openElements) - 1
-            node = self.tree.openElements[-1]
-            if node.name.translate(asciiUpper2Lower) != token["name"]:
-                self.parser.parseError("unexpected-end-tag", {"name": token["name"]})
-
-            while True:
-                if node.name.translate(asciiUpper2Lower) == token["name"]:
-                    # XXX this isn't in the spec but it seems necessary
-                    if self.parser.phase == self.parser.phases["inTableText"]:
-                        self.parser.phase.flushCharacters()
-                        self.parser.phase = self.parser.phase.originalPhase
-                    while self.tree.openElements.pop() != node:
-                        assert self.tree.openElements
-                    new_token = None
-                    break
-                nodeIndex -= 1
-
-                node = self.tree.openElements[nodeIndex]
-                if node.namespace != self.tree.defaultNamespace:
-                    continue
-                else:
-                    new_token = self.parser.phase.processEndTag(token)
-                    break
-            return new_token
-
-    class AfterBodyPhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            # Stop parsing
-            pass
-
-        def processComment(self, token):
-            # This is needed because data is to be appended to the <html> element
-            # here and not to whatever is currently open.
-            self.tree.insertComment(token, self.tree.openElements[0])
-
-        def processCharacters(self, token):
-            self.parser.parseError("unexpected-char-after-body")
-            self.parser.phase = self.parser.phases["inBody"]
-            return token
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagOther(self, token):
-            self.parser.parseError("unexpected-start-tag-after-body",
-                                   {"name": token["name"]})
-            self.parser.phase = self.parser.phases["inBody"]
-            return token
-
-        def endTagHtml(self, name):
-            if self.parser.innerHTML:
-                self.parser.parseError("unexpected-end-tag-after-body-innerhtml")
-            else:
-                self.parser.phase = self.parser.phases["afterAfterBody"]
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag-after-body",
-                                   {"name": token["name"]})
-            self.parser.phase = self.parser.phases["inBody"]
-            return token
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([("html", endTagHtml)])
-        endTagHandler.default = endTagOther
-
-    class InFramesetPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#in-frameset
-        __slots__ = tuple()
-
-        def processEOF(self):
-            if self.tree.openElements[-1].name != "html":
-                self.parser.parseError("eof-in-frameset")
-            else:
-                assert self.parser.innerHTML
-
-        def processCharacters(self, token):
-            self.parser.parseError("unexpected-char-in-frameset")
-
-        def startTagFrameset(self, token):
-            self.tree.insertElement(token)
-
-        def startTagFrame(self, token):
-            self.tree.insertElement(token)
-            self.tree.openElements.pop()
-
-        def startTagNoframes(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagOther(self, token):
-            self.parser.parseError("unexpected-start-tag-in-frameset",
-                                   {"name": token["name"]})
-
-        def endTagFrameset(self, token):
-            if self.tree.openElements[-1].name == "html":
-                # innerHTML case
-                self.parser.parseError("unexpected-frameset-in-frameset-innerhtml")
-            else:
-                self.tree.openElements.pop()
-            if (not self.parser.innerHTML and
-                    self.tree.openElements[-1].name != "frameset"):
-                # If we're not in innerHTML mode and the current node is not a
-                # "frameset" element (anymore) then switch.
-                self.parser.phase = self.parser.phases["afterFrameset"]
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag-in-frameset",
-                                   {"name": token["name"]})
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            ("frameset", startTagFrameset),
-            ("frame", startTagFrame),
-            ("noframes", startTagNoframes)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("frameset", endTagFrameset)
-        ])
-        endTagHandler.default = endTagOther
-
-    class AfterFramesetPhase(Phase):
-        # http://www.whatwg.org/specs/web-apps/current-work/#after3
-        __slots__ = tuple()
-
-        def processEOF(self):
-            # Stop parsing
-            pass
-
-        def processCharacters(self, token):
-            self.parser.parseError("unexpected-char-after-frameset")
-
-        def startTagNoframes(self, token):
-            return self.parser.phases["inHead"].processStartTag(token)
-
-        def startTagOther(self, token):
-            self.parser.parseError("unexpected-start-tag-after-frameset",
-                                   {"name": token["name"]})
-
-        def endTagHtml(self, token):
-            self.parser.phase = self.parser.phases["afterAfterFrameset"]
-
-        def endTagOther(self, token):
-            self.parser.parseError("unexpected-end-tag-after-frameset",
-                                   {"name": token["name"]})
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", Phase.startTagHtml),
-            ("noframes", startTagNoframes)
-        ])
-        startTagHandler.default = startTagOther
-
-        endTagHandler = _utils.MethodDispatcher([
-            ("html", endTagHtml)
-        ])
-        endTagHandler.default = endTagOther
-
-    class AfterAfterBodyPhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            pass
-
-        def processComment(self, token):
-            self.tree.insertComment(token, self.tree.document)
-
-        def processSpaceCharacters(self, token):
-            return self.parser.phases["inBody"].processSpaceCharacters(token)
-
-        def processCharacters(self, token):
-            self.parser.parseError("expected-eof-but-got-char")
-            self.parser.phase = self.parser.phases["inBody"]
-            return token
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagOther(self, token):
-            self.parser.parseError("expected-eof-but-got-start-tag",
-                                   {"name": token["name"]})
-            self.parser.phase = self.parser.phases["inBody"]
-            return token
-
-        def processEndTag(self, token):
-            self.parser.parseError("expected-eof-but-got-end-tag",
-                                   {"name": token["name"]})
-            self.parser.phase = self.parser.phases["inBody"]
-            return token
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml)
-        ])
-        startTagHandler.default = startTagOther
-
-    class AfterAfterFramesetPhase(Phase):
-        __slots__ = tuple()
-
-        def processEOF(self):
-            pass
-
-        def processComment(self, token):
-            self.tree.insertComment(token, self.tree.document)
-
-        def processSpaceCharacters(self, token):
-            return self.parser.phases["inBody"].processSpaceCharacters(token)
-
-        def processCharacters(self, token):
-            self.parser.parseError("expected-eof-but-got-char")
-
-        def startTagHtml(self, token):
-            return self.parser.phases["inBody"].processStartTag(token)
-
-        def startTagNoFrames(self, token):
-            return self.parser.phases["inHead"].processStartTag(token)
-
-        def startTagOther(self, token):
-            self.parser.parseError("expected-eof-but-got-start-tag",
-                                   {"name": token["name"]})
-
-        def processEndTag(self, token):
-            self.parser.parseError("expected-eof-but-got-end-tag",
-                                   {"name": token["name"]})
-
-        startTagHandler = _utils.MethodDispatcher([
-            ("html", startTagHtml),
-            ("noframes", startTagNoFrames)
-        ])
-        startTagHandler.default = startTagOther
-
-    # pylint:enable=unused-argument
-
-    return {
-        "initial": InitialPhase,
-        "beforeHtml": BeforeHtmlPhase,
-        "beforeHead": BeforeHeadPhase,
-        "inHead": InHeadPhase,
-        "inHeadNoscript": InHeadNoscriptPhase,
-        "afterHead": AfterHeadPhase,
-        "inBody": InBodyPhase,
-        "text": TextPhase,
-        "inTable": InTablePhase,
-        "inTableText": InTableTextPhase,
-        "inCaption": InCaptionPhase,
-        "inColumnGroup": InColumnGroupPhase,
-        "inTableBody": InTableBodyPhase,
-        "inRow": InRowPhase,
-        "inCell": InCellPhase,
-        "inSelect": InSelectPhase,
-        "inSelectInTable": InSelectInTablePhase,
-        "inForeignContent": InForeignContentPhase,
-        "afterBody": AfterBodyPhase,
-        "inFrameset": InFramesetPhase,
-        "afterFrameset": AfterFramesetPhase,
-        "afterAfterBody": AfterAfterBodyPhase,
-        "afterAfterFrameset": AfterAfterFramesetPhase,
-        # XXX after after frameset
-    }
-
-
-def adjust_attributes(token, replacements):
-    needs_adjustment = viewkeys(token['data']) & viewkeys(replacements)
-    if needs_adjustment:
-        token['data'] = type(token['data'])((replacements.get(k, k), v)
-                                            for k, v in token['data'].items())
-
-
-def impliedTagToken(name, type="EndTag", attributes=None,
-                    selfClosing=False):
-    if attributes is None:
-        attributes = {}
-    return {"type": tokenTypes[type], "name": name, "data": attributes,
-            "selfClosing": selfClosing}
-
-
-class ParseError(Exception):
-    """Error in parsed document"""
-    pass
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/serializer.py b/env/Lib/site-packages/pip/_vendor/html5lib/serializer.py
deleted file mode 100644
index d5669d8c..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/serializer.py
+++ /dev/null
@@ -1,409 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-from pip._vendor.six import text_type
-
-import re
-
-from codecs import register_error, xmlcharrefreplace_errors
-
-from .constants import voidElements, booleanAttributes, spaceCharacters
-from .constants import rcdataElements, entities, xmlEntities
-from . import treewalkers, _utils
-from xml.sax.saxutils import escape
-
-_quoteAttributeSpecChars = "".join(spaceCharacters) + "\"'=<>`"
-_quoteAttributeSpec = re.compile("[" + _quoteAttributeSpecChars + "]")
-_quoteAttributeLegacy = re.compile("[" + _quoteAttributeSpecChars +
-                                   "\x00\x01\x02\x03\x04\x05\x06\x07\x08\t\n"
-                                   "\x0b\x0c\r\x0e\x0f\x10\x11\x12\x13\x14\x15"
-                                   "\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f"
-                                   "\x20\x2f\x60\xa0\u1680\u180e\u180f\u2000"
-                                   "\u2001\u2002\u2003\u2004\u2005\u2006\u2007"
-                                   "\u2008\u2009\u200a\u2028\u2029\u202f\u205f"
-                                   "\u3000]")
-
-
-_encode_entity_map = {}
-_is_ucs4 = len("\U0010FFFF") == 1
-for k, v in list(entities.items()):
-    # skip multi-character entities
-    if ((_is_ucs4 and len(v) > 1) or
-            (not _is_ucs4 and len(v) > 2)):
-        continue
-    if v != "&":
-        if len(v) == 2:
-            v = _utils.surrogatePairToCodepoint(v)
-        else:
-            v = ord(v)
-        if v not in _encode_entity_map or k.islower():
-            # prefer &lt; over &LT; and similarly for &amp;, &gt;, etc.
-            _encode_entity_map[v] = k
-
-
-def htmlentityreplace_errors(exc):
-    if isinstance(exc, (UnicodeEncodeError, UnicodeTranslateError)):
-        res = []
-        codepoints = []
-        skip = False
-        for i, c in enumerate(exc.object[exc.start:exc.end]):
-            if skip:
-                skip = False
-                continue
-            index = i + exc.start
-            if _utils.isSurrogatePair(exc.object[index:min([exc.end, index + 2])]):
-                codepoint = _utils.surrogatePairToCodepoint(exc.object[index:index + 2])
-                skip = True
-            else:
-                codepoint = ord(c)
-            codepoints.append(codepoint)
-        for cp in codepoints:
-            e = _encode_entity_map.get(cp)
-            if e:
-                res.append("&")
-                res.append(e)
-                if not e.endswith(";"):
-                    res.append(";")
-            else:
-                res.append("&#x%s;" % (hex(cp)[2:]))
-        return ("".join(res), exc.end)
-    else:
-        return xmlcharrefreplace_errors(exc)
-
-
-register_error("htmlentityreplace", htmlentityreplace_errors)
-
-
-def serialize(input, tree="etree", encoding=None, **serializer_opts):
-    """Serializes the input token stream using the specified treewalker
-
-    :arg input: the token stream to serialize
-
-    :arg tree: the treewalker to use
-
-    :arg encoding: the encoding to use
-
-    :arg serializer_opts: any options to pass to the
-        :py:class:`html5lib.serializer.HTMLSerializer` that gets created
-
-    :returns: the tree serialized as a string
-
-    Example:
-
-    >>> from html5lib.html5parser import parse
-    >>> from html5lib.serializer import serialize
-    >>> token_stream = parse('<html><body><p>Hi!</p></body></html>')
-    >>> serialize(token_stream, omit_optional_tags=False)
-    '<html><head></head><body><p>Hi!</p></body></html>'
-
-    """
-    # XXX: Should we cache this?
-    walker = treewalkers.getTreeWalker(tree)
-    s = HTMLSerializer(**serializer_opts)
-    return s.render(walker(input), encoding)
-
-
-class HTMLSerializer(object):
-
-    # attribute quoting options
-    quote_attr_values = "legacy"  # be secure by default
-    quote_char = '"'
-    use_best_quote_char = True
-
-    # tag syntax options
-    omit_optional_tags = True
-    minimize_boolean_attributes = True
-    use_trailing_solidus = False
-    space_before_trailing_solidus = True
-
-    # escaping options
-    escape_lt_in_attrs = False
-    escape_rcdata = False
-    resolve_entities = True
-
-    # miscellaneous options
-    alphabetical_attributes = False
-    inject_meta_charset = True
-    strip_whitespace = False
-    sanitize = False
-
-    options = ("quote_attr_values", "quote_char", "use_best_quote_char",
-               "omit_optional_tags", "minimize_boolean_attributes",
-               "use_trailing_solidus", "space_before_trailing_solidus",
-               "escape_lt_in_attrs", "escape_rcdata", "resolve_entities",
-               "alphabetical_attributes", "inject_meta_charset",
-               "strip_whitespace", "sanitize")
-
-    def __init__(self, **kwargs):
-        """Initialize HTMLSerializer
-
-        :arg inject_meta_charset: Whether or not to inject the meta charset.
-
-            Defaults to ``True``.
-
-        :arg quote_attr_values: Whether to quote attribute values that don't
-            require quoting per legacy browser behavior (``"legacy"``), when
-            required by the standard (``"spec"``), or always (``"always"``).
-
-            Defaults to ``"legacy"``.
-
-        :arg quote_char: Use given quote character for attribute quoting.
-
-            Defaults to ``"`` which will use double quotes unless attribute
-            value contains a double quote, in which case single quotes are
-            used.
-
-        :arg escape_lt_in_attrs: Whether or not to escape ``<`` in attribute
-            values.
-
-            Defaults to ``False``.
-
-        :arg escape_rcdata: Whether to escape characters that need to be
-            escaped within normal elements within rcdata elements such as
-            style.
-
-            Defaults to ``False``.
-
-        :arg resolve_entities: Whether to resolve named character entities that
-            appear in the source tree. The XML predefined entities &lt; &gt;
-            &amp; &quot; &apos; are unaffected by this setting.
-
-            Defaults to ``True``.
-
-        :arg strip_whitespace: Whether to remove semantically meaningless
-            whitespace. (This compresses all whitespace to a single space
-            except within ``pre``.)
-
-            Defaults to ``False``.
-
-        :arg minimize_boolean_attributes: Shortens boolean attributes to give
-            just the attribute value, for example::
-
-              <input disabled="disabled">
-
-            becomes::
-
-              <input disabled>
-
-            Defaults to ``True``.
-
-        :arg use_trailing_solidus: Includes a close-tag slash at the end of the
-            start tag of void elements (empty elements whose end tag is
-            forbidden). E.g. ``<hr/>``.
-
-            Defaults to ``False``.
-
-        :arg space_before_trailing_solidus: Places a space immediately before
-            the closing slash in a tag using a trailing solidus. E.g.
-            ``<hr />``. Requires ``use_trailing_solidus=True``.
-
-            Defaults to ``True``.
-
-        :arg sanitize: Strip all unsafe or unknown constructs from output.
-            See :py:class:`html5lib.filters.sanitizer.Filter`.
-
-            Defaults to ``False``.
-
-        :arg omit_optional_tags: Omit start/end tags that are optional.
-
-            Defaults to ``True``.
-
-        :arg alphabetical_attributes: Reorder attributes to be in alphabetical order.
-
-            Defaults to ``False``.
-
-        """
-        unexpected_args = frozenset(kwargs) - frozenset(self.options)
-        if len(unexpected_args) > 0:
-            raise TypeError("__init__() got an unexpected keyword argument '%s'" % next(iter(unexpected_args)))
-        if 'quote_char' in kwargs:
-            self.use_best_quote_char = False
-        for attr in self.options:
-            setattr(self, attr, kwargs.get(attr, getattr(self, attr)))
-        self.errors = []
-        self.strict = False
-
-    def encode(self, string):
-        assert(isinstance(string, text_type))
-        if self.encoding:
-            return string.encode(self.encoding, "htmlentityreplace")
-        else:
-            return string
-
-    def encodeStrict(self, string):
-        assert(isinstance(string, text_type))
-        if self.encoding:
-            return string.encode(self.encoding, "strict")
-        else:
-            return string
-
-    def serialize(self, treewalker, encoding=None):
-        # pylint:disable=too-many-nested-blocks
-        self.encoding = encoding
-        in_cdata = False
-        self.errors = []
-
-        if encoding and self.inject_meta_charset:
-            from .filters.inject_meta_charset import Filter
-            treewalker = Filter(treewalker, encoding)
-        # Alphabetical attributes is here under the assumption that none of
-        # the later filters add or change order of attributes; it needs to be
-        # before the sanitizer so escaped elements come out correctly
-        if self.alphabetical_attributes:
-            from .filters.alphabeticalattributes import Filter
-            treewalker = Filter(treewalker)
-        # WhitespaceFilter should be used before OptionalTagFilter
-        # for maximum efficiently of this latter filter
-        if self.strip_whitespace:
-            from .filters.whitespace import Filter
-            treewalker = Filter(treewalker)
-        if self.sanitize:
-            from .filters.sanitizer import Filter
-            treewalker = Filter(treewalker)
-        if self.omit_optional_tags:
-            from .filters.optionaltags import Filter
-            treewalker = Filter(treewalker)
-
-        for token in treewalker:
-            type = token["type"]
-            if type == "Doctype":
-                doctype = "<!DOCTYPE %s" % token["name"]
-
-                if token["publicId"]:
-                    doctype += ' PUBLIC "%s"' % token["publicId"]
-                elif token["systemId"]:
-                    doctype += " SYSTEM"
-                if token["systemId"]:
-                    if token["systemId"].find('"') >= 0:
-                        if token["systemId"].find("'") >= 0:
-                            self.serializeError("System identifier contains both single and double quote characters")
-                        quote_char = "'"
-                    else:
-                        quote_char = '"'
-                    doctype += " %s%s%s" % (quote_char, token["systemId"], quote_char)
-
-                doctype += ">"
-                yield self.encodeStrict(doctype)
-
-            elif type in ("Characters", "SpaceCharacters"):
-                if type == "SpaceCharacters" or in_cdata:
-                    if in_cdata and token["data"].find("</") >= 0:
-                        self.serializeError("Unexpected </ in CDATA")
-                    yield self.encode(token["data"])
-                else:
-                    yield self.encode(escape(token["data"]))
-
-            elif type in ("StartTag", "EmptyTag"):
-                name = token["name"]
-                yield self.encodeStrict("<%s" % name)
-                if name in rcdataElements and not self.escape_rcdata:
-                    in_cdata = True
-                elif in_cdata:
-                    self.serializeError("Unexpected child element of a CDATA element")
-                for (_, attr_name), attr_value in token["data"].items():
-                    # TODO: Add namespace support here
-                    k = attr_name
-                    v = attr_value
-                    yield self.encodeStrict(' ')
-
-                    yield self.encodeStrict(k)
-                    if not self.minimize_boolean_attributes or \
-                        (k not in booleanAttributes.get(name, tuple()) and
-                         k not in booleanAttributes.get("", tuple())):
-                        yield self.encodeStrict("=")
-                        if self.quote_attr_values == "always" or len(v) == 0:
-                            quote_attr = True
-                        elif self.quote_attr_values == "spec":
-                            quote_attr = _quoteAttributeSpec.search(v) is not None
-                        elif self.quote_attr_values == "legacy":
-                            quote_attr = _quoteAttributeLegacy.search(v) is not None
-                        else:
-                            raise ValueError("quote_attr_values must be one of: "
-                                             "'always', 'spec', or 'legacy'")
-                        v = v.replace("&", "&amp;")
-                        if self.escape_lt_in_attrs:
-                            v = v.replace("<", "&lt;")
-                        if quote_attr:
-                            quote_char = self.quote_char
-                            if self.use_best_quote_char:
-                                if "'" in v and '"' not in v:
-                                    quote_char = '"'
-                                elif '"' in v and "'" not in v:
-                                    quote_char = "'"
-                            if quote_char == "'":
-                                v = v.replace("'", "&#39;")
-                            else:
-                                v = v.replace('"', "&quot;")
-                            yield self.encodeStrict(quote_char)
-                            yield self.encode(v)
-                            yield self.encodeStrict(quote_char)
-                        else:
-                            yield self.encode(v)
-                if name in voidElements and self.use_trailing_solidus:
-                    if self.space_before_trailing_solidus:
-                        yield self.encodeStrict(" /")
-                    else:
-                        yield self.encodeStrict("/")
-                yield self.encode(">")
-
-            elif type == "EndTag":
-                name = token["name"]
-                if name in rcdataElements:
-                    in_cdata = False
-                elif in_cdata:
-                    self.serializeError("Unexpected child element of a CDATA element")
-                yield self.encodeStrict("</%s>" % name)
-
-            elif type == "Comment":
-                data = token["data"]
-                if data.find("--") >= 0:
-                    self.serializeError("Comment contains --")
-                yield self.encodeStrict("<!--%s-->" % token["data"])
-
-            elif type == "Entity":
-                name = token["name"]
-                key = name + ";"
-                if key not in entities:
-                    self.serializeError("Entity %s not recognized" % name)
-                if self.resolve_entities and key not in xmlEntities:
-                    data = entities[key]
-                else:
-                    data = "&%s;" % name
-                yield self.encodeStrict(data)
-
-            else:
-                self.serializeError(token["data"])
-
-    def render(self, treewalker, encoding=None):
-        """Serializes the stream from the treewalker into a string
-
-        :arg treewalker: the treewalker to serialize
-
-        :arg encoding: the string encoding to use
-
-        :returns: the serialized tree
-
-        Example:
-
-        >>> from html5lib import parse, getTreeWalker
-        >>> from html5lib.serializer import HTMLSerializer
-        >>> token_stream = parse('<html><body>Hi!</body></html>')
-        >>> walker = getTreeWalker('etree')
-        >>> serializer = HTMLSerializer(omit_optional_tags=False)
-        >>> serializer.render(walker(token_stream))
-        '<html><head></head><body>Hi!</body></html>'
-
-        """
-        if encoding:
-            return b"".join(list(self.serialize(treewalker, encoding)))
-        else:
-            return "".join(list(self.serialize(treewalker)))
-
-    def serializeError(self, data="XXX ERROR MESSAGE NEEDED"):
-        # XXX The idea is to make data mandatory.
-        self.errors.append(data)
-        if self.strict:
-            raise SerializeError
-
-
-class SerializeError(Exception):
-    """Error in serialized tree"""
-    pass
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py
deleted file mode 100644
index 7ef59590..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__init__.py
+++ /dev/null
@@ -1,30 +0,0 @@
-"""Tree adapters let you convert from one tree structure to another
-
-Example:
-
-.. code-block:: python
-
-   from pip._vendor import html5lib
-   from pip._vendor.html5lib.treeadapters import genshi
-
-   doc = '<html><body>Hi!</body></html>'
-   treebuilder = html5lib.getTreeBuilder('etree')
-   parser = html5lib.HTMLParser(tree=treebuilder)
-   tree = parser.parse(doc)
-   TreeWalker = html5lib.getTreeWalker('etree')
-
-   genshi_tree = genshi.to_genshi(TreeWalker(tree))
-
-"""
-from __future__ import absolute_import, division, unicode_literals
-
-from . import sax
-
-__all__ = ["sax"]
-
-try:
-    from . import genshi  # noqa
-except ImportError:
-    pass
-else:
-    __all__.append("genshi")
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 99d0654679c79fd13cc76e246369315b203af4f9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 965
zcmYe~<>g{vU|^UdaWHi`69dCz5C<7^FfcGUFfcF_$1pH3q%cG=q%fv1<uK+lMKR?v
zM=|HJM6ob3q%fzj<gn(lMX@n5q_CzlMzL23q%fzj<*?>*L~$@Ogfrv`u`r}^R{Ah9
zfM6s;9*+S-D*FPi6!wLTj0`Cp!3>(5i5D0d7($9tQxy_Z5(`RFi;5L;QcDyn^Gg+y
z^YhA5i%JyIit=+6^7B#^N<hkrONvU9OG=AU6-x3I67%v)GE$4UxLhj|a|?1(t+=@K
z^c0fwQ&M%4a`Kb2t*jIZDoZl*^SHPa6d(o_WESYfm!;;V<QFMq<`(1^l_+GC<mQ;>
zWF}!#qX(1J1KAFDBUER4YF=?hCfM+l{A2}N1$7&cdOMq>{FF*Nk4!}yeK5;LA1tg6
zvH@gHQfX#RN@|gUE!=Ls^wbhiFgQVEG}Kc;>eMwsItmhticuANg!uXdfJHSx%4|Ud
z)J(7r5MRMo0isb4OlhR#CxhicwuC3<WTTo0wH_jYupMMQ#FOz*Ga)>^lKglGO9NpZ
z*e#lxTwE_fiAj_B7Jp(=aehu|NoqVKyl!!%WR_(XXXfYK5-82f1jSQ)PG(7JQDRQ<
zOGX9;22I9W%*BZnMQji@8^nqtb_NCpKTYmi?D6p_`N{F|x47ct(@H^!AU?i`iGhKk
zh#5q%FfcIOVgPFfDNW4DiH`^Cy~XVbj%nATqWq#;Y>5R0sd*_Y8H)Hox<JIQK4+_#
z(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>
zAO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~;>?m%-GapA?8Nlc;+TTW0)1$@11APh
zg3||uDJ)It$H!;pWtPOp>lIYq;;_lhPbtkwwF8Apu>b=D1B;Ld6Au#`6BDBVBM&1R
F699^^BeMVi

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/genshi.cpython-39.pyc
deleted file mode 100644
index 9dfe76138922c1c7cbb7b935f57cfb39d948da1d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1573
zcmYe~<>g{vU|^UdaWHi=8w0~*5C<7EF)%PVFfcF_`!Fytq%fo~<}l<kMlt3xMKR?v
zM=>*k#F%nea#^ETbJ?QUz<lN$mR$BI_FRrAj$F<t&Rni2u3YXYZbpU_mK4?&hA5sC
zwqOQL_Lm@gG?{PlCngo==aiPD#%Jah<QJ9P;z-FX%Ph{!&$}g1nwOcJpOPA%lUb5l
zl$cYj$#jb~&@VAJ^%kpRNl8($ChINM;1I{4kXy{IelE9ILR=$4Zm~Q2`}(^2h1_Cy
z@plf13~)_m1X%^eYzzzxAe;>HRS+WsLpnn(V-14~!vw}yty-oUrW8g=hFazt<`kwf
zh9bQh#sv&DOexHg3=0_<8S<oR7>hhg7*kjlFx4<FWK3aAV-90rgqXpc!dAvmw4sJ6
zg<X=NC@+Nr!m43P;gn=ZV-jPiWyu4HaY{1OvXn5VaHVj!K+RsjvXH@rp_#Fnv6i)j
zwS=vPrJ1pYHH`^oehqU9Pc~E0h7?|~%XqVyiatP0FS<s+9(IUnFp~;7YM4{_vY93@
z7V(sTT*EBMfFj4A%~Zru!U=J84O5DMB*=||k_>6gDNx@QaujmZFiv1B^1}>?6ro@S
zP2sAk&iQ#|sYN9Ui3%k}si_Jj`3i{&>8W|e8JS=KE-nQH1qG|bqI8Aw#GLHZA}fWG
zj8w1`gb&hDS`5|*5`fEs#FL?BXO=*XDM~FVEy^pl0@;vSlvt8qq>!Hm;()Bn%TGxy
zhA6znQc_uvs>yVV%Q+*lC^5MtwW#<Oe{ex!aw?JlOG;u%;w=VEX1|yJ|NsAAB*?(P
zpviQLBe*27s3asY{T7F7Zb3;Uh{c(gn44M*(*KLCTD7=VwfGhbNC+jxF*7hQure?(
z1cOqX2?Hp_)iA{B#4yz|)-sha)G($nNHU}_mNFJ8r7+bniZSG|)i8omTr*=0QySAm
zrb3or22GYCP%8E-5@lducnM-^G8TbM)nvZKq-Su8C9$NW=oV{PVoqu5N`@k71_p*-
zJ<e7!p~b01#WATlDVaqv{&}e`MVV!(3c3oRex6~jLBXCOj=>6^elGrguECy;F~P3B
zuE8O$K?-Iu0RcWSi6*)^`RSR(C7IbVsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$1^V%2
zsd*{+Mfw>fxjCjenMwMf2v1B&EC7YBJ|xcd3My}L+2mvvmn7%s7TC#xLV^X95gFP3
zSIL&-$3vCb<m4wO<`moMA=DNLGcYjRVsp()0R=d_bAE1aYF^1Lc9;BQP-NcXC@4+J
z$xQZ4xy4ajSzMBu>zU%G$#sh@v7jI|FQteRq?;uxKQpfgl<RM?W|pMp78kKIFff3F
zuZRQ00u_Qq+@N@7yTt}dZ>dGMSV~eWN^Y^1<Y%Ym74d*niGj>w1qF05IDjF93`mp{
z?gx;`#V(-2hJ%HXi;;togHeEyg;9u+g$cwK1Cw0;IhaHkIS^t@LQGtYLQEWte2i@W
znHZV=bFeTmu`w2DF)%RrY4YCUijPk#Eh#NZjgKz^mB~e*L{$U|!YFQN*d^x|r9!*}
w@+icIV9$Yqpa||mu#pg#gAxgZ1@;4nO>TZlX-=vgD0LNs3=v@xV3c7707%}BK>z>%

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/__pycache__/sax.cpython-39.pyc
deleted file mode 100644
index 1c945ee3bd3c419a2ffdbf318d8757bae274d674..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1492
zcmYe~<>g{vU|^UdaWM4*8w0~*5C<8vFfcGUFfcF_r!X)uq%fo~<}l<kMlt3xMKR?v
zM=>*k#F%nea#^ET85vTTQ&@7?a@nKUb2*|o7#T7dqBv987jP|PaAAm*ieZl8j^c^p
zP32BuEoCgSN##xDOy#y=D6~moOJQ$eh~i6O4Q9~fcnPv!llc~ZVp4H_PH9PMd}eMz
zeo@ISj+D%@%;L=ayjudLd6~)iDXH-}nI)-3i8;lZjJE_FOG=6|lS)fci~WK<a|?1_
zGBGePXfoXrPfW=wEiQ4(FG|f!&qJuXC0Uw>L&`51q!;845N2m!U|?flU~mS7gA^kJ
zLk;5shJ_4_3?+;Un81D$iD9Z`s%5TWT)<qzRKvWGiIJgDpa$gYW3?<bEGdkV47IE^
ztSL;{OhrzGT7_CQtSQW83`KKFK(Z{73?;11Otow^j0@OmSW;Le8ERNk*d!U!m>_fw
z+d^hWh8ors_H3r24>gPn*s-Ys+X^z7Bb%w{5J6R(Wei2PY8V%A)Uc$mNHQ#BWMlxl
ziz}O{=t-eg3U{%V7efk9Gh-8Dp%&byLU5mQ)-Zwf{HkFD#V{j73U4rjCSTQR=fs>G
zg<!`B-JHzqRE6aHypq(s5`~P!yp){OB88;H;?xv{{5*w{qSVy##GLHZA_WM=#igL2
zpkS3)lnxcJQYgttMOIgmuTWZ?s!);-Rsfd;2_)y|m8BMyC}fr(83VP`3gjBN10aS#
zRNZ1JsVqpn#qN@y3}R?9-Qox?Nh~S}Nld@R;hI}eQVC+Qq$HLk-r~$l%uOvWNK8(>
z#R6g$@h~tj++uUhO9@F#*JQfI<(!dNl$czST2y?CKNzGANr2rsKQ}iuuf(lNC^RoS
zFTXrbp(H;$HBSL#t)C|ME#6{~y)OC5r66Uu_zH?r(=sdKa}x^+GV{`Jv1XQ}<`&-)
z0;>uD%lSg2idY#K7>YPRZs7yVy5^*UjPMJ-#gm$sg5Yr_BitvDnwNrN$}R5HycC%2
zn(VjOAW?FQ9U6qU*dPun;saU43U+%DCzzdBQc_gBlA%b6fq~&yr?XW|XmM&$aZGAX
zN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+W3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7
zqKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#lc4B&JaZEvGfqr~hYF<iyk$y%=ZjNbA
zW|BTAEhVNT7Jvd@zc{f%ub}c4TS<O=abg88DAU@3vM~n-qW~ix69*#*vVcjZ|13;G
zjBJcd|5%tg7=;+w{<AS5XaPnJMkXdcCILns#v&C^VZwilD?UE0w4}5sH9o!wR7Mmr
zgMuGaN=6A*<mTvsEU(DTDN0RDNi71$%`ML4{Ji3l#JrN?B2Y;Jj;kV3P}s4RCFYc-
z78l7gFfc@M=Hw?Q=J+M%rh)?*Y#}&MkqBjwE)JXA{FKt1R69nH*FX^>!o<TQz{J8R
K#K^(O#S8#|eyLpm

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py
deleted file mode 100644
index 61d5fb6a..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/genshi.py
+++ /dev/null
@@ -1,54 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from genshi.core import QName, Attrs
-from genshi.core import START, END, TEXT, COMMENT, DOCTYPE
-
-
-def to_genshi(walker):
-    """Convert a tree to a genshi tree
-
-    :arg walker: the treewalker to use to walk the tree to convert it
-
-    :returns: generator of genshi nodes
-
-    """
-    text = []
-    for token in walker:
-        type = token["type"]
-        if type in ("Characters", "SpaceCharacters"):
-            text.append(token["data"])
-        elif text:
-            yield TEXT, "".join(text), (None, -1, -1)
-            text = []
-
-        if type in ("StartTag", "EmptyTag"):
-            if token["namespace"]:
-                name = "{%s}%s" % (token["namespace"], token["name"])
-            else:
-                name = token["name"]
-            attrs = Attrs([(QName("{%s}%s" % attr if attr[0] is not None else attr[1]), value)
-                           for attr, value in token["data"].items()])
-            yield (START, (QName(name), attrs), (None, -1, -1))
-            if type == "EmptyTag":
-                type = "EndTag"
-
-        if type == "EndTag":
-            if token["namespace"]:
-                name = "{%s}%s" % (token["namespace"], token["name"])
-            else:
-                name = token["name"]
-
-            yield END, QName(name), (None, -1, -1)
-
-        elif type == "Comment":
-            yield COMMENT, token["data"], (None, -1, -1)
-
-        elif type == "Doctype":
-            yield DOCTYPE, (token["name"], token["publicId"],
-                            token["systemId"]), (None, -1, -1)
-
-        else:
-            pass  # FIXME: What to do?
-
-    if text:
-        yield TEXT, "".join(text), (None, -1, -1)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py b/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py
deleted file mode 100644
index f4ccea5a..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treeadapters/sax.py
+++ /dev/null
@@ -1,50 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from xml.sax.xmlreader import AttributesNSImpl
-
-from ..constants import adjustForeignAttributes, unadjustForeignAttributes
-
-prefix_mapping = {}
-for prefix, localName, namespace in adjustForeignAttributes.values():
-    if prefix is not None:
-        prefix_mapping[prefix] = namespace
-
-
-def to_sax(walker, handler):
-    """Call SAX-like content handler based on treewalker walker
-
-    :arg walker: the treewalker to use to walk the tree to convert it
-
-    :arg handler: SAX handler to use
-
-    """
-    handler.startDocument()
-    for prefix, namespace in prefix_mapping.items():
-        handler.startPrefixMapping(prefix, namespace)
-
-    for token in walker:
-        type = token["type"]
-        if type == "Doctype":
-            continue
-        elif type in ("StartTag", "EmptyTag"):
-            attrs = AttributesNSImpl(token["data"],
-                                     unadjustForeignAttributes)
-            handler.startElementNS((token["namespace"], token["name"]),
-                                   token["name"],
-                                   attrs)
-            if type == "EmptyTag":
-                handler.endElementNS((token["namespace"], token["name"]),
-                                     token["name"])
-        elif type == "EndTag":
-            handler.endElementNS((token["namespace"], token["name"]),
-                                 token["name"])
-        elif type in ("Characters", "SpaceCharacters"):
-            handler.characters(token["data"])
-        elif type == "Comment":
-            pass
-        else:
-            assert False, "Unknown token type"
-
-    for prefix, namespace in prefix_mapping.items():
-        handler.endPrefixMapping(prefix)
-    handler.endDocument()
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py
deleted file mode 100644
index d44447ea..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__init__.py
+++ /dev/null
@@ -1,88 +0,0 @@
-"""A collection of modules for building different kinds of trees from HTML
-documents.
-
-To create a treebuilder for a new type of tree, you need to do
-implement several things:
-
-1. A set of classes for various types of elements: Document, Doctype, Comment,
-   Element. These must implement the interface of ``base.treebuilders.Node``
-   (although comment nodes have a different signature for their constructor,
-   see ``treebuilders.etree.Comment``) Textual content may also be implemented
-   as another node type, or not, as your tree implementation requires.
-
-2. A treebuilder object (called ``TreeBuilder`` by convention) that inherits
-   from ``treebuilders.base.TreeBuilder``. This has 4 required attributes:
-
-   * ``documentClass`` - the class to use for the bottommost node of a document
-   * ``elementClass`` - the class to use for HTML Elements
-   * ``commentClass`` - the class to use for comments
-   * ``doctypeClass`` - the class to use for doctypes
-
-   It also has one required method:
-
-   * ``getDocument`` - Returns the root node of the complete document tree
-
-3. If you wish to run the unit tests, you must also create a ``testSerializer``
-   method on your treebuilder which accepts a node and returns a string
-   containing Node and its children serialized according to the format used in
-   the unittests
-
-"""
-
-from __future__ import absolute_import, division, unicode_literals
-
-from .._utils import default_etree
-
-treeBuilderCache = {}
-
-
-def getTreeBuilder(treeType, implementation=None, **kwargs):
-    """Get a TreeBuilder class for various types of trees with built-in support
-
-    :arg treeType: the name of the tree type required (case-insensitive). Supported
-        values are:
-
-        * "dom" - A generic builder for DOM implementations, defaulting to a
-          xml.dom.minidom based implementation.
-        * "etree" - A generic builder for tree implementations exposing an
-          ElementTree-like interface, defaulting to xml.etree.cElementTree if
-          available and xml.etree.ElementTree if not.
-        * "lxml" - A etree-based builder for lxml.etree, handling limitations
-          of lxml's implementation.
-
-    :arg implementation: (Currently applies to the "etree" and "dom" tree
-        types). A module implementing the tree type e.g. xml.etree.ElementTree
-        or xml.etree.cElementTree.
-
-    :arg kwargs: Any additional options to pass to the TreeBuilder when
-        creating it.
-
-    Example:
-
-    >>> from html5lib.treebuilders import getTreeBuilder
-    >>> builder = getTreeBuilder('etree')
-
-    """
-
-    treeType = treeType.lower()
-    if treeType not in treeBuilderCache:
-        if treeType == "dom":
-            from . import dom
-            # Come up with a sane default (pref. from the stdlib)
-            if implementation is None:
-                from xml.dom import minidom
-                implementation = minidom
-            # NEVER cache here, caching is done in the dom submodule
-            return dom.getDomModule(implementation, **kwargs).TreeBuilder
-        elif treeType == "lxml":
-            from . import etree_lxml
-            treeBuilderCache[treeType] = etree_lxml.TreeBuilder
-        elif treeType == "etree":
-            from . import etree
-            if implementation is None:
-                implementation = default_etree
-            # NEVER cache here, caching is done in the etree submodule
-            return etree.getETreeModule(implementation, **kwargs).TreeBuilder
-        else:
-            raise ValueError("""Unrecognised treebuilder "%s" """ % treeType)
-    return treeBuilderCache.get(treeType)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 3804fd8036fd70557bf6a8df2be70d28b2b44c3d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3360
zcmYe~<>g{vU|^UdaWIvGkAdMah=Yuo85kHG7#J9e%@`OMQW&BbQW#U1au{=&qL^}-
zqnLA9qF5LiQkYX%a#(ZOqSzQ2G8v-SQ#exCQrKG<qc~DngBdhA6E#^G7#tOn^K)`i
zlS?x5^Az&a6ms)ZN^??+71HvH6p~6ab5b(%(iKuN)6!ClQu9g_vNQ8iib3j1ic&$U
zit=+6JVJbZxKi?yOLJ56N{aQkxI*$3l8aIkOHvgQ6+r61=A;&Z%}i9tOD$I@sVqo^
znWCdmnO~}qmztWQP?E2ZlFyZyTac3qGE1R2wJfzLF-M^!BQr0(*ouqGP*1^8p*Xb!
zq&GPyvA7uIhWsLhvc#gy{L*5uxnSp|LQE*OQgDGfOb5gQ*{h@AoSzFaUWZFTLBSQG
zP){KwBeghHA-A-+L;>M|l8jV^%)FA+qO`<hu!9p4k`jwk^^km3tml`XlA4eJGE5^e
zrz9i4G(AHh8DfP(UVchyu|h^-87M3e!C0J`o|jlsT9gV7lah?o%p!&4{Ji3lqSEA&
z{35W+ic?b+5)x2sN(J%spw3T7&{POXttcr?%mL{w0Yy)4Vx>Z2PI10MQYyk1sVN}0
zB^E0r=H-`Uq!xi41r915g?tdNL`Na97!(Ud;OIi=Oa!NjqSV6D%%W6K%o>5hALIyF
zl;$U8r6!jsXe1}*<fNu3BqW3srKUQ8(oJenLV`k4CCF)Isd*rSG!;rR5=#^^^D<J4
zGE0g<j!FZiA2d&b0~o~^P~>ESLa|uEL;>oW6otf+lA_F{(vnnA!cb69&{9Z9fTcob
zP})dHP|#HX#UMDPfD%_}F+9K(lJZMR@^f?Zi%THkk)NiJr~uOsavR7zXfh&T94G_8
z5)#;3Ag#%e6hJ^LR25uTN`5jZjS|oWRaMLda;IkrB+4@qixu+oQV{`^n_7~QpJD}8
z1aeV&Y6&befP*F|wWPEtuNWLeMfv%NZ~%u{J}4KKq{4#)oHV$&jP(>e(?DrOp**uV
z0~Dx5rFmc@O7k*H6iQNyONt>m8l08Di4k5HBqV_3gHww#6LT`FKq&;|0f;*l^7BB(
zLXsdXd6j2mCTA!lCMTyBloTr@LSia0FGZmU>h?s1;*z4wymXK`$@zIDiJ5tz0t=KS
z6+r4TONteeGct2hic<3wieVO~fQ-y90+($i`C!+l<rn29mMD}Kr=}=m=7Ed@g#yS=
zASV}dalHhUznaXq_!E<g^K(i|QsXmo3-XIfZgHe!mSq-a=I7lKD9y`E&QD2=&&ezS
zm0QIxnHU%tG#PL4rlh7NmgbbigEO#SGDsL?90;>BFfgz%Ffe$7it}9z3=B043m6tM
z)H2jClrWYt7Hz0uNMX!oDhfzpN@31n%4M!)W@M;gOkpWyD6&amO<~Jn$z`o&VPvRb
zsb#ET&SI-!Ok>Pss9{>d*vFW~9?Vd~kiwqLR8)|{l){n2l*>`e%E(Z|n#EqiSi@k$
zkmpdtkiwbGRJ0_8DTOPCDVMXB4Q~E~60Tat8n!HMbTdnMQn+gv#2A_xn;1(N7x30F
zEMyF3(Bw&EW?^7(Pc2bMR6xqX3Xlv4s!}itYEWTPtWcg=k^!!6N^~>x6pBj=Kp_iG
zxC&N@Md{$Q7gAY}Y6Xs~yu@5^VGN2PkbZDkhDi4s$%)0Ox|w;!sd>ejC7ETZntBSs
z5F;T)p#lh$CFYc-7Aqtcr9yHDNK8RXK`A9aS4lxv!BHVSH7~U&Ga2lx6lm?`;_r)A
zIu`3FKqD8F?n?3%5<zJPY?y*VMQ)B>N`9_hZf0I)N`9^asAx+;Ge8fnUQ0m<oIY?{
z5B4m)b^@2q#R{nv1^LAw%M-!L7HT!LUIWE~Zcb)4QZ<I|V2~rh_Ua`gX;R2cgF8$?
zA+anmGbb@ACl#Ej5IRsbDCFgrpm-;zA~y%(8?Xhs5dXt6Hz+-TROo>vbrdoZ^HOp^
z9?8kf%`AcV4#^GqX$m0K>ctoV2v!76C#Yd#rJ&(lS_Eph<Wwpo78K-UrWS)rEKs_E
z1vRLUfW$c{aKR>lLJ(947i;P%I6@ml2s=Rz1Q`HQ4oP^adg*%Ls0RB(4=GIG#^o0w
zDL@WpJ)}gQU7lE!UTme{m{+Ngn39qSsxuRF6!Hr|46wrs5{tn!$bL}FLMvK@@{CkO
z+=EM7kSjAwpr*T4B!UWaXgasEvr_=qyBQ_9Ii@+8NhqxukVo^2N)*ylOOR{;djzBr
z7I(I23N+Ngo>$j|_~#aLN`CH3MsVp@1S;YDiXfa@?9jY$iv<*!nvA!&z#8L0yj!eb
zwkBf{4+8^3m0W0EQEGC2dR``|PzHrJ%yuQ!VkHGlzFVw0`Q@oaw*)|P(6De$OwLHX
z#Q?VS7CR`VrsU@qaWXJ4+~NUOfVsZl7Va%>B<~e*GcYiKEiGaLspLyfEpY|OL)CJH
zfeH)PqN4nwTg>UHC7SHFI6!uSilke7sEO_t8zdgVE&yAMFnuLMkt72H!>>MPtC-N@
z)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?Psf;GS6|oQ5Z53D
zvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi>*g3JQ___EZzl>8!n
zSUl^4oD2=ZV*U8|%)HE!_;|g7%3C1+g1ie2Lv>J9qynm(WH=Z>kcWwbk%y6mNrVwZ
z^MFYX5TA*Mu}B&m%YK@ix7g$3Q}UDJ<8N`r$ETHonz!-sMWDK_2-IIG0@ZT2*y2k|
sGINT-;atQA3U-iwaIhc|QlMDiuz_?&>_ADUm;+Q#%8M}ZFtIQL0ONKi00000

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index e4928bd3a95a7fa0c5153de3137e3d337a6b9728..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 11344
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
CyTJ+o

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/dom.cpython-39.pyc
deleted file mode 100644
index 47664e6b588d9feebf437bcfe5c864839a3e6a21..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree.cpython-39.pyc
deleted file mode 100644
index fcc114b380aee1df39d9a2b8e2be72ad0b24bc7b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 11849
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
BiX#93

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/__pycache__/etree_lxml.cpython-39.pyc
deleted file mode 100644
index 328dbb6ca730053534aeb3d2e7b477426d2afae8..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py
deleted file mode 100644
index 965fce29..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/base.py
+++ /dev/null
@@ -1,417 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-from pip._vendor.six import text_type
-
-from ..constants import scopingElements, tableInsertModeElements, namespaces
-
-# The scope markers are inserted when entering object elements,
-# marquees, table cells, and table captions, and are used to prevent formatting
-# from "leaking" into tables, object elements, and marquees.
-Marker = None
-
-listElementsMap = {
-    None: (frozenset(scopingElements), False),
-    "button": (frozenset(scopingElements | {(namespaces["html"], "button")}), False),
-    "list": (frozenset(scopingElements | {(namespaces["html"], "ol"),
-                                          (namespaces["html"], "ul")}), False),
-    "table": (frozenset([(namespaces["html"], "html"),
-                         (namespaces["html"], "table")]), False),
-    "select": (frozenset([(namespaces["html"], "optgroup"),
-                          (namespaces["html"], "option")]), True)
-}
-
-
-class Node(object):
-    """Represents an item in the tree"""
-    def __init__(self, name):
-        """Creates a Node
-
-        :arg name: The tag name associated with the node
-
-        """
-        # The tag name associated with the node
-        self.name = name
-        # The parent of the current node (or None for the document node)
-        self.parent = None
-        # The value of the current node (applies to text nodes and comments)
-        self.value = None
-        # A dict holding name -> value pairs for attributes of the node
-        self.attributes = {}
-        # A list of child nodes of the current node. This must include all
-        # elements but not necessarily other node types.
-        self.childNodes = []
-        # A list of miscellaneous flags that can be set on the node.
-        self._flags = []
-
-    def __str__(self):
-        attributesStr = " ".join(["%s=\"%s\"" % (name, value)
-                                  for name, value in
-                                  self.attributes.items()])
-        if attributesStr:
-            return "<%s %s>" % (self.name, attributesStr)
-        else:
-            return "<%s>" % (self.name)
-
-    def __repr__(self):
-        return "<%s>" % (self.name)
-
-    def appendChild(self, node):
-        """Insert node as a child of the current node
-
-        :arg node: the node to insert
-
-        """
-        raise NotImplementedError
-
-    def insertText(self, data, insertBefore=None):
-        """Insert data as text in the current node, positioned before the
-        start of node insertBefore or to the end of the node's text.
-
-        :arg data: the data to insert
-
-        :arg insertBefore: True if you want to insert the text before the node
-            and False if you want to insert it after the node
-
-        """
-        raise NotImplementedError
-
-    def insertBefore(self, node, refNode):
-        """Insert node as a child of the current node, before refNode in the
-        list of child nodes. Raises ValueError if refNode is not a child of
-        the current node
-
-        :arg node: the node to insert
-
-        :arg refNode: the child node to insert the node before
-
-        """
-        raise NotImplementedError
-
-    def removeChild(self, node):
-        """Remove node from the children of the current node
-
-        :arg node: the child node to remove
-
-        """
-        raise NotImplementedError
-
-    def reparentChildren(self, newParent):
-        """Move all the children of the current node to newParent.
-        This is needed so that trees that don't store text as nodes move the
-        text in the correct way
-
-        :arg newParent: the node to move all this node's children to
-
-        """
-        # XXX - should this method be made more general?
-        for child in self.childNodes:
-            newParent.appendChild(child)
-        self.childNodes = []
-
-    def cloneNode(self):
-        """Return a shallow copy of the current node i.e. a node with the same
-        name and attributes but with no parent or child nodes
-        """
-        raise NotImplementedError
-
-    def hasContent(self):
-        """Return true if the node has children or text, false otherwise
-        """
-        raise NotImplementedError
-
-
-class ActiveFormattingElements(list):
-    def append(self, node):
-        equalCount = 0
-        if node != Marker:
-            for element in self[::-1]:
-                if element == Marker:
-                    break
-                if self.nodesEqual(element, node):
-                    equalCount += 1
-                if equalCount == 3:
-                    self.remove(element)
-                    break
-        list.append(self, node)
-
-    def nodesEqual(self, node1, node2):
-        if not node1.nameTuple == node2.nameTuple:
-            return False
-
-        if not node1.attributes == node2.attributes:
-            return False
-
-        return True
-
-
-class TreeBuilder(object):
-    """Base treebuilder implementation
-
-    * documentClass - the class to use for the bottommost node of a document
-    * elementClass - the class to use for HTML Elements
-    * commentClass - the class to use for comments
-    * doctypeClass - the class to use for doctypes
-
-    """
-    # pylint:disable=not-callable
-
-    # Document class
-    documentClass = None
-
-    # The class to use for creating a node
-    elementClass = None
-
-    # The class to use for creating comments
-    commentClass = None
-
-    # The class to use for creating doctypes
-    doctypeClass = None
-
-    # Fragment class
-    fragmentClass = None
-
-    def __init__(self, namespaceHTMLElements):
-        """Create a TreeBuilder
-
-        :arg namespaceHTMLElements: whether or not to namespace HTML elements
-
-        """
-        if namespaceHTMLElements:
-            self.defaultNamespace = "http://www.w3.org/1999/xhtml"
-        else:
-            self.defaultNamespace = None
-        self.reset()
-
-    def reset(self):
-        self.openElements = []
-        self.activeFormattingElements = ActiveFormattingElements()
-
-        # XXX - rename these to headElement, formElement
-        self.headPointer = None
-        self.formPointer = None
-
-        self.insertFromTable = False
-
-        self.document = self.documentClass()
-
-    def elementInScope(self, target, variant=None):
-
-        # If we pass a node in we match that. if we pass a string
-        # match any node with that name
-        exactNode = hasattr(target, "nameTuple")
-        if not exactNode:
-            if isinstance(target, text_type):
-                target = (namespaces["html"], target)
-            assert isinstance(target, tuple)
-
-        listElements, invert = listElementsMap[variant]
-
-        for node in reversed(self.openElements):
-            if exactNode and node == target:
-                return True
-            elif not exactNode and node.nameTuple == target:
-                return True
-            elif (invert ^ (node.nameTuple in listElements)):
-                return False
-
-        assert False  # We should never reach this point
-
-    def reconstructActiveFormattingElements(self):
-        # Within this algorithm the order of steps described in the
-        # specification is not quite the same as the order of steps in the
-        # code. It should still do the same though.
-
-        # Step 1: stop the algorithm when there's nothing to do.
-        if not self.activeFormattingElements:
-            return
-
-        # Step 2 and step 3: we start with the last element. So i is -1.
-        i = len(self.activeFormattingElements) - 1
-        entry = self.activeFormattingElements[i]
-        if entry == Marker or entry in self.openElements:
-            return
-
-        # Step 6
-        while entry != Marker and entry not in self.openElements:
-            if i == 0:
-                # This will be reset to 0 below
-                i = -1
-                break
-            i -= 1
-            # Step 5: let entry be one earlier in the list.
-            entry = self.activeFormattingElements[i]
-
-        while True:
-            # Step 7
-            i += 1
-
-            # Step 8
-            entry = self.activeFormattingElements[i]
-            clone = entry.cloneNode()  # Mainly to get a new copy of the attributes
-
-            # Step 9
-            element = self.insertElement({"type": "StartTag",
-                                          "name": clone.name,
-                                          "namespace": clone.namespace,
-                                          "data": clone.attributes})
-
-            # Step 10
-            self.activeFormattingElements[i] = element
-
-            # Step 11
-            if element == self.activeFormattingElements[-1]:
-                break
-
-    def clearActiveFormattingElements(self):
-        entry = self.activeFormattingElements.pop()
-        while self.activeFormattingElements and entry != Marker:
-            entry = self.activeFormattingElements.pop()
-
-    def elementInActiveFormattingElements(self, name):
-        """Check if an element exists between the end of the active
-        formatting elements and the last marker. If it does, return it, else
-        return false"""
-
-        for item in self.activeFormattingElements[::-1]:
-            # Check for Marker first because if it's a Marker it doesn't have a
-            # name attribute.
-            if item == Marker:
-                break
-            elif item.name == name:
-                return item
-        return False
-
-    def insertRoot(self, token):
-        element = self.createElement(token)
-        self.openElements.append(element)
-        self.document.appendChild(element)
-
-    def insertDoctype(self, token):
-        name = token["name"]
-        publicId = token["publicId"]
-        systemId = token["systemId"]
-
-        doctype = self.doctypeClass(name, publicId, systemId)
-        self.document.appendChild(doctype)
-
-    def insertComment(self, token, parent=None):
-        if parent is None:
-            parent = self.openElements[-1]
-        parent.appendChild(self.commentClass(token["data"]))
-
-    def createElement(self, token):
-        """Create an element but don't insert it anywhere"""
-        name = token["name"]
-        namespace = token.get("namespace", self.defaultNamespace)
-        element = self.elementClass(name, namespace)
-        element.attributes = token["data"]
-        return element
-
-    def _getInsertFromTable(self):
-        return self._insertFromTable
-
-    def _setInsertFromTable(self, value):
-        """Switch the function used to insert an element from the
-        normal one to the misnested table one and back again"""
-        self._insertFromTable = value
-        if value:
-            self.insertElement = self.insertElementTable
-        else:
-            self.insertElement = self.insertElementNormal
-
-    insertFromTable = property(_getInsertFromTable, _setInsertFromTable)
-
-    def insertElementNormal(self, token):
-        name = token["name"]
-        assert isinstance(name, text_type), "Element %s not unicode" % name
-        namespace = token.get("namespace", self.defaultNamespace)
-        element = self.elementClass(name, namespace)
-        element.attributes = token["data"]
-        self.openElements[-1].appendChild(element)
-        self.openElements.append(element)
-        return element
-
-    def insertElementTable(self, token):
-        """Create an element and insert it into the tree"""
-        element = self.createElement(token)
-        if self.openElements[-1].name not in tableInsertModeElements:
-            return self.insertElementNormal(token)
-        else:
-            # We should be in the InTable mode. This means we want to do
-            # special magic element rearranging
-            parent, insertBefore = self.getTableMisnestedNodePosition()
-            if insertBefore is None:
-                parent.appendChild(element)
-            else:
-                parent.insertBefore(element, insertBefore)
-            self.openElements.append(element)
-        return element
-
-    def insertText(self, data, parent=None):
-        """Insert text data."""
-        if parent is None:
-            parent = self.openElements[-1]
-
-        if (not self.insertFromTable or (self.insertFromTable and
-                                         self.openElements[-1].name
-                                         not in tableInsertModeElements)):
-            parent.insertText(data)
-        else:
-            # We should be in the InTable mode. This means we want to do
-            # special magic element rearranging
-            parent, insertBefore = self.getTableMisnestedNodePosition()
-            parent.insertText(data, insertBefore)
-
-    def getTableMisnestedNodePosition(self):
-        """Get the foster parent element, and sibling to insert before
-        (or None) when inserting a misnested table node"""
-        # The foster parent element is the one which comes before the most
-        # recently opened table element
-        # XXX - this is really inelegant
-        lastTable = None
-        fosterParent = None
-        insertBefore = None
-        for elm in self.openElements[::-1]:
-            if elm.name == "table":
-                lastTable = elm
-                break
-        if lastTable:
-            # XXX - we should really check that this parent is actually a
-            # node here
-            if lastTable.parent:
-                fosterParent = lastTable.parent
-                insertBefore = lastTable
-            else:
-                fosterParent = self.openElements[
-                    self.openElements.index(lastTable) - 1]
-        else:
-            fosterParent = self.openElements[0]
-        return fosterParent, insertBefore
-
-    def generateImpliedEndTags(self, exclude=None):
-        name = self.openElements[-1].name
-        # XXX td, th and tr are not actually needed
-        if (name in frozenset(("dd", "dt", "li", "option", "optgroup", "p", "rp", "rt")) and
-                name != exclude):
-            self.openElements.pop()
-            # XXX This is not entirely what the specification says. We should
-            # investigate it more closely.
-            self.generateImpliedEndTags(exclude)
-
-    def getDocument(self):
-        """Return the final tree"""
-        return self.document
-
-    def getFragment(self):
-        """Return the final fragment"""
-        # assert self.innerHTML
-        fragment = self.fragmentClass()
-        self.openElements[0].reparentChildren(fragment)
-        return fragment
-
-    def testSerializer(self, node):
-        """Serialize the subtree of node in the format required by unit tests
-
-        :arg node: the node from which to start serializing
-
-        """
-        raise NotImplementedError
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py
deleted file mode 100644
index d8b53004..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/dom.py
+++ /dev/null
@@ -1,239 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-
-try:
-    from collections.abc import MutableMapping
-except ImportError:  # Python 2.7
-    from collections import MutableMapping
-from xml.dom import minidom, Node
-import weakref
-
-from . import base
-from .. import constants
-from ..constants import namespaces
-from .._utils import moduleFactoryFactory
-
-
-def getDomBuilder(DomImplementation):
-    Dom = DomImplementation
-
-    class AttrList(MutableMapping):
-        def __init__(self, element):
-            self.element = element
-
-        def __iter__(self):
-            return iter(self.element.attributes.keys())
-
-        def __setitem__(self, name, value):
-            if isinstance(name, tuple):
-                raise NotImplementedError
-            else:
-                attr = self.element.ownerDocument.createAttribute(name)
-                attr.value = value
-                self.element.attributes[name] = attr
-
-        def __len__(self):
-            return len(self.element.attributes)
-
-        def items(self):
-            return list(self.element.attributes.items())
-
-        def values(self):
-            return list(self.element.attributes.values())
-
-        def __getitem__(self, name):
-            if isinstance(name, tuple):
-                raise NotImplementedError
-            else:
-                return self.element.attributes[name].value
-
-        def __delitem__(self, name):
-            if isinstance(name, tuple):
-                raise NotImplementedError
-            else:
-                del self.element.attributes[name]
-
-    class NodeBuilder(base.Node):
-        def __init__(self, element):
-            base.Node.__init__(self, element.nodeName)
-            self.element = element
-
-        namespace = property(lambda self: hasattr(self.element, "namespaceURI") and
-                             self.element.namespaceURI or None)
-
-        def appendChild(self, node):
-            node.parent = self
-            self.element.appendChild(node.element)
-
-        def insertText(self, data, insertBefore=None):
-            text = self.element.ownerDocument.createTextNode(data)
-            if insertBefore:
-                self.element.insertBefore(text, insertBefore.element)
-            else:
-                self.element.appendChild(text)
-
-        def insertBefore(self, node, refNode):
-            self.element.insertBefore(node.element, refNode.element)
-            node.parent = self
-
-        def removeChild(self, node):
-            if node.element.parentNode == self.element:
-                self.element.removeChild(node.element)
-            node.parent = None
-
-        def reparentChildren(self, newParent):
-            while self.element.hasChildNodes():
-                child = self.element.firstChild
-                self.element.removeChild(child)
-                newParent.element.appendChild(child)
-            self.childNodes = []
-
-        def getAttributes(self):
-            return AttrList(self.element)
-
-        def setAttributes(self, attributes):
-            if attributes:
-                for name, value in list(attributes.items()):
-                    if isinstance(name, tuple):
-                        if name[0] is not None:
-                            qualifiedName = (name[0] + ":" + name[1])
-                        else:
-                            qualifiedName = name[1]
-                        self.element.setAttributeNS(name[2], qualifiedName,
-                                                    value)
-                    else:
-                        self.element.setAttribute(
-                            name, value)
-        attributes = property(getAttributes, setAttributes)
-
-        def cloneNode(self):
-            return NodeBuilder(self.element.cloneNode(False))
-
-        def hasContent(self):
-            return self.element.hasChildNodes()
-
-        def getNameTuple(self):
-            if self.namespace is None:
-                return namespaces["html"], self.name
-            else:
-                return self.namespace, self.name
-
-        nameTuple = property(getNameTuple)
-
-    class TreeBuilder(base.TreeBuilder):  # pylint:disable=unused-variable
-        def documentClass(self):
-            self.dom = Dom.getDOMImplementation().createDocument(None, None, None)
-            return weakref.proxy(self)
-
-        def insertDoctype(self, token):
-            name = token["name"]
-            publicId = token["publicId"]
-            systemId = token["systemId"]
-
-            domimpl = Dom.getDOMImplementation()
-            doctype = domimpl.createDocumentType(name, publicId, systemId)
-            self.document.appendChild(NodeBuilder(doctype))
-            if Dom == minidom:
-                doctype.ownerDocument = self.dom
-
-        def elementClass(self, name, namespace=None):
-            if namespace is None and self.defaultNamespace is None:
-                node = self.dom.createElement(name)
-            else:
-                node = self.dom.createElementNS(namespace, name)
-
-            return NodeBuilder(node)
-
-        def commentClass(self, data):
-            return NodeBuilder(self.dom.createComment(data))
-
-        def fragmentClass(self):
-            return NodeBuilder(self.dom.createDocumentFragment())
-
-        def appendChild(self, node):
-            self.dom.appendChild(node.element)
-
-        def testSerializer(self, element):
-            return testSerializer(element)
-
-        def getDocument(self):
-            return self.dom
-
-        def getFragment(self):
-            return base.TreeBuilder.getFragment(self).element
-
-        def insertText(self, data, parent=None):
-            data = data
-            if parent != self:
-                base.TreeBuilder.insertText(self, data, parent)
-            else:
-                # HACK: allow text nodes as children of the document node
-                if hasattr(self.dom, '_child_node_types'):
-                    # pylint:disable=protected-access
-                    if Node.TEXT_NODE not in self.dom._child_node_types:
-                        self.dom._child_node_types = list(self.dom._child_node_types)
-                        self.dom._child_node_types.append(Node.TEXT_NODE)
-                self.dom.appendChild(self.dom.createTextNode(data))
-
-        implementation = DomImplementation
-        name = None
-
-    def testSerializer(element):
-        element.normalize()
-        rv = []
-
-        def serializeElement(element, indent=0):
-            if element.nodeType == Node.DOCUMENT_TYPE_NODE:
-                if element.name:
-                    if element.publicId or element.systemId:
-                        publicId = element.publicId or ""
-                        systemId = element.systemId or ""
-                        rv.append("""|%s<!DOCTYPE %s "%s" "%s">""" %
-                                  (' ' * indent, element.name, publicId, systemId))
-                    else:
-                        rv.append("|%s<!DOCTYPE %s>" % (' ' * indent, element.name))
-                else:
-                    rv.append("|%s<!DOCTYPE >" % (' ' * indent,))
-            elif element.nodeType == Node.DOCUMENT_NODE:
-                rv.append("#document")
-            elif element.nodeType == Node.DOCUMENT_FRAGMENT_NODE:
-                rv.append("#document-fragment")
-            elif element.nodeType == Node.COMMENT_NODE:
-                rv.append("|%s<!-- %s -->" % (' ' * indent, element.nodeValue))
-            elif element.nodeType == Node.TEXT_NODE:
-                rv.append("|%s\"%s\"" % (' ' * indent, element.nodeValue))
-            else:
-                if (hasattr(element, "namespaceURI") and
-                        element.namespaceURI is not None):
-                    name = "%s %s" % (constants.prefixes[element.namespaceURI],
-                                      element.nodeName)
-                else:
-                    name = element.nodeName
-                rv.append("|%s<%s>" % (' ' * indent, name))
-                if element.hasAttributes():
-                    attributes = []
-                    for i in range(len(element.attributes)):
-                        attr = element.attributes.item(i)
-                        name = attr.nodeName
-                        value = attr.value
-                        ns = attr.namespaceURI
-                        if ns:
-                            name = "%s %s" % (constants.prefixes[ns], attr.localName)
-                        else:
-                            name = attr.nodeName
-                        attributes.append((name, value))
-
-                    for name, value in sorted(attributes):
-                        rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value))
-            indent += 2
-            for child in element.childNodes:
-                serializeElement(child, indent)
-        serializeElement(element, 0)
-
-        return "\n".join(rv)
-
-    return locals()
-
-
-# The actual means to get a module!
-getDomModule = moduleFactoryFactory(getDomBuilder)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py
deleted file mode 100644
index ea92dc30..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree.py
+++ /dev/null
@@ -1,343 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-# pylint:disable=protected-access
-
-from pip._vendor.six import text_type
-
-import re
-
-from copy import copy
-
-from . import base
-from .. import _ihatexml
-from .. import constants
-from ..constants import namespaces
-from .._utils import moduleFactoryFactory
-
-tag_regexp = re.compile("{([^}]*)}(.*)")
-
-
-def getETreeBuilder(ElementTreeImplementation, fullTree=False):
-    ElementTree = ElementTreeImplementation
-    ElementTreeCommentType = ElementTree.Comment("asd").tag
-
-    class Element(base.Node):
-        def __init__(self, name, namespace=None):
-            self._name = name
-            self._namespace = namespace
-            self._element = ElementTree.Element(self._getETreeTag(name,
-                                                                  namespace))
-            if namespace is None:
-                self.nameTuple = namespaces["html"], self._name
-            else:
-                self.nameTuple = self._namespace, self._name
-            self.parent = None
-            self._childNodes = []
-            self._flags = []
-
-        def _getETreeTag(self, name, namespace):
-            if namespace is None:
-                etree_tag = name
-            else:
-                etree_tag = "{%s}%s" % (namespace, name)
-            return etree_tag
-
-        def _setName(self, name):
-            self._name = name
-            self._element.tag = self._getETreeTag(self._name, self._namespace)
-
-        def _getName(self):
-            return self._name
-
-        name = property(_getName, _setName)
-
-        def _setNamespace(self, namespace):
-            self._namespace = namespace
-            self._element.tag = self._getETreeTag(self._name, self._namespace)
-
-        def _getNamespace(self):
-            return self._namespace
-
-        namespace = property(_getNamespace, _setNamespace)
-
-        def _getAttributes(self):
-            return self._element.attrib
-
-        def _setAttributes(self, attributes):
-            el_attrib = self._element.attrib
-            el_attrib.clear()
-            if attributes:
-                # calling .items _always_ allocates, and the above truthy check is cheaper than the
-                # allocation on average
-                for key, value in attributes.items():
-                    if isinstance(key, tuple):
-                        name = "{%s}%s" % (key[2], key[1])
-                    else:
-                        name = key
-                    el_attrib[name] = value
-
-        attributes = property(_getAttributes, _setAttributes)
-
-        def _getChildNodes(self):
-            return self._childNodes
-
-        def _setChildNodes(self, value):
-            del self._element[:]
-            self._childNodes = []
-            for element in value:
-                self.insertChild(element)
-
-        childNodes = property(_getChildNodes, _setChildNodes)
-
-        def hasContent(self):
-            """Return true if the node has children or text"""
-            return bool(self._element.text or len(self._element))
-
-        def appendChild(self, node):
-            self._childNodes.append(node)
-            self._element.append(node._element)
-            node.parent = self
-
-        def insertBefore(self, node, refNode):
-            index = list(self._element).index(refNode._element)
-            self._element.insert(index, node._element)
-            node.parent = self
-
-        def removeChild(self, node):
-            self._childNodes.remove(node)
-            self._element.remove(node._element)
-            node.parent = None
-
-        def insertText(self, data, insertBefore=None):
-            if not(len(self._element)):
-                if not self._element.text:
-                    self._element.text = ""
-                self._element.text += data
-            elif insertBefore is None:
-                # Insert the text as the tail of the last child element
-                if not self._element[-1].tail:
-                    self._element[-1].tail = ""
-                self._element[-1].tail += data
-            else:
-                # Insert the text before the specified node
-                children = list(self._element)
-                index = children.index(insertBefore._element)
-                if index > 0:
-                    if not self._element[index - 1].tail:
-                        self._element[index - 1].tail = ""
-                    self._element[index - 1].tail += data
-                else:
-                    if not self._element.text:
-                        self._element.text = ""
-                    self._element.text += data
-
-        def cloneNode(self):
-            element = type(self)(self.name, self.namespace)
-            if self._element.attrib:
-                element._element.attrib = copy(self._element.attrib)
-            return element
-
-        def reparentChildren(self, newParent):
-            if newParent.childNodes:
-                newParent.childNodes[-1]._element.tail += self._element.text
-            else:
-                if not newParent._element.text:
-                    newParent._element.text = ""
-                if self._element.text is not None:
-                    newParent._element.text += self._element.text
-            self._element.text = ""
-            base.Node.reparentChildren(self, newParent)
-
-    class Comment(Element):
-        def __init__(self, data):
-            # Use the superclass constructor to set all properties on the
-            # wrapper element
-            self._element = ElementTree.Comment(data)
-            self.parent = None
-            self._childNodes = []
-            self._flags = []
-
-        def _getData(self):
-            return self._element.text
-
-        def _setData(self, value):
-            self._element.text = value
-
-        data = property(_getData, _setData)
-
-    class DocumentType(Element):
-        def __init__(self, name, publicId, systemId):
-            Element.__init__(self, "<!DOCTYPE>")
-            self._element.text = name
-            self.publicId = publicId
-            self.systemId = systemId
-
-        def _getPublicId(self):
-            return self._element.get("publicId", "")
-
-        def _setPublicId(self, value):
-            if value is not None:
-                self._element.set("publicId", value)
-
-        publicId = property(_getPublicId, _setPublicId)
-
-        def _getSystemId(self):
-            return self._element.get("systemId", "")
-
-        def _setSystemId(self, value):
-            if value is not None:
-                self._element.set("systemId", value)
-
-        systemId = property(_getSystemId, _setSystemId)
-
-    class Document(Element):
-        def __init__(self):
-            Element.__init__(self, "DOCUMENT_ROOT")
-
-    class DocumentFragment(Element):
-        def __init__(self):
-            Element.__init__(self, "DOCUMENT_FRAGMENT")
-
-    def testSerializer(element):
-        rv = []
-
-        def serializeElement(element, indent=0):
-            if not(hasattr(element, "tag")):
-                element = element.getroot()
-            if element.tag == "<!DOCTYPE>":
-                if element.get("publicId") or element.get("systemId"):
-                    publicId = element.get("publicId") or ""
-                    systemId = element.get("systemId") or ""
-                    rv.append("""<!DOCTYPE %s "%s" "%s">""" %
-                              (element.text, publicId, systemId))
-                else:
-                    rv.append("<!DOCTYPE %s>" % (element.text,))
-            elif element.tag == "DOCUMENT_ROOT":
-                rv.append("#document")
-                if element.text is not None:
-                    rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text))
-                if element.tail is not None:
-                    raise TypeError("Document node cannot have tail")
-                if hasattr(element, "attrib") and len(element.attrib):
-                    raise TypeError("Document node cannot have attributes")
-            elif element.tag == ElementTreeCommentType:
-                rv.append("|%s<!-- %s -->" % (' ' * indent, element.text))
-            else:
-                assert isinstance(element.tag, text_type), \
-                    "Expected unicode, got %s, %s" % (type(element.tag), element.tag)
-                nsmatch = tag_regexp.match(element.tag)
-
-                if nsmatch is None:
-                    name = element.tag
-                else:
-                    ns, name = nsmatch.groups()
-                    prefix = constants.prefixes[ns]
-                    name = "%s %s" % (prefix, name)
-                rv.append("|%s<%s>" % (' ' * indent, name))
-
-                if hasattr(element, "attrib"):
-                    attributes = []
-                    for name, value in element.attrib.items():
-                        nsmatch = tag_regexp.match(name)
-                        if nsmatch is not None:
-                            ns, name = nsmatch.groups()
-                            prefix = constants.prefixes[ns]
-                            attr_string = "%s %s" % (prefix, name)
-                        else:
-                            attr_string = name
-                        attributes.append((attr_string, value))
-
-                    for name, value in sorted(attributes):
-                        rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value))
-                if element.text:
-                    rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text))
-            indent += 2
-            for child in element:
-                serializeElement(child, indent)
-            if element.tail:
-                rv.append("|%s\"%s\"" % (' ' * (indent - 2), element.tail))
-        serializeElement(element, 0)
-
-        return "\n".join(rv)
-
-    def tostring(element):  # pylint:disable=unused-variable
-        """Serialize an element and its child nodes to a string"""
-        rv = []
-        filter = _ihatexml.InfosetFilter()
-
-        def serializeElement(element):
-            if isinstance(element, ElementTree.ElementTree):
-                element = element.getroot()
-
-            if element.tag == "<!DOCTYPE>":
-                if element.get("publicId") or element.get("systemId"):
-                    publicId = element.get("publicId") or ""
-                    systemId = element.get("systemId") or ""
-                    rv.append("""<!DOCTYPE %s PUBLIC "%s" "%s">""" %
-                              (element.text, publicId, systemId))
-                else:
-                    rv.append("<!DOCTYPE %s>" % (element.text,))
-            elif element.tag == "DOCUMENT_ROOT":
-                if element.text is not None:
-                    rv.append(element.text)
-                if element.tail is not None:
-                    raise TypeError("Document node cannot have tail")
-                if hasattr(element, "attrib") and len(element.attrib):
-                    raise TypeError("Document node cannot have attributes")
-
-                for child in element:
-                    serializeElement(child)
-
-            elif element.tag == ElementTreeCommentType:
-                rv.append("<!--%s-->" % (element.text,))
-            else:
-                # This is assumed to be an ordinary element
-                if not element.attrib:
-                    rv.append("<%s>" % (filter.fromXmlName(element.tag),))
-                else:
-                    attr = " ".join(["%s=\"%s\"" % (
-                        filter.fromXmlName(name), value)
-                        for name, value in element.attrib.items()])
-                    rv.append("<%s %s>" % (element.tag, attr))
-                if element.text:
-                    rv.append(element.text)
-
-                for child in element:
-                    serializeElement(child)
-
-                rv.append("</%s>" % (element.tag,))
-
-            if element.tail:
-                rv.append(element.tail)
-
-        serializeElement(element)
-
-        return "".join(rv)
-
-    class TreeBuilder(base.TreeBuilder):  # pylint:disable=unused-variable
-        documentClass = Document
-        doctypeClass = DocumentType
-        elementClass = Element
-        commentClass = Comment
-        fragmentClass = DocumentFragment
-        implementation = ElementTreeImplementation
-
-        def testSerializer(self, element):
-            return testSerializer(element)
-
-        def getDocument(self):
-            if fullTree:
-                return self.document._element
-            else:
-                if self.defaultNamespace is not None:
-                    return self.document._element.find(
-                        "{%s}html" % self.defaultNamespace)
-                else:
-                    return self.document._element.find("html")
-
-        def getFragment(self):
-            return base.TreeBuilder.getFragment(self)._element
-
-    return locals()
-
-
-getETreeModule = moduleFactoryFactory(getETreeBuilder)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py b/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py
deleted file mode 100644
index f037759f..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treebuilders/etree_lxml.py
+++ /dev/null
@@ -1,392 +0,0 @@
-"""Module for supporting the lxml.etree library. The idea here is to use as much
-of the native library as possible, without using fragile hacks like custom element
-names that break between releases. The downside of this is that we cannot represent
-all possible trees; specifically the following are known to cause problems:
-
-Text or comments as siblings of the root element
-Docypes with no name
-
-When any of these things occur, we emit a DataLossWarning
-"""
-
-from __future__ import absolute_import, division, unicode_literals
-# pylint:disable=protected-access
-
-import warnings
-import re
-import sys
-
-try:
-    from collections.abc import MutableMapping
-except ImportError:
-    from collections import MutableMapping
-
-from . import base
-from ..constants import DataLossWarning
-from .. import constants
-from . import etree as etree_builders
-from .. import _ihatexml
-
-import lxml.etree as etree
-from pip._vendor.six import PY3, binary_type
-
-
-fullTree = True
-tag_regexp = re.compile("{([^}]*)}(.*)")
-
-comment_type = etree.Comment("asd").tag
-
-
-class DocumentType(object):
-    def __init__(self, name, publicId, systemId):
-        self.name = name
-        self.publicId = publicId
-        self.systemId = systemId
-
-
-class Document(object):
-    def __init__(self):
-        self._elementTree = None
-        self._childNodes = []
-
-    def appendChild(self, element):
-        last = self._elementTree.getroot()
-        for last in self._elementTree.getroot().itersiblings():
-            pass
-
-        last.addnext(element._element)
-
-    def _getChildNodes(self):
-        return self._childNodes
-
-    childNodes = property(_getChildNodes)
-
-
-def testSerializer(element):
-    rv = []
-    infosetFilter = _ihatexml.InfosetFilter(preventDoubleDashComments=True)
-
-    def serializeElement(element, indent=0):
-        if not hasattr(element, "tag"):
-            if hasattr(element, "getroot"):
-                # Full tree case
-                rv.append("#document")
-                if element.docinfo.internalDTD:
-                    if not (element.docinfo.public_id or
-                            element.docinfo.system_url):
-                        dtd_str = "<!DOCTYPE %s>" % element.docinfo.root_name
-                    else:
-                        dtd_str = """<!DOCTYPE %s "%s" "%s">""" % (
-                            element.docinfo.root_name,
-                            element.docinfo.public_id,
-                            element.docinfo.system_url)
-                    rv.append("|%s%s" % (' ' * (indent + 2), dtd_str))
-                next_element = element.getroot()
-                while next_element.getprevious() is not None:
-                    next_element = next_element.getprevious()
-                while next_element is not None:
-                    serializeElement(next_element, indent + 2)
-                    next_element = next_element.getnext()
-            elif isinstance(element, str) or isinstance(element, bytes):
-                # Text in a fragment
-                assert isinstance(element, str) or sys.version_info[0] == 2
-                rv.append("|%s\"%s\"" % (' ' * indent, element))
-            else:
-                # Fragment case
-                rv.append("#document-fragment")
-                for next_element in element:
-                    serializeElement(next_element, indent + 2)
-        elif element.tag == comment_type:
-            rv.append("|%s<!-- %s -->" % (' ' * indent, element.text))
-            if hasattr(element, "tail") and element.tail:
-                rv.append("|%s\"%s\"" % (' ' * indent, element.tail))
-        else:
-            assert isinstance(element, etree._Element)
-            nsmatch = etree_builders.tag_regexp.match(element.tag)
-            if nsmatch is not None:
-                ns = nsmatch.group(1)
-                tag = nsmatch.group(2)
-                prefix = constants.prefixes[ns]
-                rv.append("|%s<%s %s>" % (' ' * indent, prefix,
-                                          infosetFilter.fromXmlName(tag)))
-            else:
-                rv.append("|%s<%s>" % (' ' * indent,
-                                       infosetFilter.fromXmlName(element.tag)))
-
-            if hasattr(element, "attrib"):
-                attributes = []
-                for name, value in element.attrib.items():
-                    nsmatch = tag_regexp.match(name)
-                    if nsmatch is not None:
-                        ns, name = nsmatch.groups()
-                        name = infosetFilter.fromXmlName(name)
-                        prefix = constants.prefixes[ns]
-                        attr_string = "%s %s" % (prefix, name)
-                    else:
-                        attr_string = infosetFilter.fromXmlName(name)
-                    attributes.append((attr_string, value))
-
-                for name, value in sorted(attributes):
-                    rv.append('|%s%s="%s"' % (' ' * (indent + 2), name, value))
-
-            if element.text:
-                rv.append("|%s\"%s\"" % (' ' * (indent + 2), element.text))
-            indent += 2
-            for child in element:
-                serializeElement(child, indent)
-            if hasattr(element, "tail") and element.tail:
-                rv.append("|%s\"%s\"" % (' ' * (indent - 2), element.tail))
-    serializeElement(element, 0)
-
-    return "\n".join(rv)
-
-
-def tostring(element):
-    """Serialize an element and its child nodes to a string"""
-    rv = []
-
-    def serializeElement(element):
-        if not hasattr(element, "tag"):
-            if element.docinfo.internalDTD:
-                if element.docinfo.doctype:
-                    dtd_str = element.docinfo.doctype
-                else:
-                    dtd_str = "<!DOCTYPE %s>" % element.docinfo.root_name
-                rv.append(dtd_str)
-            serializeElement(element.getroot())
-
-        elif element.tag == comment_type:
-            rv.append("<!--%s-->" % (element.text,))
-
-        else:
-            # This is assumed to be an ordinary element
-            if not element.attrib:
-                rv.append("<%s>" % (element.tag,))
-            else:
-                attr = " ".join(["%s=\"%s\"" % (name, value)
-                                 for name, value in element.attrib.items()])
-                rv.append("<%s %s>" % (element.tag, attr))
-            if element.text:
-                rv.append(element.text)
-
-            for child in element:
-                serializeElement(child)
-
-            rv.append("</%s>" % (element.tag,))
-
-        if hasattr(element, "tail") and element.tail:
-            rv.append(element.tail)
-
-    serializeElement(element)
-
-    return "".join(rv)
-
-
-class TreeBuilder(base.TreeBuilder):
-    documentClass = Document
-    doctypeClass = DocumentType
-    elementClass = None
-    commentClass = None
-    fragmentClass = Document
-    implementation = etree
-
-    def __init__(self, namespaceHTMLElements, fullTree=False):
-        builder = etree_builders.getETreeModule(etree, fullTree=fullTree)
-        infosetFilter = self.infosetFilter = _ihatexml.InfosetFilter(preventDoubleDashComments=True)
-        self.namespaceHTMLElements = namespaceHTMLElements
-
-        class Attributes(MutableMapping):
-            def __init__(self, element):
-                self._element = element
-
-            def _coerceKey(self, key):
-                if isinstance(key, tuple):
-                    name = "{%s}%s" % (key[2], infosetFilter.coerceAttribute(key[1]))
-                else:
-                    name = infosetFilter.coerceAttribute(key)
-                return name
-
-            def __getitem__(self, key):
-                value = self._element._element.attrib[self._coerceKey(key)]
-                if not PY3 and isinstance(value, binary_type):
-                    value = value.decode("ascii")
-                return value
-
-            def __setitem__(self, key, value):
-                self._element._element.attrib[self._coerceKey(key)] = value
-
-            def __delitem__(self, key):
-                del self._element._element.attrib[self._coerceKey(key)]
-
-            def __iter__(self):
-                return iter(self._element._element.attrib)
-
-            def __len__(self):
-                return len(self._element._element.attrib)
-
-            def clear(self):
-                return self._element._element.attrib.clear()
-
-        class Element(builder.Element):
-            def __init__(self, name, namespace):
-                name = infosetFilter.coerceElement(name)
-                builder.Element.__init__(self, name, namespace=namespace)
-                self._attributes = Attributes(self)
-
-            def _setName(self, name):
-                self._name = infosetFilter.coerceElement(name)
-                self._element.tag = self._getETreeTag(
-                    self._name, self._namespace)
-
-            def _getName(self):
-                return infosetFilter.fromXmlName(self._name)
-
-            name = property(_getName, _setName)
-
-            def _getAttributes(self):
-                return self._attributes
-
-            def _setAttributes(self, value):
-                attributes = self.attributes
-                attributes.clear()
-                attributes.update(value)
-
-            attributes = property(_getAttributes, _setAttributes)
-
-            def insertText(self, data, insertBefore=None):
-                data = infosetFilter.coerceCharacters(data)
-                builder.Element.insertText(self, data, insertBefore)
-
-            def cloneNode(self):
-                element = type(self)(self.name, self.namespace)
-                if self._element.attrib:
-                    element._element.attrib.update(self._element.attrib)
-                return element
-
-        class Comment(builder.Comment):
-            def __init__(self, data):
-                data = infosetFilter.coerceComment(data)
-                builder.Comment.__init__(self, data)
-
-            def _setData(self, data):
-                data = infosetFilter.coerceComment(data)
-                self._element.text = data
-
-            def _getData(self):
-                return self._element.text
-
-            data = property(_getData, _setData)
-
-        self.elementClass = Element
-        self.commentClass = Comment
-        # self.fragmentClass = builder.DocumentFragment
-        base.TreeBuilder.__init__(self, namespaceHTMLElements)
-
-    def reset(self):
-        base.TreeBuilder.reset(self)
-        self.insertComment = self.insertCommentInitial
-        self.initial_comments = []
-        self.doctype = None
-
-    def testSerializer(self, element):
-        return testSerializer(element)
-
-    def getDocument(self):
-        if fullTree:
-            return self.document._elementTree
-        else:
-            return self.document._elementTree.getroot()
-
-    def getFragment(self):
-        fragment = []
-        element = self.openElements[0]._element
-        if element.text:
-            fragment.append(element.text)
-        fragment.extend(list(element))
-        if element.tail:
-            fragment.append(element.tail)
-        return fragment
-
-    def insertDoctype(self, token):
-        name = token["name"]
-        publicId = token["publicId"]
-        systemId = token["systemId"]
-
-        if not name:
-            warnings.warn("lxml cannot represent empty doctype", DataLossWarning)
-            self.doctype = None
-        else:
-            coercedName = self.infosetFilter.coerceElement(name)
-            if coercedName != name:
-                warnings.warn("lxml cannot represent non-xml doctype", DataLossWarning)
-
-            doctype = self.doctypeClass(coercedName, publicId, systemId)
-            self.doctype = doctype
-
-    def insertCommentInitial(self, data, parent=None):
-        assert parent is None or parent is self.document
-        assert self.document._elementTree is None
-        self.initial_comments.append(data)
-
-    def insertCommentMain(self, data, parent=None):
-        if (parent == self.document and
-                self.document._elementTree.getroot()[-1].tag == comment_type):
-            warnings.warn("lxml cannot represent adjacent comments beyond the root elements", DataLossWarning)
-        super(TreeBuilder, self).insertComment(data, parent)
-
-    def insertRoot(self, token):
-        # Because of the way libxml2 works, it doesn't seem to be possible to
-        # alter information like the doctype after the tree has been parsed.
-        # Therefore we need to use the built-in parser to create our initial
-        # tree, after which we can add elements like normal
-        docStr = ""
-        if self.doctype:
-            assert self.doctype.name
-            docStr += "<!DOCTYPE %s" % self.doctype.name
-            if (self.doctype.publicId is not None or
-                    self.doctype.systemId is not None):
-                docStr += (' PUBLIC "%s" ' %
-                           (self.infosetFilter.coercePubid(self.doctype.publicId or "")))
-                if self.doctype.systemId:
-                    sysid = self.doctype.systemId
-                    if sysid.find("'") >= 0 and sysid.find('"') >= 0:
-                        warnings.warn("DOCTYPE system cannot contain single and double quotes", DataLossWarning)
-                        sysid = sysid.replace("'", 'U00027')
-                    if sysid.find("'") >= 0:
-                        docStr += '"%s"' % sysid
-                    else:
-                        docStr += "'%s'" % sysid
-                else:
-                    docStr += "''"
-            docStr += ">"
-            if self.doctype.name != token["name"]:
-                warnings.warn("lxml cannot represent doctype with a different name to the root element", DataLossWarning)
-        docStr += "<THIS_SHOULD_NEVER_APPEAR_PUBLICLY/>"
-        root = etree.fromstring(docStr)
-
-        # Append the initial comments:
-        for comment_token in self.initial_comments:
-            comment = self.commentClass(comment_token["data"])
-            root.addprevious(comment._element)
-
-        # Create the root document and add the ElementTree to it
-        self.document = self.documentClass()
-        self.document._elementTree = root.getroottree()
-
-        # Give the root element the right name
-        name = token["name"]
-        namespace = token.get("namespace", self.defaultNamespace)
-        if namespace is None:
-            etree_tag = name
-        else:
-            etree_tag = "{%s}%s" % (namespace, name)
-        root.tag = etree_tag
-
-        # Add the root element to the internal child/open data structures
-        root_element = self.elementClass(name, namespace)
-        root_element._element = root
-        self.document._childNodes.append(root_element)
-        self.openElements.append(root_element)
-
-        # Reset to the default insert comment function
-        self.insertComment = self.insertCommentMain
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py
deleted file mode 100644
index b2d3aac3..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__init__.py
+++ /dev/null
@@ -1,154 +0,0 @@
-"""A collection of modules for iterating through different kinds of
-tree, generating tokens identical to those produced by the tokenizer
-module.
-
-To create a tree walker for a new type of tree, you need to
-implement a tree walker object (called TreeWalker by convention) that
-implements a 'serialize' method which takes a tree as sole argument and
-returns an iterator which generates tokens.
-"""
-
-from __future__ import absolute_import, division, unicode_literals
-
-from .. import constants
-from .._utils import default_etree
-
-__all__ = ["getTreeWalker", "pprint"]
-
-treeWalkerCache = {}
-
-
-def getTreeWalker(treeType, implementation=None, **kwargs):
-    """Get a TreeWalker class for various types of tree with built-in support
-
-    :arg str treeType: the name of the tree type required (case-insensitive).
-        Supported values are:
-
-        * "dom": The xml.dom.minidom DOM implementation
-        * "etree": A generic walker for tree implementations exposing an
-          elementtree-like interface (known to work with ElementTree,
-          cElementTree and lxml.etree).
-        * "lxml": Optimized walker for lxml.etree
-        * "genshi": a Genshi stream
-
-    :arg implementation: A module implementing the tree type e.g.
-        xml.etree.ElementTree or cElementTree (Currently applies to the "etree"
-        tree type only).
-
-    :arg kwargs: keyword arguments passed to the etree walker--for other
-        walkers, this has no effect
-
-    :returns: a TreeWalker class
-
-    """
-
-    treeType = treeType.lower()
-    if treeType not in treeWalkerCache:
-        if treeType == "dom":
-            from . import dom
-            treeWalkerCache[treeType] = dom.TreeWalker
-        elif treeType == "genshi":
-            from . import genshi
-            treeWalkerCache[treeType] = genshi.TreeWalker
-        elif treeType == "lxml":
-            from . import etree_lxml
-            treeWalkerCache[treeType] = etree_lxml.TreeWalker
-        elif treeType == "etree":
-            from . import etree
-            if implementation is None:
-                implementation = default_etree
-            # XXX: NEVER cache here, caching is done in the etree submodule
-            return etree.getETreeModule(implementation, **kwargs).TreeWalker
-    return treeWalkerCache.get(treeType)
-
-
-def concatenateCharacterTokens(tokens):
-    pendingCharacters = []
-    for token in tokens:
-        type = token["type"]
-        if type in ("Characters", "SpaceCharacters"):
-            pendingCharacters.append(token["data"])
-        else:
-            if pendingCharacters:
-                yield {"type": "Characters", "data": "".join(pendingCharacters)}
-                pendingCharacters = []
-            yield token
-    if pendingCharacters:
-        yield {"type": "Characters", "data": "".join(pendingCharacters)}
-
-
-def pprint(walker):
-    """Pretty printer for tree walkers
-
-    Takes a TreeWalker instance and pretty prints the output of walking the tree.
-
-    :arg walker: a TreeWalker instance
-
-    """
-    output = []
-    indent = 0
-    for token in concatenateCharacterTokens(walker):
-        type = token["type"]
-        if type in ("StartTag", "EmptyTag"):
-            # tag name
-            if token["namespace"] and token["namespace"] != constants.namespaces["html"]:
-                if token["namespace"] in constants.prefixes:
-                    ns = constants.prefixes[token["namespace"]]
-                else:
-                    ns = token["namespace"]
-                name = "%s %s" % (ns, token["name"])
-            else:
-                name = token["name"]
-            output.append("%s<%s>" % (" " * indent, name))
-            indent += 2
-            # attributes (sorted for consistent ordering)
-            attrs = token["data"]
-            for (namespace, localname), value in sorted(attrs.items()):
-                if namespace:
-                    if namespace in constants.prefixes:
-                        ns = constants.prefixes[namespace]
-                    else:
-                        ns = namespace
-                    name = "%s %s" % (ns, localname)
-                else:
-                    name = localname
-                output.append("%s%s=\"%s\"" % (" " * indent, name, value))
-            # self-closing
-            if type == "EmptyTag":
-                indent -= 2
-
-        elif type == "EndTag":
-            indent -= 2
-
-        elif type == "Comment":
-            output.append("%s<!-- %s -->" % (" " * indent, token["data"]))
-
-        elif type == "Doctype":
-            if token["name"]:
-                if token["publicId"]:
-                    output.append("""%s<!DOCTYPE %s "%s" "%s">""" %
-                                  (" " * indent,
-                                   token["name"],
-                                   token["publicId"],
-                                   token["systemId"] if token["systemId"] else ""))
-                elif token["systemId"]:
-                    output.append("""%s<!DOCTYPE %s "" "%s">""" %
-                                  (" " * indent,
-                                   token["name"],
-                                   token["systemId"]))
-                else:
-                    output.append("%s<!DOCTYPE %s>" % (" " * indent,
-                                                       token["name"]))
-            else:
-                output.append("%s<!DOCTYPE >" % (" " * indent,))
-
-        elif type == "Characters":
-            output.append("%s\"%s\"" % (" " * indent, token["data"]))
-
-        elif type == "SpaceCharacters":
-            assert False, "concatenateCharacterTokens should have got rid of all Space tokens"
-
-        else:
-            raise ValueError("Unknown token type, %s" % type)
-
-    return "\n".join(output)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 34fc06cf9a14d6271ded03f3177b5eb10e08e77d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4026
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
TE)gakMjj>(CKhHc9S(i~Irdbl

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/base.cpython-39.pyc
deleted file mode 100644
index bbfc8763f08952bd75c0f9e1920594a433f827ab..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7025
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
A6#xJL

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/dom.cpython-39.pyc
deleted file mode 100644
index 1147e58ae30c8a58fdd3f93181e7639a5f5a7f41..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1760
zcmYe~<>g{vU|^UdaWJ)&m4V?gh=Yt-7#J8F7#J9eofsGxQW#Pga~N_NqZo6UqL^}-
zqnH^%VoW(KxvWvFj0`EvDJ(f`x$IHwj12A!DXb}MEet7asq9%C&CF4pDeS=vnj9}d
zrfV|a;!jK}&d(_=NsZ6UEyyn_xy6x^S(aIxnV)w{pfoQtIX@*eJ}0vzwJ0&CSd;M<
zi(h_9>Ptoj1_lr(DX};;8DtPLW`a3Yhk=11l_82Tg&~S5g)xPxg&~R=<g^xsC>DsL
zqF7VdQ#e`}qS#V6gBdirZgGVarKW}_=47W9C4<a?nG5nh8v_G_Gbji?FfcIGFlI57
zFlI4jGZiV6FlVvUFlMpVFlMpUFlMo*u>`~9IZ7C_IMbNQ7>evln6tQQ7_+$3nBcNJ
z*-S<2G8t-_N_cA+v-lS9FJx$DbYY0KsAaBUTp&=xypXY$xrRAQu&AYmIZLR93B;~p
z&Js>zvSBEUfrzCr)G%kULPScKvqWkbvjl4xvqWo{Y8V%YEo4Yzh1(~d%~W)(ggHwB
z%^i{@j9F4(S3W3V&XP`J3}z@{&XNK75#-twhG2%3jDDK3Q5<>sDXAfq1*t`>3=9lW
zLN5N!p}wwuA@L!R0j}|W{w}UX>>vqt7k_7v&@Gm{#N5<d90jFGIho0xDYrO^D~n4~
zb3Id{I73_`Lcm(0gq&R*LmcCSU7bTb{rw<fEFkG9PLO?Ji8-aIQ9Q0bu3)P`w%lUL
z$t*6p#g$l6Qk0ogT9R6PizPd?vN%d0J+;IUCJ0I@Q9K|Q6c;2Wr-lZ3-eN5S8^)QF
zpPZQEmzbLx#SS(17T9lKA>NF{V&{y^oD`4&#Zf%Y{=NvC*`d5BUbyE$E{YO^bKQa*
z-Qnt^IAG$p*hBri{rtoIG+A!36sP8--C_ax?iMS^6UDb!K-5ZxA_)cthF=}dRxzQ)
zsYS&xsW~Z`MKS()sV+sCWvL3f3ZZ_UVXi^Jo*|CG3Z8y0{(i2(o{llWuD-6pA+A9R
zW-$Q)J~4?Vx;gpjnZ+fU*)gekWidXPNioHlC8@dviOJcC>8Zsr1(^l<@nxxbDfvbE
z86~+nra75O`XxoFspa6rU#y>!pQ~3;d5bSSwFDFlE~zDnnK{Lrp!BZ>$`y<}j3P`z
zj66&{j4X^oj9iRt5I!Tve->sQMjj?1Mh@mGNko3qLp2E{dx5eVC{Kg47bu^Bl3p-F
z5y(1C#wf0|%%b8FaFncMDiUE}U?>s=5umUF2Uw9L0|Ub?-t^QGH@Hd_kW)bhGcZ<3
zpgIGgh!j_F=cQJZ1ZO7YWagz8Nn^1e999T5>PQYi4+n%QQe41QkXV$O2aXS{4gdu}
z09=U{lKp4_fKcS8$$pC?J|2`w;^S{|#mDF7r<CTT#>d~{iH|QVP0WGF6iI>nD+3~A
zL4+KLKm<RS1&V_r4h9AW5H1E09E=>&9LyZdU{OC!E|B?Yr6r|Bsqyhepr|Qg2AKmY
zTyL>g<mTw5<mZA*mRk&vazxB8KQAaXxwNP_vn&-6hhXy{5f8Q*On|Jv#bE<+za1zw
O6@yZe2onzz4>JG-;<+yX

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree.cpython-39.pyc
deleted file mode 100644
index 46f1c0120b90088dcb6ea5059fe4074faf1dbb9c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3522
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
Khlz`sqZ9xPcaoR@

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/etree_lxml.cpython-39.pyc
deleted file mode 100644
index 01c44c8ed1b1fe27e01317fab78ef36d3185b050..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6659
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
E0Wz^#XaE2J

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/__pycache__/genshi.cpython-39.pyc
deleted file mode 100644
index bb93a33e4dc2f97d74c8b7c0d44ced264c332673..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1916
zcmYe~<>g{vU|^UdaWIvYlY!weh=Yt-7#J8F7#J9e`xqD)QW#Pga~N_NqZo6UqL^}-
zqnH^%VoW(KxvWvFU^a6OOD<a!TP}MPdoD*5M=oa+XD(M17g&xZhb5OgiaVDliYJ#h
ziZ_=piZ7Qxia%E%N`R3eg*AmOM=)0?N{Epmg*}BMM>tm`N+ee_N|ceoogsxYg{y@j
zg)3DkORSkWN-Tvtm_d{0CCH_k%(wUxlZx|mN=s7XGjj{_i%M>Bq-2(57H8(?-4ZCx
z%S_HsNsZ6REJ-a&%qiAnyu}*mmzbNX$$E=5IK(k1<QB85pUW-Y2w$IgKSy8J-~dNw
z*IVo^{>~wh0j{@LLR=$4G}&%(fYrwP1>a(G^>YEy+z=6G7sn9CTbv+42$Lzm^A@|a
zzpt;WU&u>F1_lOA##<~&iN&cenLr$-TRdg?nJKP0sky0nCB?V6@)C1XiwhEyQ;U;9
z{z1kd4dBq1VPIfLWr$)-VTfW%VN79aVTfW*VNPLbVTfW$VGU-`WV^)`Qk0q+o|u!J
zT9gd36=n`723Z*x7(j*>M}T9oma&E*i@}8<R-=}whB1Yql(9&!hG79?4Py<{LM9i6
zSgu;;8s;ztMutMA8m3ytLN2JP5QwT21~gS3DGb33nv8y$Ot)A{ic(W=v6bX!r{)!F
zvfN@RPR&WX#Zgd{T9%n#T6~K&wJbHS<Q6Mf!AgcASq27%U)|1DF`>n&Ma40xIVqV%
zG5&d}E=8GTsS3IZp?;oWu0g?`A&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QSF^ML+
zIr-_C#U+{9F{ycFF+Q0|F~ylBsk#M;$=QkNsl_n`nFadsWvO{7`9=B}CAm4KIhjfN
zAg7jtL#$XoJvFa5BU7)S@)k#YJSeTi$Mb^Hy$~oInOGRP7&#aP7&#c(m_c-vFe0?|
zVCs{ZL299xkAZ=K0~YKhj0_Alj4{l$%(X1FtToIf4B1RY`)XKXm}=Q-*=yLc7;8Cd
z*s_>vIWrk*xoX&57-9`#m}<Fec}kdTxJy`?nTmpHcxt$6xU-mQxU(43m~0pd^*|yi
z3^m+P9%l(_3Zo>*<TW)MC2VC3MQdsp7O>ZF)^OBt)iCie6wIn&N@0>@DB;Lv2D6zZ
z8EV+FnHREvqnx*f7aZmD@&sxa7H~rJEd(cnyiGOCB^=pIMc-;zz;0y$xwQsnBXjXH
zu#JpGUuqZ@aDj9#WCEF$S5?DY!kx`Dfw73MhG79u4a-7Cuy|4pa|th4+^B|O0Ut=*
zg&~%w7V3rxjD<>hb~Vf;{9rX+H4Iq-H7tD$V7+QJ%q4;){3Svq!X+Xlq9tN!>}3oS
z7>iQ!cxo6Hh}SSf>;NZ87Qb68py)0F<%l9dQ2vuBVq;)nxW$>1pPZNj%6qpsK_oZ_
z-r~wE&de(=Nz6-5EdphlB2fkgh9VIL28Jk()ZBuS%8<nLB6cvhxFoTtBqTBY7F%jw
z3P@N0WGs7fel93q7lDe^TP!816(vQSV2PCc<dVvQ)FM!#DB=bg%L5`niL3~eSc>?;
z%1ZOH^YY8{H2I1oLDJG7L6*GKijrF_*_nAMw^&jVOA>D}#@}KtNlcGoPb?`Z%1kQ0
z#RBp}krK#dg30-LWvN9asVVU=S;p*JjAccjLIj-OAcP#qd<g~y29O=aE}(P^PUReo
zY>aG-EQ~yiT#Q0Yd`u!Bnvv@t2QwFw5EDdJgi(Nri;)k68F@e?6Bi@fe-0)l<|;v?
zoB__{#eSNspiBjFVSM~8uK4)e{FKt1)cE*YJn`{`rI1*Nk1vvkISArDP{{ycfn6%b
zz`y_sv0_kx#=*$JR|FFA(-a4pm{wX+T9g_eUj!;Ki$M9X2&62E8=9??^NXMn3W|Ji
z3_>CT6gS|w!Wkt+;CN*y0u=<eIFs|i$)ltgoG2j41LO{fLs6Z4i^B%uQ#(-VD+W1U
Qgo%eyhEaiuhe?1L0EdsyrvLx|

diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py
deleted file mode 100644
index 80c474c4..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/base.py
+++ /dev/null
@@ -1,252 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from xml.dom import Node
-from ..constants import namespaces, voidElements, spaceCharacters
-
-__all__ = ["DOCUMENT", "DOCTYPE", "TEXT", "ELEMENT", "COMMENT", "ENTITY", "UNKNOWN",
-           "TreeWalker", "NonRecursiveTreeWalker"]
-
-DOCUMENT = Node.DOCUMENT_NODE
-DOCTYPE = Node.DOCUMENT_TYPE_NODE
-TEXT = Node.TEXT_NODE
-ELEMENT = Node.ELEMENT_NODE
-COMMENT = Node.COMMENT_NODE
-ENTITY = Node.ENTITY_NODE
-UNKNOWN = "<#UNKNOWN#>"
-
-spaceCharacters = "".join(spaceCharacters)
-
-
-class TreeWalker(object):
-    """Walks a tree yielding tokens
-
-    Tokens are dicts that all have a ``type`` field specifying the type of the
-    token.
-
-    """
-    def __init__(self, tree):
-        """Creates a TreeWalker
-
-        :arg tree: the tree to walk
-
-        """
-        self.tree = tree
-
-    def __iter__(self):
-        raise NotImplementedError
-
-    def error(self, msg):
-        """Generates an error token with the given message
-
-        :arg msg: the error message
-
-        :returns: SerializeError token
-
-        """
-        return {"type": "SerializeError", "data": msg}
-
-    def emptyTag(self, namespace, name, attrs, hasChildren=False):
-        """Generates an EmptyTag token
-
-        :arg namespace: the namespace of the token--can be ``None``
-
-        :arg name: the name of the element
-
-        :arg attrs: the attributes of the element as a dict
-
-        :arg hasChildren: whether or not to yield a SerializationError because
-            this tag shouldn't have children
-
-        :returns: EmptyTag token
-
-        """
-        yield {"type": "EmptyTag", "name": name,
-               "namespace": namespace,
-               "data": attrs}
-        if hasChildren:
-            yield self.error("Void element has children")
-
-    def startTag(self, namespace, name, attrs):
-        """Generates a StartTag token
-
-        :arg namespace: the namespace of the token--can be ``None``
-
-        :arg name: the name of the element
-
-        :arg attrs: the attributes of the element as a dict
-
-        :returns: StartTag token
-
-        """
-        return {"type": "StartTag",
-                "name": name,
-                "namespace": namespace,
-                "data": attrs}
-
-    def endTag(self, namespace, name):
-        """Generates an EndTag token
-
-        :arg namespace: the namespace of the token--can be ``None``
-
-        :arg name: the name of the element
-
-        :returns: EndTag token
-
-        """
-        return {"type": "EndTag",
-                "name": name,
-                "namespace": namespace}
-
-    def text(self, data):
-        """Generates SpaceCharacters and Characters tokens
-
-        Depending on what's in the data, this generates one or more
-        ``SpaceCharacters`` and ``Characters`` tokens.
-
-        For example:
-
-            >>> from html5lib.treewalkers.base import TreeWalker
-            >>> # Give it an empty tree just so it instantiates
-            >>> walker = TreeWalker([])
-            >>> list(walker.text(''))
-            []
-            >>> list(walker.text('  '))
-            [{u'data': '  ', u'type': u'SpaceCharacters'}]
-            >>> list(walker.text(' abc '))  # doctest: +NORMALIZE_WHITESPACE
-            [{u'data': ' ', u'type': u'SpaceCharacters'},
-            {u'data': u'abc', u'type': u'Characters'},
-            {u'data': u' ', u'type': u'SpaceCharacters'}]
-
-        :arg data: the text data
-
-        :returns: one or more ``SpaceCharacters`` and ``Characters`` tokens
-
-        """
-        data = data
-        middle = data.lstrip(spaceCharacters)
-        left = data[:len(data) - len(middle)]
-        if left:
-            yield {"type": "SpaceCharacters", "data": left}
-        data = middle
-        middle = data.rstrip(spaceCharacters)
-        right = data[len(middle):]
-        if middle:
-            yield {"type": "Characters", "data": middle}
-        if right:
-            yield {"type": "SpaceCharacters", "data": right}
-
-    def comment(self, data):
-        """Generates a Comment token
-
-        :arg data: the comment
-
-        :returns: Comment token
-
-        """
-        return {"type": "Comment", "data": data}
-
-    def doctype(self, name, publicId=None, systemId=None):
-        """Generates a Doctype token
-
-        :arg name:
-
-        :arg publicId:
-
-        :arg systemId:
-
-        :returns: the Doctype token
-
-        """
-        return {"type": "Doctype",
-                "name": name,
-                "publicId": publicId,
-                "systemId": systemId}
-
-    def entity(self, name):
-        """Generates an Entity token
-
-        :arg name: the entity name
-
-        :returns: an Entity token
-
-        """
-        return {"type": "Entity", "name": name}
-
-    def unknown(self, nodeType):
-        """Handles unknown node types"""
-        return self.error("Unknown node type: " + nodeType)
-
-
-class NonRecursiveTreeWalker(TreeWalker):
-    def getNodeDetails(self, node):
-        raise NotImplementedError
-
-    def getFirstChild(self, node):
-        raise NotImplementedError
-
-    def getNextSibling(self, node):
-        raise NotImplementedError
-
-    def getParentNode(self, node):
-        raise NotImplementedError
-
-    def __iter__(self):
-        currentNode = self.tree
-        while currentNode is not None:
-            details = self.getNodeDetails(currentNode)
-            type, details = details[0], details[1:]
-            hasChildren = False
-
-            if type == DOCTYPE:
-                yield self.doctype(*details)
-
-            elif type == TEXT:
-                for token in self.text(*details):
-                    yield token
-
-            elif type == ELEMENT:
-                namespace, name, attributes, hasChildren = details
-                if (not namespace or namespace == namespaces["html"]) and name in voidElements:
-                    for token in self.emptyTag(namespace, name, attributes,
-                                               hasChildren):
-                        yield token
-                    hasChildren = False
-                else:
-                    yield self.startTag(namespace, name, attributes)
-
-            elif type == COMMENT:
-                yield self.comment(details[0])
-
-            elif type == ENTITY:
-                yield self.entity(details[0])
-
-            elif type == DOCUMENT:
-                hasChildren = True
-
-            else:
-                yield self.unknown(details[0])
-
-            if hasChildren:
-                firstChild = self.getFirstChild(currentNode)
-            else:
-                firstChild = None
-
-            if firstChild is not None:
-                currentNode = firstChild
-            else:
-                while currentNode is not None:
-                    details = self.getNodeDetails(currentNode)
-                    type, details = details[0], details[1:]
-                    if type == ELEMENT:
-                        namespace, name, attributes, hasChildren = details
-                        if (namespace and namespace != namespaces["html"]) or name not in voidElements:
-                            yield self.endTag(namespace, name)
-                    if self.tree is currentNode:
-                        currentNode = None
-                        break
-                    nextSibling = self.getNextSibling(currentNode)
-                    if nextSibling is not None:
-                        currentNode = nextSibling
-                        break
-                    else:
-                        currentNode = self.getParentNode(currentNode)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py
deleted file mode 100644
index b0c89b00..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/dom.py
+++ /dev/null
@@ -1,43 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from xml.dom import Node
-
-from . import base
-
-
-class TreeWalker(base.NonRecursiveTreeWalker):
-    def getNodeDetails(self, node):
-        if node.nodeType == Node.DOCUMENT_TYPE_NODE:
-            return base.DOCTYPE, node.name, node.publicId, node.systemId
-
-        elif node.nodeType in (Node.TEXT_NODE, Node.CDATA_SECTION_NODE):
-            return base.TEXT, node.nodeValue
-
-        elif node.nodeType == Node.ELEMENT_NODE:
-            attrs = {}
-            for attr in list(node.attributes.keys()):
-                attr = node.getAttributeNode(attr)
-                if attr.namespaceURI:
-                    attrs[(attr.namespaceURI, attr.localName)] = attr.value
-                else:
-                    attrs[(None, attr.name)] = attr.value
-            return (base.ELEMENT, node.namespaceURI, node.nodeName,
-                    attrs, node.hasChildNodes())
-
-        elif node.nodeType == Node.COMMENT_NODE:
-            return base.COMMENT, node.nodeValue
-
-        elif node.nodeType in (Node.DOCUMENT_NODE, Node.DOCUMENT_FRAGMENT_NODE):
-            return (base.DOCUMENT,)
-
-        else:
-            return base.UNKNOWN, node.nodeType
-
-    def getFirstChild(self, node):
-        return node.firstChild
-
-    def getNextSibling(self, node):
-        return node.nextSibling
-
-    def getParentNode(self, node):
-        return node.parentNode
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py
deleted file mode 100644
index 837b27ec..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree.py
+++ /dev/null
@@ -1,131 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from collections import OrderedDict
-import re
-
-from pip._vendor.six import string_types
-
-from . import base
-from .._utils import moduleFactoryFactory
-
-tag_regexp = re.compile("{([^}]*)}(.*)")
-
-
-def getETreeBuilder(ElementTreeImplementation):
-    ElementTree = ElementTreeImplementation
-    ElementTreeCommentType = ElementTree.Comment("asd").tag
-
-    class TreeWalker(base.NonRecursiveTreeWalker):  # pylint:disable=unused-variable
-        """Given the particular ElementTree representation, this implementation,
-        to avoid using recursion, returns "nodes" as tuples with the following
-        content:
-
-        1. The current element
-
-        2. The index of the element relative to its parent
-
-        3. A stack of ancestor elements
-
-        4. A flag "text", "tail" or None to indicate if the current node is a
-           text node; either the text or tail of the current element (1)
-        """
-        def getNodeDetails(self, node):
-            if isinstance(node, tuple):  # It might be the root Element
-                elt, _, _, flag = node
-                if flag in ("text", "tail"):
-                    return base.TEXT, getattr(elt, flag)
-                else:
-                    node = elt
-
-            if not(hasattr(node, "tag")):
-                node = node.getroot()
-
-            if node.tag in ("DOCUMENT_ROOT", "DOCUMENT_FRAGMENT"):
-                return (base.DOCUMENT,)
-
-            elif node.tag == "<!DOCTYPE>":
-                return (base.DOCTYPE, node.text,
-                        node.get("publicId"), node.get("systemId"))
-
-            elif node.tag == ElementTreeCommentType:
-                return base.COMMENT, node.text
-
-            else:
-                assert isinstance(node.tag, string_types), type(node.tag)
-                # This is assumed to be an ordinary element
-                match = tag_regexp.match(node.tag)
-                if match:
-                    namespace, tag = match.groups()
-                else:
-                    namespace = None
-                    tag = node.tag
-                attrs = OrderedDict()
-                for name, value in list(node.attrib.items()):
-                    match = tag_regexp.match(name)
-                    if match:
-                        attrs[(match.group(1), match.group(2))] = value
-                    else:
-                        attrs[(None, name)] = value
-                return (base.ELEMENT, namespace, tag,
-                        attrs, len(node) or node.text)
-
-        def getFirstChild(self, node):
-            if isinstance(node, tuple):
-                element, key, parents, flag = node
-            else:
-                element, key, parents, flag = node, None, [], None
-
-            if flag in ("text", "tail"):
-                return None
-            else:
-                if element.text:
-                    return element, key, parents, "text"
-                elif len(element):
-                    parents.append(element)
-                    return element[0], 0, parents, None
-                else:
-                    return None
-
-        def getNextSibling(self, node):
-            if isinstance(node, tuple):
-                element, key, parents, flag = node
-            else:
-                return None
-
-            if flag == "text":
-                if len(element):
-                    parents.append(element)
-                    return element[0], 0, parents, None
-                else:
-                    return None
-            else:
-                if element.tail and flag != "tail":
-                    return element, key, parents, "tail"
-                elif key < len(parents[-1]) - 1:
-                    return parents[-1][key + 1], key + 1, parents, None
-                else:
-                    return None
-
-        def getParentNode(self, node):
-            if isinstance(node, tuple):
-                element, key, parents, flag = node
-            else:
-                return None
-
-            if flag == "text":
-                if not parents:
-                    return element
-                else:
-                    return element, key, parents, None
-            else:
-                parent = parents.pop()
-                if not parents:
-                    return parent
-                else:
-                    assert list(parents[-1]).count(parent) == 1
-                    return parent, list(parents[-1]).index(parent), parents, None
-
-    return locals()
-
-
-getETreeModule = moduleFactoryFactory(getETreeBuilder)
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py
deleted file mode 100644
index c56af390..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/etree_lxml.py
+++ /dev/null
@@ -1,215 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-from pip._vendor.six import text_type
-
-from collections import OrderedDict
-
-from lxml import etree
-from ..treebuilders.etree import tag_regexp
-
-from . import base
-
-from .. import _ihatexml
-
-
-def ensure_str(s):
-    if s is None:
-        return None
-    elif isinstance(s, text_type):
-        return s
-    else:
-        return s.decode("ascii", "strict")
-
-
-class Root(object):
-    def __init__(self, et):
-        self.elementtree = et
-        self.children = []
-
-        try:
-            if et.docinfo.internalDTD:
-                self.children.append(Doctype(self,
-                                             ensure_str(et.docinfo.root_name),
-                                             ensure_str(et.docinfo.public_id),
-                                             ensure_str(et.docinfo.system_url)))
-        except AttributeError:
-            pass
-
-        try:
-            node = et.getroot()
-        except AttributeError:
-            node = et
-
-        while node.getprevious() is not None:
-            node = node.getprevious()
-        while node is not None:
-            self.children.append(node)
-            node = node.getnext()
-
-        self.text = None
-        self.tail = None
-
-    def __getitem__(self, key):
-        return self.children[key]
-
-    def getnext(self):
-        return None
-
-    def __len__(self):
-        return 1
-
-
-class Doctype(object):
-    def __init__(self, root_node, name, public_id, system_id):
-        self.root_node = root_node
-        self.name = name
-        self.public_id = public_id
-        self.system_id = system_id
-
-        self.text = None
-        self.tail = None
-
-    def getnext(self):
-        return self.root_node.children[1]
-
-
-class FragmentRoot(Root):
-    def __init__(self, children):
-        self.children = [FragmentWrapper(self, child) for child in children]
-        self.text = self.tail = None
-
-    def getnext(self):
-        return None
-
-
-class FragmentWrapper(object):
-    def __init__(self, fragment_root, obj):
-        self.root_node = fragment_root
-        self.obj = obj
-        if hasattr(self.obj, 'text'):
-            self.text = ensure_str(self.obj.text)
-        else:
-            self.text = None
-        if hasattr(self.obj, 'tail'):
-            self.tail = ensure_str(self.obj.tail)
-        else:
-            self.tail = None
-
-    def __getattr__(self, name):
-        return getattr(self.obj, name)
-
-    def getnext(self):
-        siblings = self.root_node.children
-        idx = siblings.index(self)
-        if idx < len(siblings) - 1:
-            return siblings[idx + 1]
-        else:
-            return None
-
-    def __getitem__(self, key):
-        return self.obj[key]
-
-    def __bool__(self):
-        return bool(self.obj)
-
-    def getparent(self):
-        return None
-
-    def __str__(self):
-        return str(self.obj)
-
-    def __unicode__(self):
-        return str(self.obj)
-
-    def __len__(self):
-        return len(self.obj)
-
-
-class TreeWalker(base.NonRecursiveTreeWalker):
-    def __init__(self, tree):
-        # pylint:disable=redefined-variable-type
-        if isinstance(tree, list):
-            self.fragmentChildren = set(tree)
-            tree = FragmentRoot(tree)
-        else:
-            self.fragmentChildren = set()
-            tree = Root(tree)
-        base.NonRecursiveTreeWalker.__init__(self, tree)
-        self.filter = _ihatexml.InfosetFilter()
-
-    def getNodeDetails(self, node):
-        if isinstance(node, tuple):  # Text node
-            node, key = node
-            assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key
-            return base.TEXT, ensure_str(getattr(node, key))
-
-        elif isinstance(node, Root):
-            return (base.DOCUMENT,)
-
-        elif isinstance(node, Doctype):
-            return base.DOCTYPE, node.name, node.public_id, node.system_id
-
-        elif isinstance(node, FragmentWrapper) and not hasattr(node, "tag"):
-            return base.TEXT, ensure_str(node.obj)
-
-        elif node.tag == etree.Comment:
-            return base.COMMENT, ensure_str(node.text)
-
-        elif node.tag == etree.Entity:
-            return base.ENTITY, ensure_str(node.text)[1:-1]  # strip &;
-
-        else:
-            # This is assumed to be an ordinary element
-            match = tag_regexp.match(ensure_str(node.tag))
-            if match:
-                namespace, tag = match.groups()
-            else:
-                namespace = None
-                tag = ensure_str(node.tag)
-            attrs = OrderedDict()
-            for name, value in list(node.attrib.items()):
-                name = ensure_str(name)
-                value = ensure_str(value)
-                match = tag_regexp.match(name)
-                if match:
-                    attrs[(match.group(1), match.group(2))] = value
-                else:
-                    attrs[(None, name)] = value
-            return (base.ELEMENT, namespace, self.filter.fromXmlName(tag),
-                    attrs, len(node) > 0 or node.text)
-
-    def getFirstChild(self, node):
-        assert not isinstance(node, tuple), "Text nodes have no children"
-
-        assert len(node) or node.text, "Node has no children"
-        if node.text:
-            return (node, "text")
-        else:
-            return node[0]
-
-    def getNextSibling(self, node):
-        if isinstance(node, tuple):  # Text node
-            node, key = node
-            assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key
-            if key == "text":
-                # XXX: we cannot use a "bool(node) and node[0] or None" construct here
-                # because node[0] might evaluate to False if it has no child element
-                if len(node):
-                    return node[0]
-                else:
-                    return None
-            else:  # tail
-                return node.getnext()
-
-        return (node, "tail") if node.tail else node.getnext()
-
-    def getParentNode(self, node):
-        if isinstance(node, tuple):  # Text node
-            node, key = node
-            assert key in ("text", "tail"), "Text nodes are text or tail, found %s" % key
-            if key == "text":
-                return node
-            # else: fallback to "normal" processing
-        elif node in self.fragmentChildren:
-            return None
-
-        return node.getparent()
diff --git a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py b/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py
deleted file mode 100644
index 7483be27..00000000
--- a/env/Lib/site-packages/pip/_vendor/html5lib/treewalkers/genshi.py
+++ /dev/null
@@ -1,69 +0,0 @@
-from __future__ import absolute_import, division, unicode_literals
-
-from genshi.core import QName
-from genshi.core import START, END, XML_NAMESPACE, DOCTYPE, TEXT
-from genshi.core import START_NS, END_NS, START_CDATA, END_CDATA, PI, COMMENT
-
-from . import base
-
-from ..constants import voidElements, namespaces
-
-
-class TreeWalker(base.TreeWalker):
-    def __iter__(self):
-        # Buffer the events so we can pass in the following one
-        previous = None
-        for event in self.tree:
-            if previous is not None:
-                for token in self.tokens(previous, event):
-                    yield token
-            previous = event
-
-        # Don't forget the final event!
-        if previous is not None:
-            for token in self.tokens(previous, None):
-                yield token
-
-    def tokens(self, event, next):
-        kind, data, _ = event
-        if kind == START:
-            tag, attribs = data
-            name = tag.localname
-            namespace = tag.namespace
-            converted_attribs = {}
-            for k, v in attribs:
-                if isinstance(k, QName):
-                    converted_attribs[(k.namespace, k.localname)] = v
-                else:
-                    converted_attribs[(None, k)] = v
-
-            if namespace == namespaces["html"] and name in voidElements:
-                for token in self.emptyTag(namespace, name, converted_attribs,
-                                           not next or next[0] != END or
-                                           next[1] != tag):
-                    yield token
-            else:
-                yield self.startTag(namespace, name, converted_attribs)
-
-        elif kind == END:
-            name = data.localname
-            namespace = data.namespace
-            if namespace != namespaces["html"] or name not in voidElements:
-                yield self.endTag(namespace, name)
-
-        elif kind == COMMENT:
-            yield self.comment(data)
-
-        elif kind == TEXT:
-            for token in self.text(data):
-                yield token
-
-        elif kind == DOCTYPE:
-            yield self.doctype(*data)
-
-        elif kind in (XML_NAMESPACE, DOCTYPE, START_NS, END_NS,
-                      START_CDATA, END_CDATA, PI):
-            pass
-
-        else:
-            yield self.unknown(kind)
diff --git a/env/Lib/site-packages/pip/_vendor/idna/__init__.py b/env/Lib/site-packages/pip/_vendor/idna/__init__.py
index 847bf935..a40eeafc 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/__init__.py
@@ -1,2 +1,44 @@
 from .package_data import __version__
-from .core import *
+from .core import (
+    IDNABidiError,
+    IDNAError,
+    InvalidCodepoint,
+    InvalidCodepointContext,
+    alabel,
+    check_bidi,
+    check_hyphen_ok,
+    check_initial_combiner,
+    check_label,
+    check_nfc,
+    decode,
+    encode,
+    ulabel,
+    uts46_remap,
+    valid_contextj,
+    valid_contexto,
+    valid_label_length,
+    valid_string_length,
+)
+from .intranges import intranges_contain
+
+__all__ = [
+    "IDNABidiError",
+    "IDNAError",
+    "InvalidCodepoint",
+    "InvalidCodepointContext",
+    "alabel",
+    "check_bidi",
+    "check_hyphen_ok",
+    "check_initial_combiner",
+    "check_label",
+    "check_nfc",
+    "decode",
+    "encode",
+    "intranges_contain",
+    "ulabel",
+    "uts46_remap",
+    "valid_contextj",
+    "valid_contexto",
+    "valid_label_length",
+    "valid_string_length",
+]
diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 9153748e3386dc6e8428f5c6eeee01482af68441..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 285
zcmYe~<>g{vU|^UdaWK`2fq~&Mh=Yuo7#J8F7#J9eB^VeOQW#Pga~N_NqZk=MY^EHh
z5QY@yU<OT=my8Sy44RC$xZ~r?Qj3Z+^Yh~4H5qR)YWZn0-{L7qOwLYBPmNDWEJ-W^
znRtsOIlm}%B|{M#0|SKkRqJdO6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq
z;ux&p>F46_=Njzk7!&O3>lz&58l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0n
zstdKeIHn-8KtH}LH7_N<NIx?rFHt`}J~J<~BtBlRpz;=nO>TZlX-=vg$RoudH}Wt7
E0MNor%K!iX

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/codec.cpython-39.pyc
deleted file mode 100644
index 8842b410416ab5da9865a9fe1ff35997e2fb9a68..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2819
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
E082_zmjD0&

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index aa878326e9d1859aea85e744013129b15ff77d1d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 657
zcmYe~<>g{vU|^UdaWM4-0|Ucj5C<7EF)%PVFfcF_>o71dq%fo~<}idnXvPqR6s8pB
z7KSLM6qXd$7KSM16t)!h7KSL66pmm9P0p8$3=9mKjJFuIl0ht(sUSAURA-Q>91IK$
zB@8tT&5XeeD;fPX8E>(r<|XH+q^@MV#hR0tl$x`Wp@^M<f#FxRvsFxJacWU<OlnR_
zW>JiPUaCt`W?8C&u0p7vXP9eHuxE&4u!5(bi@%?1u%}~8u&b|YaENP=f>}&JfKN=K
ziEd7QdS-D+W_C<!URjJ!W>QRXW=X1UL1J=tVtQ(EOhIOWetcPKUP^wEer8HuqJDCI
zZb4#+UP0w8_K<wXU}sNH7Lc1kj%Q#j;$&c8AkJe&%#eU!OGyQJt%#L@0pcmJ&x$}{
zaEmh}KQu2BBn|RyG1Lxjyms(_122WKnX!p6g&~+hlgY12$J52nQNhT-z(OG<KebpP
zFTX^gv?Mbpvp7{DFEKZ@peVIKp`a+gBtJPnN0afEuwQ<OXKq1GYHn&?NotB~QBi&o
zD9(x@ZUZ?6;y@0VZcuuGxsQ*5fx%Cc^%hHVeo^WzR*>_P!2weQa(NL*8p#|a!)$W%
XQ%ZAE?Ldj47!&{;j2uiH%pA-B)S8X#

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/core.cpython-39.pyc
deleted file mode 100644
index 92702b5b1057f0b3f71546eef5f22b964953fee6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9113
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
bbJ=jPb8vF7ap-Vqawu>}a!7K?aLEGzq_{*P

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/idnadata.cpython-39.pyc
deleted file mode 100644
index 50dcaa5a94151ca7e0d72d83f83aff1d52423aa6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 22166
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
F764rPD<J>?

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/intranges.cpython-39.pyc
deleted file mode 100644
index 3378c2c3ec717fcdb9763c7d652400034fdcafed..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1837
zcmYe~<>g{vU|^UdaWM5N8w0~*5C<7EF)%PVFfcF_8!#|1q%cG=q%fv1<uFDurZA_l
zv@k?5rLd;3wJ=06r?97Rv@k@mq;RHiwJ=1nrZ5FFXmTfVGBPl5xo4K8<|!m9<YX3?
zDCDOpWagEmrl%Ga>nP+VrlcyA7JvjbGV%*j(@Jx4Dm4`n6^e5cb8-~&N^_G^i$JnD
z`FZIIMWuPgT={7V$@zK3smY}!nPsU+W+mt67L=BxDkLftr4|&W7N_QwB$j06=Yh1B
zWTYyj<rn30X=oIeBo>tz>L{e<r5I}JC_wl|V7`&2f}Wn9rk+Ab2FSg6#pS6*3Lve8
zrK!bWqm;@MixnyqpvH4$=7FX2i!#$Q^AdBw9<*0d010R2rYiVr<m9JoD1+Utsj0{H
z5)`t2$&4ThirE+#7}yyY7@R?2+`+)WP{L5d(9BrNn9fkkl)_lcT*6qwRKwWJ*v#m{
z5SvuXQp1wMB+dX4%VsF@s$r~Qkz@doAaO~C6ebCVY^EZwLYW%I8fK6fL`N%=BttE0
z4buYV5|$d)6lO_=8rBp>ka}^3W~POVj0`m_wakSwC9E|}&5Xeenk<RZj0_Axu%N^e
zeF}-ipqNT6EKSWzP6Y*XQDR<tYOxiUf`WnqG^FDVz(E^t01xYUNZ`kVLLU^|Its<5
z$r%bI8Hpt*p$RqxmQ)lHi&7O*D-x4Saw-){GV+U46)KSQfg?3OQ^Ceop+dn16u0r2
zpa@qe&d*I%$kgKk8x{n19>l1;<ouM>6p$B+GxO4O5D5vIA{1<F6pW1&YCvXb>L}#p
zmw?oklosTq7VCjcd-?zW|Nk#Rky!*HG}&&k73UX~q^8_r1&6~e=A6{LTWpC11*v%{
zw|L`I!B)mY<XFKbX|mm71!ao(Tig(>@gUwUHn5uFTU<Gb#U=6OMVTe3w-_^T@g|oR
z6{Y5tK#W+)P$a;>!0@Zi*(xTqIJKxaCN(D|vna+tFV&?8lrwY{Lj63$T!Vr=LmYz@
zJpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgsUw
zld}`kQ;TB?G7I$M%Tn`F@{9B{Q}Pn^GxJIyF4QZiyd@0h#iteJ=Yo9zDpQKZKuMf~
zgOP=ig;9V}fKh^xiBW`6hLMe_NQi-fAsJM(fRunRhz-KvY{0|7z)-`G!f3}(!|22i
z%%I8S_fmm@0pedxrdzDw*uKS_nwJ6&0tg`pQo+H%z#tFGN+81+7>huBl>7#YDP~xH
z1BD;RB72Z^Ob!fbpfZcuuSl4IfguN^>VN(JdS<A-jJFtzAU1)t6@jd~#T%cJ3Q9+i
z7*Rs9SRCDlpiIsJv$zVH(Nh?knQECz7#A?rFxD_FWU6JZVNPMpW-0P3VTNR12?j}q
zX2uw%T9#VY8kQOc76xX9Y{nwD8rE!vBELKqMut3=6y{)t8c?=oY-Y@6C@O>Kh3jJj
z>C0v+Dg&uYVF_l?WUaDwNi9h&%FWD6Rme<JNXX19iBC{SOU%hB1{J9J3i)~9{0u7l
zATbRp(-I)e1U+ziF9HQnh?^!WIFN6#C1n<;CYRjehS2djsc9uepin3R6>*yEw^%@y
z6oKOQ78^M6$KPTu$S=Od0#bR4wJ0+^qvRH2JbDldB9d2feqKppW}X@-n8AsQiHnhk
znS)V;QG$_$iHA{u5tP`9KuJZD?G}4{d`f<De0-4vC}Dt79N3`{H-Xe3*@TEu4x8Nk
Zl+v73J5WL?2Bl*bb`B;EQ4VGf7693E+>8JK

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/package_data.cpython-39.pyc
deleted file mode 100644
index 4136077de8dc3d40cfbeca722e5029a3bfb8080a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 239
zcmYe~<>g{vU|^UdaWGYsfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}WHjr9!u
zG#PJk$H$kY78Pga=f%gbWGG@{V1N+68lA0TLW@(2iepl9QZkET{PR*>iZaVm6?7Fs
z{XD~5gMvLn9D@}+{apP0T!TFwV}f0MU4uhhgA~kS0s?$u5>0e-^3yYmOER-#QuE4U
zd@_?_iZe@6bqf-cvlG)(i(?8h3-sg5Qu9*si}W*7@)Gr-GVv*iC5d_kmA5!-a`RJ4
Nb5iX<p7;#%6#xLCLFxbi

diff --git a/env/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/idna/__pycache__/uts46data.cpython-39.pyc
deleted file mode 100644
index 59e3992c8093fb82c859a5e4cae20fd07c8563ea..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 146174
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
S$(Lm_lOM|_CV!TVO#cBG3F3+X

diff --git a/env/Lib/site-packages/pip/_vendor/idna/codec.py b/env/Lib/site-packages/pip/_vendor/idna/codec.py
index 30fe72fb..1ca9ba62 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/codec.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/codec.py
@@ -1,23 +1,22 @@
 from .core import encode, decode, alabel, ulabel, IDNAError
 import codecs
 import re
+from typing import Tuple, Optional
 
 _unicode_dots_re = re.compile('[\u002e\u3002\uff0e\uff61]')
 
 class Codec(codecs.Codec):
 
-    def encode(self, data, errors='strict'):
-
+    def encode(self, data: str, errors: str = 'strict') -> Tuple[bytes, int]:
         if errors != 'strict':
             raise IDNAError('Unsupported error handling \"{}\"'.format(errors))
 
         if not data:
-            return "", 0
+            return b"", 0
 
         return encode(data), len(data)
 
-    def decode(self, data, errors='strict'):
-
+    def decode(self, data: bytes, errors: str = 'strict') -> Tuple[str, int]:
         if errors != 'strict':
             raise IDNAError('Unsupported error handling \"{}\"'.format(errors))
 
@@ -27,12 +26,12 @@ class Codec(codecs.Codec):
         return decode(data), len(data)
 
 class IncrementalEncoder(codecs.BufferedIncrementalEncoder):
-    def _buffer_encode(self, data, errors, final):
+    def _buffer_encode(self, data: str, errors: str, final: bool) -> Tuple[str, int]:  # type: ignore
         if errors != 'strict':
             raise IDNAError('Unsupported error handling \"{}\"'.format(errors))
 
         if not data:
-            return ('', 0)
+            return "", 0
 
         labels = _unicode_dots_re.split(data)
         trailing_dot = ''
@@ -55,12 +54,12 @@ class IncrementalEncoder(codecs.BufferedIncrementalEncoder):
             size += len(label)
 
         # Join with U+002E
-        result = '.'.join(result) + trailing_dot
+        result_str = '.'.join(result) + trailing_dot  # type: ignore
         size += len(trailing_dot)
-        return (result, size)
+        return result_str, size
 
 class IncrementalDecoder(codecs.BufferedIncrementalDecoder):
-    def _buffer_decode(self, data, errors, final):
+    def _buffer_decode(self, data: str, errors: str, final: bool) -> Tuple[str, int]:  # type: ignore
         if errors != 'strict':
             raise IDNAError('Unsupported error handling \"{}\"'.format(errors))
 
@@ -87,22 +86,25 @@ class IncrementalDecoder(codecs.BufferedIncrementalDecoder):
                 size += 1
             size += len(label)
 
-        result = '.'.join(result) + trailing_dot
+        result_str = '.'.join(result) + trailing_dot
         size += len(trailing_dot)
-        return (result, size)
+        return (result_str, size)
 
 
 class StreamWriter(Codec, codecs.StreamWriter):
     pass
 
+
 class StreamReader(Codec, codecs.StreamReader):
     pass
 
-def getregentry():
+
+def getregentry() -> codecs.CodecInfo:
+    # Compatibility as a search_function for codecs.register()
     return codecs.CodecInfo(
         name='idna',
-        encode=Codec().encode,
-        decode=Codec().decode,
+        encode=Codec().encode,  # type: ignore
+        decode=Codec().decode,  # type: ignore
         incrementalencoder=IncrementalEncoder,
         incrementaldecoder=IncrementalDecoder,
         streamwriter=StreamWriter,
diff --git a/env/Lib/site-packages/pip/_vendor/idna/compat.py b/env/Lib/site-packages/pip/_vendor/idna/compat.py
index 2e622d6f..786e6bda 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/compat.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/compat.py
@@ -1,12 +1,13 @@
 from .core import *
 from .codec import *
+from typing import Any, Union
 
-def ToASCII(label):
+def ToASCII(label: str) -> bytes:
     return encode(label)
 
-def ToUnicode(label):
+def ToUnicode(label: Union[bytes, bytearray]) -> str:
     return decode(label)
 
-def nameprep(s):
+def nameprep(s: Any) -> None:
     raise NotImplementedError('IDNA 2008 does not utilise nameprep protocol')
 
diff --git a/env/Lib/site-packages/pip/_vendor/idna/core.py b/env/Lib/site-packages/pip/_vendor/idna/core.py
index 2c193d63..4f300371 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/core.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/core.py
@@ -2,7 +2,7 @@ from . import idnadata
 import bisect
 import unicodedata
 import re
-import sys
+from typing import Union, Optional
 from .intranges import intranges_contain
 
 _virama_combining_class = 9
@@ -29,39 +29,36 @@ class InvalidCodepointContext(IDNAError):
     pass
 
 
-def _combining_class(cp):
+def _combining_class(cp: int) -> int:
     v = unicodedata.combining(chr(cp))
     if v == 0:
         if not unicodedata.name(chr(cp)):
             raise ValueError('Unknown character in unicodedata')
     return v
 
-def _is_script(cp, script):
+def _is_script(cp: str, script: str) -> bool:
     return intranges_contain(ord(cp), idnadata.scripts[script])
 
-def _punycode(s):
+def _punycode(s: str) -> bytes:
     return s.encode('punycode')
 
-def _unot(s):
+def _unot(s: int) -> str:
     return 'U+{:04X}'.format(s)
 
 
-def valid_label_length(label):
-
+def valid_label_length(label: Union[bytes, str]) -> bool:
     if len(label) > 63:
         return False
     return True
 
 
-def valid_string_length(label, trailing_dot):
-
+def valid_string_length(label: Union[bytes, str], trailing_dot: bool) -> bool:
     if len(label) > (254 if trailing_dot else 253):
         return False
     return True
 
 
-def check_bidi(label, check_ltr=False):
-
+def check_bidi(label: str, check_ltr: bool = False) -> bool:
     # Bidi rules should only be applied if string contains RTL characters
     bidi_label = False
     for (idx, cp) in enumerate(label, 1):
@@ -84,7 +81,7 @@ def check_bidi(label, check_ltr=False):
         raise IDNABidiError('First codepoint in label {} must be directionality L, R or AL'.format(repr(label)))
 
     valid_ending = False
-    number_type = False
+    number_type = None  # type: Optional[str]
     for (idx, cp) in enumerate(label, 1):
         direction = unicodedata.bidirectional(cp)
 
@@ -120,15 +117,13 @@ def check_bidi(label, check_ltr=False):
     return True
 
 
-def check_initial_combiner(label):
-
+def check_initial_combiner(label: str) -> bool:
     if unicodedata.category(label[0])[0] == 'M':
         raise IDNAError('Label begins with an illegal combining character')
     return True
 
 
-def check_hyphen_ok(label):
-
+def check_hyphen_ok(label: str) -> bool:
     if label[2:4] == '--':
         raise IDNAError('Label has disallowed hyphens in 3rd and 4th position')
     if label[0] == '-' or label[-1] == '-':
@@ -136,14 +131,12 @@ def check_hyphen_ok(label):
     return True
 
 
-def check_nfc(label):
-
+def check_nfc(label: str) -> None:
     if unicodedata.normalize('NFC', label) != label:
         raise IDNAError('Label must be in Normalization Form C')
 
 
-def valid_contextj(label, pos):
-
+def valid_contextj(label: str, pos: int) -> bool:
     cp_value = ord(label[pos])
 
     if cp_value == 0x200c:
@@ -186,8 +179,7 @@ def valid_contextj(label, pos):
         return False
 
 
-def valid_contexto(label, pos, exception=False):
-
+def valid_contexto(label: str, pos: int, exception: bool = False) -> bool:
     cp_value = ord(label[pos])
 
     if cp_value == 0x00b7:
@@ -226,9 +218,10 @@ def valid_contexto(label, pos, exception=False):
                 return False
         return True
 
+    return False
 
-def check_label(label):
 
+def check_label(label: Union[str, bytes, bytearray]) -> None:
     if isinstance(label, (bytes, bytearray)):
         label = label.decode('utf-8')
     if len(label) == 0:
@@ -259,14 +252,13 @@ def check_label(label):
     check_bidi(label)
 
 
-def alabel(label):
-
+def alabel(label: str) -> bytes:
     try:
-        label = label.encode('ascii')
-        ulabel(label)
-        if not valid_label_length(label):
+        label_bytes = label.encode('ascii')
+        ulabel(label_bytes)
+        if not valid_label_length(label_bytes):
             raise IDNAError('Label too long')
-        return label
+        return label_bytes
     except UnicodeEncodeError:
         pass
 
@@ -275,51 +267,58 @@ def alabel(label):
 
     label = str(label)
     check_label(label)
-    label = _punycode(label)
-    label = _alabel_prefix + label
+    label_bytes = _punycode(label)
+    label_bytes = _alabel_prefix + label_bytes
 
-    if not valid_label_length(label):
+    if not valid_label_length(label_bytes):
         raise IDNAError('Label too long')
 
-    return label
-
+    return label_bytes
 
-def ulabel(label):
 
+def ulabel(label: Union[str, bytes, bytearray]) -> str:
     if not isinstance(label, (bytes, bytearray)):
         try:
-            label = label.encode('ascii')
+            label_bytes = label.encode('ascii')
         except UnicodeEncodeError:
             check_label(label)
             return label
+    else:
+        label_bytes = label
 
-    label = label.lower()
-    if label.startswith(_alabel_prefix):
-        label = label[len(_alabel_prefix):]
-        if not label:
+    label_bytes = label_bytes.lower()
+    if label_bytes.startswith(_alabel_prefix):
+        label_bytes = label_bytes[len(_alabel_prefix):]
+        if not label_bytes:
             raise IDNAError('Malformed A-label, no Punycode eligible content found')
-        if label.decode('ascii')[-1] == '-':
+        if label_bytes.decode('ascii')[-1] == '-':
             raise IDNAError('A-label must not end with a hyphen')
     else:
-        check_label(label)
-        return label.decode('ascii')
+        check_label(label_bytes)
+        return label_bytes.decode('ascii')
 
-    label = label.decode('punycode')
+    try:
+        label = label_bytes.decode('punycode')
+    except UnicodeError:
+        raise IDNAError('Invalid A-label')
     check_label(label)
     return label
 
 
-def uts46_remap(domain, std3_rules=True, transitional=False):
+def uts46_remap(domain: str, std3_rules: bool = True, transitional: bool = False) -> str:
     """Re-map the characters in the string according to UTS46 processing."""
     from .uts46data import uts46data
     output = ''
-    try:
-        for pos, char in enumerate(domain):
-            code_point = ord(char)
+
+    for pos, char in enumerate(domain):
+        code_point = ord(char)
+        try:
             uts46row = uts46data[code_point if code_point < 256 else
                 bisect.bisect_left(uts46data, (code_point, 'Z')) - 1]
             status = uts46row[1]
-            replacement = uts46row[2] if len(uts46row) == 3 else None
+            replacement = None  # type: Optional[str]
+            if len(uts46row) == 3:
+                replacement = uts46row[2]  # type: ignore
             if (status == 'V' or
                     (status == 'D' and not transitional) or
                     (status == '3' and not std3_rules and replacement is None)):
@@ -330,17 +329,20 @@ def uts46_remap(domain, std3_rules=True, transitional=False):
                 output += replacement
             elif status != 'I':
                 raise IndexError()
-        return unicodedata.normalize('NFC', output)
-    except IndexError:
-        raise InvalidCodepoint(
-            'Codepoint {} not allowed at position {} in {}'.format(
-            _unot(code_point), pos + 1, repr(domain)))
+        except IndexError:
+            raise InvalidCodepoint(
+                'Codepoint {} not allowed at position {} in {}'.format(
+                _unot(code_point), pos + 1, repr(domain)))
 
+    return unicodedata.normalize('NFC', output)
 
-def encode(s, strict=False, uts46=False, std3_rules=False, transitional=False):
 
+def encode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = False, std3_rules: bool = False, transitional: bool = False) -> bytes:
     if isinstance(s, (bytes, bytearray)):
-        s = s.decode('ascii')
+        try:
+            s = s.decode('ascii')
+        except UnicodeDecodeError:
+            raise IDNAError('should pass a unicode string to the function rather than a byte string.')
     if uts46:
         s = uts46_remap(s, std3_rules, transitional)
     trailing_dot = False
@@ -368,10 +370,12 @@ def encode(s, strict=False, uts46=False, std3_rules=False, transitional=False):
     return s
 
 
-def decode(s, strict=False, uts46=False, std3_rules=False):
-
-    if isinstance(s, (bytes, bytearray)):
-        s = s.decode('ascii')
+def decode(s: Union[str, bytes, bytearray], strict: bool = False, uts46: bool = False, std3_rules: bool = False) -> str:
+    try:
+        if isinstance(s, (bytes, bytearray)):
+            s = s.decode('ascii')
+    except UnicodeDecodeError:
+        raise IDNAError('Invalid ASCII in A-label')
     if uts46:
         s = uts46_remap(s, std3_rules, False)
     trailing_dot = False
diff --git a/env/Lib/site-packages/pip/_vendor/idna/idnadata.py b/env/Lib/site-packages/pip/_vendor/idna/idnadata.py
index b86a3e06..67db4625 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/idnadata.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/idnadata.py
@@ -1,6 +1,6 @@
 # This file is automatically generated by tools/idna-data
 
-__version__ = '13.0.0'
+__version__ = '15.0.0'
 scripts = {
     'Greek': (
         0x37000000374,
@@ -49,17 +49,19 @@ scripts = {
         0x30210000302a,
         0x30380000303c,
         0x340000004dc0,
-        0x4e0000009ffd,
+        0x4e000000a000,
         0xf9000000fa6e,
         0xfa700000fada,
+        0x16fe200016fe4,
         0x16ff000016ff2,
-        0x200000002a6de,
-        0x2a7000002b735,
+        0x200000002a6e0,
+        0x2a7000002b73a,
         0x2b7400002b81e,
         0x2b8200002cea2,
         0x2ceb00002ebe1,
         0x2f8000002fa1e,
         0x300000003134b,
+        0x31350000323b0,
     ),
     'Hebrew': (
         0x591000005c8,
@@ -75,7 +77,8 @@ scripts = {
     'Hiragana': (
         0x304100003097,
         0x309d000030a0,
-        0x1b0010001b11f,
+        0x1b0010001b120,
+        0x1b1320001b133,
         0x1b1500001b153,
         0x1f2000001f201,
     ),
@@ -87,7 +90,12 @@ scripts = {
         0x330000003358,
         0xff660000ff70,
         0xff710000ff9e,
+        0x1aff00001aff4,
+        0x1aff50001affc,
+        0x1affd0001afff,
         0x1b0000001b001,
+        0x1b1200001b123,
+        0x1b1550001b156,
         0x1b1640001b168,
     ),
 }
@@ -405,6 +413,39 @@ joining_types = {
     0x868: 68,
     0x869: 82,
     0x86a: 82,
+    0x870: 82,
+    0x871: 82,
+    0x872: 82,
+    0x873: 82,
+    0x874: 82,
+    0x875: 82,
+    0x876: 82,
+    0x877: 82,
+    0x878: 82,
+    0x879: 82,
+    0x87a: 82,
+    0x87b: 82,
+    0x87c: 82,
+    0x87d: 82,
+    0x87e: 82,
+    0x87f: 82,
+    0x880: 82,
+    0x881: 82,
+    0x882: 82,
+    0x883: 67,
+    0x884: 67,
+    0x885: 67,
+    0x886: 68,
+    0x887: 85,
+    0x888: 85,
+    0x889: 68,
+    0x88a: 68,
+    0x88b: 68,
+    0x88c: 68,
+    0x88d: 68,
+    0x88e: 82,
+    0x890: 85,
+    0x891: 85,
     0x8a0: 68,
     0x8a1: 68,
     0x8a2: 68,
@@ -426,6 +467,7 @@ joining_types = {
     0x8b2: 82,
     0x8b3: 68,
     0x8b4: 68,
+    0x8b5: 68,
     0x8b6: 68,
     0x8b7: 68,
     0x8b8: 68,
@@ -444,6 +486,7 @@ joining_types = {
     0x8c5: 68,
     0x8c6: 68,
     0x8c7: 68,
+    0x8c8: 68,
     0x8e2: 85,
     0x1806: 85,
     0x1807: 68,
@@ -768,6 +811,24 @@ joining_types = {
     0x10f52: 68,
     0x10f53: 68,
     0x10f54: 82,
+    0x10f70: 68,
+    0x10f71: 68,
+    0x10f72: 68,
+    0x10f73: 68,
+    0x10f74: 82,
+    0x10f75: 82,
+    0x10f76: 68,
+    0x10f77: 68,
+    0x10f78: 68,
+    0x10f79: 68,
+    0x10f7a: 68,
+    0x10f7b: 68,
+    0x10f7c: 68,
+    0x10f7d: 68,
+    0x10f7e: 68,
+    0x10f7f: 68,
+    0x10f80: 68,
+    0x10f81: 68,
     0x10fb0: 68,
     0x10fb1: 85,
     0x10fb2: 68,
@@ -1168,9 +1229,9 @@ codepoint_classes = {
         0x8000000082e,
         0x8400000085c,
         0x8600000086b,
-        0x8a0000008b5,
-        0x8b6000008c8,
-        0x8d3000008e2,
+        0x87000000888,
+        0x8890000088f,
+        0x898000008e2,
         0x8e300000958,
         0x96000000964,
         0x96600000970,
@@ -1252,11 +1313,12 @@ codepoint_classes = {
         0xc0e00000c11,
         0xc1200000c29,
         0xc2a00000c3a,
-        0xc3d00000c45,
+        0xc3c00000c45,
         0xc4600000c49,
         0xc4a00000c4e,
         0xc5500000c57,
         0xc5800000c5b,
+        0xc5d00000c5e,
         0xc6000000c64,
         0xc6600000c70,
         0xc8000000c84,
@@ -1269,10 +1331,10 @@ codepoint_classes = {
         0xcc600000cc9,
         0xcca00000cce,
         0xcd500000cd7,
-        0xcde00000cdf,
+        0xcdd00000cdf,
         0xce000000ce4,
         0xce600000cf0,
-        0xcf100000cf3,
+        0xcf100000cf4,
         0xd0000000d0d,
         0xd0e00000d11,
         0xd1200000d45,
@@ -1307,7 +1369,7 @@ codepoint_classes = {
         0xeb400000ebe,
         0xec000000ec5,
         0xec600000ec7,
-        0xec800000ece,
+        0xec800000ecf,
         0xed000000eda,
         0xede00000ee0,
         0xf0000000f01,
@@ -1366,9 +1428,8 @@ codepoint_classes = {
         0x16810000169b,
         0x16a0000016eb,
         0x16f1000016f9,
-        0x17000000170d,
-        0x170e00001715,
-        0x172000001735,
+        0x170000001716,
+        0x171f00001735,
         0x174000001754,
         0x17600000176d,
         0x176e00001771,
@@ -1397,8 +1458,8 @@ codepoint_classes = {
         0x1a9000001a9a,
         0x1aa700001aa8,
         0x1ab000001abe,
-        0x1abf00001ac1,
-        0x1b0000001b4c,
+        0x1abf00001acf,
+        0x1b0000001b4d,
         0x1b5000001b5a,
         0x1b6b00001b74,
         0x1b8000001bf4,
@@ -1413,8 +1474,7 @@ codepoint_classes = {
         0x1d4e00001d4f,
         0x1d6b00001d78,
         0x1d7900001d9b,
-        0x1dc000001dfa,
-        0x1dfb00001e00,
+        0x1dc000001e00,
         0x1e0100001e02,
         0x1e0300001e04,
         0x1e0500001e06,
@@ -1563,7 +1623,7 @@ codepoint_classes = {
         0x1ff600001ff7,
         0x214e0000214f,
         0x218400002185,
-        0x2c3000002c5f,
+        0x2c3000002c60,
         0x2c6100002c62,
         0x2c6500002c67,
         0x2c6800002c69,
@@ -1652,8 +1712,7 @@ codepoint_classes = {
         0x31a0000031c0,
         0x31f000003200,
         0x340000004dc0,
-        0x4e0000009ffd,
-        0xa0000000a48d,
+        0x4e000000a48d,
         0xa4d00000a4fe,
         0xa5000000a60d,
         0xa6100000a62c,
@@ -1766,9 +1825,16 @@ codepoint_classes = {
         0xa7bb0000a7bc,
         0xa7bd0000a7be,
         0xa7bf0000a7c0,
+        0xa7c10000a7c2,
         0xa7c30000a7c4,
         0xa7c80000a7c9,
         0xa7ca0000a7cb,
+        0xa7d10000a7d2,
+        0xa7d30000a7d4,
+        0xa7d50000a7d6,
+        0xa7d70000a7d8,
+        0xa7d90000a7da,
+        0xa7f20000a7f5,
         0xa7f60000a7f8,
         0xa7fa0000a828,
         0xa82c0000a82d,
@@ -1796,7 +1862,7 @@ codepoint_classes = {
         0xab200000ab27,
         0xab280000ab2f,
         0xab300000ab5b,
-        0xab600000ab6a,
+        0xab600000ab69,
         0xabc00000abeb,
         0xabec0000abee,
         0xabf00000abfa,
@@ -1834,9 +1900,16 @@ codepoint_classes = {
         0x104d8000104fc,
         0x1050000010528,
         0x1053000010564,
+        0x10597000105a2,
+        0x105a3000105b2,
+        0x105b3000105ba,
+        0x105bb000105bd,
         0x1060000010737,
         0x1074000010756,
         0x1076000010768,
+        0x1078000010786,
+        0x10787000107b1,
+        0x107b2000107bb,
         0x1080000010806,
         0x1080800010809,
         0x1080a00010836,
@@ -1873,14 +1946,16 @@ codepoint_classes = {
         0x10e8000010eaa,
         0x10eab00010ead,
         0x10eb000010eb2,
-        0x10f0000010f1d,
+        0x10efd00010f1d,
         0x10f2700010f28,
         0x10f3000010f51,
+        0x10f7000010f86,
         0x10fb000010fc5,
         0x10fe000010ff7,
         0x1100000011047,
-        0x1106600011070,
+        0x1106600011076,
         0x1107f000110bb,
+        0x110c2000110c3,
         0x110d0000110e9,
         0x110f0000110fa,
         0x1110000011135,
@@ -1894,7 +1969,7 @@ codepoint_classes = {
         0x111dc000111dd,
         0x1120000011212,
         0x1121300011238,
-        0x1123e0001123f,
+        0x1123e00011242,
         0x1128000011287,
         0x1128800011289,
         0x1128a0001128e,
@@ -1934,6 +2009,7 @@ codepoint_classes = {
         0x117000001171b,
         0x1171d0001172c,
         0x117300001173a,
+        0x1174000011747,
         0x118000001183b,
         0x118c0000118ea,
         0x118ff00011907,
@@ -1952,7 +2028,7 @@ codepoint_classes = {
         0x11a4700011a48,
         0x11a5000011a9a,
         0x11a9d00011a9e,
-        0x11ac000011af9,
+        0x11ab000011af9,
         0x11c0000011c09,
         0x11c0a00011c37,
         0x11c3800011c41,
@@ -1974,14 +2050,22 @@ codepoint_classes = {
         0x11d9300011d99,
         0x11da000011daa,
         0x11ee000011ef7,
+        0x11f0000011f11,
+        0x11f1200011f3b,
+        0x11f3e00011f43,
+        0x11f5000011f5a,
         0x11fb000011fb1,
         0x120000001239a,
         0x1248000012544,
-        0x130000001342f,
+        0x12f9000012ff1,
+        0x1300000013430,
+        0x1344000013456,
         0x1440000014647,
         0x1680000016a39,
         0x16a4000016a5f,
         0x16a6000016a6a,
+        0x16a7000016abf,
+        0x16ac000016aca,
         0x16ad000016aee,
         0x16af000016af5,
         0x16b0000016b37,
@@ -1999,8 +2083,13 @@ codepoint_classes = {
         0x17000000187f8,
         0x1880000018cd6,
         0x18d0000018d09,
-        0x1b0000001b11f,
+        0x1aff00001aff4,
+        0x1aff50001affc,
+        0x1affd0001afff,
+        0x1b0000001b123,
+        0x1b1320001b133,
         0x1b1500001b153,
+        0x1b1550001b156,
         0x1b1640001b168,
         0x1b1700001b2fc,
         0x1bc000001bc6b,
@@ -2008,33 +2097,45 @@ codepoint_classes = {
         0x1bc800001bc89,
         0x1bc900001bc9a,
         0x1bc9d0001bc9f,
+        0x1cf000001cf2e,
+        0x1cf300001cf47,
         0x1da000001da37,
         0x1da3b0001da6d,
         0x1da750001da76,
         0x1da840001da85,
         0x1da9b0001daa0,
         0x1daa10001dab0,
+        0x1df000001df1f,
+        0x1df250001df2b,
         0x1e0000001e007,
         0x1e0080001e019,
         0x1e01b0001e022,
         0x1e0230001e025,
         0x1e0260001e02b,
+        0x1e0300001e06e,
+        0x1e08f0001e090,
         0x1e1000001e12d,
         0x1e1300001e13e,
         0x1e1400001e14a,
         0x1e14e0001e14f,
+        0x1e2900001e2af,
         0x1e2c00001e2fa,
+        0x1e4d00001e4fa,
+        0x1e7e00001e7e7,
+        0x1e7e80001e7ec,
+        0x1e7ed0001e7ef,
+        0x1e7f00001e7ff,
         0x1e8000001e8c5,
         0x1e8d00001e8d7,
         0x1e9220001e94c,
         0x1e9500001e95a,
-        0x1fbf00001fbfa,
-        0x200000002a6de,
-        0x2a7000002b735,
+        0x200000002a6e0,
+        0x2a7000002b73a,
         0x2b7400002b81e,
         0x2b8200002cea2,
         0x2ceb00002ebe1,
         0x300000003134b,
+        0x31350000323b0,
     ),
     'CONTEXTJ': (
         0x200c0000200e,
diff --git a/env/Lib/site-packages/pip/_vendor/idna/intranges.py b/env/Lib/site-packages/pip/_vendor/idna/intranges.py
index fa8a7356..6a43b047 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/intranges.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/intranges.py
@@ -6,8 +6,9 @@ in the original list?" in time O(log(# runs)).
 """
 
 import bisect
+from typing import List, Tuple
 
-def intranges_from_list(list_):
+def intranges_from_list(list_: List[int]) -> Tuple[int, ...]:
     """Represent a list of integers as a sequence of ranges:
     ((start_0, end_0), (start_1, end_1), ...), such that the original
     integers are exactly those x such that start_i <= x < end_i for some i.
@@ -28,14 +29,14 @@ def intranges_from_list(list_):
 
     return tuple(ranges)
 
-def _encode_range(start, end):
+def _encode_range(start: int, end: int) -> int:
     return (start << 32) | end
 
-def _decode_range(r):
+def _decode_range(r: int) -> Tuple[int, int]:
     return (r >> 32), (r & ((1 << 32) - 1))
 
 
-def intranges_contain(int_, ranges):
+def intranges_contain(int_: int, ranges: Tuple[int, ...]) -> bool:
     """Determine if `int_` falls into one of the ranges in `ranges`."""
     tuple_ = _encode_range(int_, 0)
     pos = bisect.bisect_left(ranges, tuple_)
diff --git a/env/Lib/site-packages/pip/_vendor/idna/package_data.py b/env/Lib/site-packages/pip/_vendor/idna/package_data.py
index 1420ea2f..8501893b 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/package_data.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/package_data.py
@@ -1,2 +1,2 @@
-__version__ = '3.1'
+__version__ = '3.4'
 
diff --git a/env/Lib/site-packages/pip/_vendor/idna/uts46data.py b/env/Lib/site-packages/pip/_vendor/idna/uts46data.py
index 8ae36cbe..186796c1 100644
--- a/env/Lib/site-packages/pip/_vendor/idna/uts46data.py
+++ b/env/Lib/site-packages/pip/_vendor/idna/uts46data.py
@@ -1,10 +1,14 @@
 # This file is automatically generated by tools/idna-data
+# vim: set fileencoding=utf-8 :
+
+from typing import List, Tuple, Union
+
 
 """IDNA Mapping Table from UTS46."""
 
 
-__version__ = '13.0.0'
-def _seg_0():
+__version__ = '15.0.0'
+def _seg_0() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x0, '3'),
     (0x1, '3'),
@@ -108,7 +112,7 @@ def _seg_0():
     (0x63, 'V'),
     ]
 
-def _seg_1():
+def _seg_1() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x64, 'V'),
     (0x65, 'V'),
@@ -212,7 +216,7 @@ def _seg_1():
     (0xC7, 'M', 'ç'),
     ]
 
-def _seg_2():
+def _seg_2() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0xC8, 'M', 'è'),
     (0xC9, 'M', 'é'),
@@ -316,7 +320,7 @@ def _seg_2():
     (0x12B, 'V'),
     ]
 
-def _seg_3():
+def _seg_3() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x12C, 'M', 'ĭ'),
     (0x12D, 'V'),
@@ -420,7 +424,7 @@ def _seg_3():
     (0x193, 'M', 'ɠ'),
     ]
 
-def _seg_4():
+def _seg_4() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x194, 'M', 'ɣ'),
     (0x195, 'V'),
@@ -524,7 +528,7 @@ def _seg_4():
     (0x20C, 'M', 'ȍ'),
     ]
 
-def _seg_5():
+def _seg_5() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x20D, 'V'),
     (0x20E, 'M', 'ȏ'),
@@ -628,7 +632,7 @@ def _seg_5():
     (0x377, 'V'),
     ]
 
-def _seg_6():
+def _seg_6() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x378, 'X'),
     (0x37A, '3', ' ι'),
@@ -732,7 +736,7 @@ def _seg_6():
     (0x402, 'M', 'ђ'),
     ]
 
-def _seg_7():
+def _seg_7() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x403, 'M', 'ѓ'),
     (0x404, 'M', 'є'),
@@ -836,7 +840,7 @@ def _seg_7():
     (0x49D, 'V'),
     ]
 
-def _seg_8():
+def _seg_8() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x49E, 'M', 'ҟ'),
     (0x49F, 'V'),
@@ -940,7 +944,7 @@ def _seg_8():
     (0x502, 'M', 'ԃ'),
     ]
 
-def _seg_9():
+def _seg_9() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x503, 'V'),
     (0x504, 'M', 'ԅ'),
@@ -1041,10 +1045,10 @@ def _seg_9():
     (0x5F5, 'X'),
     (0x606, 'V'),
     (0x61C, 'X'),
-    (0x61E, 'V'),
+    (0x61D, 'V'),
     ]
 
-def _seg_10():
+def _seg_10() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x675, 'M', 'اٴ'),
     (0x676, 'M', 'وٴ'),
@@ -1070,11 +1074,9 @@ def _seg_10():
     (0x85F, 'X'),
     (0x860, 'V'),
     (0x86B, 'X'),
-    (0x8A0, 'V'),
-    (0x8B5, 'X'),
-    (0x8B6, 'V'),
-    (0x8C8, 'X'),
-    (0x8D3, 'V'),
+    (0x870, 'V'),
+    (0x88F, 'X'),
+    (0x898, 'V'),
     (0x8E2, 'X'),
     (0x8E3, 'V'),
     (0x958, 'M', 'क़'),
@@ -1146,12 +1148,12 @@ def _seg_10():
     (0xA59, 'M', 'ਖ਼'),
     (0xA5A, 'M', 'ਗ਼'),
     (0xA5B, 'M', 'ਜ਼'),
+    (0xA5C, 'V'),
+    (0xA5D, 'X'),
     ]
 
-def _seg_11():
+def _seg_11() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
-    (0xA5C, 'V'),
-    (0xA5D, 'X'),
     (0xA5E, 'M', 'ਫ਼'),
     (0xA5F, 'X'),
     (0xA66, 'V'),
@@ -1250,14 +1252,14 @@ def _seg_11():
     (0xC0E, 'V'),
     (0xC11, 'X'),
     (0xC12, 'V'),
+    (0xC29, 'X'),
+    (0xC2A, 'V'),
     ]
 
-def _seg_12():
+def _seg_12() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
-    (0xC29, 'X'),
-    (0xC2A, 'V'),
     (0xC3A, 'X'),
-    (0xC3D, 'V'),
+    (0xC3C, 'V'),
     (0xC45, 'X'),
     (0xC46, 'V'),
     (0xC49, 'X'),
@@ -1267,6 +1269,8 @@ def _seg_12():
     (0xC57, 'X'),
     (0xC58, 'V'),
     (0xC5B, 'X'),
+    (0xC5D, 'V'),
+    (0xC5E, 'X'),
     (0xC60, 'V'),
     (0xC64, 'X'),
     (0xC66, 'V'),
@@ -1289,14 +1293,14 @@ def _seg_12():
     (0xCCE, 'X'),
     (0xCD5, 'V'),
     (0xCD7, 'X'),
-    (0xCDE, 'V'),
+    (0xCDD, 'V'),
     (0xCDF, 'X'),
     (0xCE0, 'V'),
     (0xCE4, 'X'),
     (0xCE6, 'V'),
     (0xCF0, 'X'),
     (0xCF1, 'V'),
-    (0xCF3, 'X'),
+    (0xCF4, 'X'),
     (0xD00, 'V'),
     (0xD0D, 'X'),
     (0xD0E, 'V'),
@@ -1356,7 +1360,7 @@ def _seg_12():
     (0xEB4, 'V'),
     ]
 
-def _seg_13():
+def _seg_13() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0xEBE, 'X'),
     (0xEC0, 'V'),
@@ -1364,7 +1368,7 @@ def _seg_13():
     (0xEC6, 'V'),
     (0xEC7, 'X'),
     (0xEC8, 'V'),
-    (0xECE, 'X'),
+    (0xECF, 'X'),
     (0xED0, 'V'),
     (0xEDA, 'X'),
     (0xEDC, 'M', 'ຫນ'),
@@ -1460,7 +1464,7 @@ def _seg_13():
     (0x1312, 'V'),
     ]
 
-def _seg_14():
+def _seg_14() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
     (0x1316, 'X'),
     (0x1318, 'V'),
@@ -1485,10 +1489,8 @@ def _seg_14():
     (0x16A0, 'V'),
     (0x16F9, 'X'),
     (0x1700, 'V'),
-    (0x170D, 'X'),
-    (0x170E, 'V'),
-    (0x1715, 'X'),
-    (0x1720, 'V'),
+    (0x1716, 'X'),
+    (0x171F, 'V'),
     (0x1737, 'X'),
     (0x1740, 'V'),
     (0x1754, 'X'),
@@ -1511,6 +1513,7 @@ def _seg_14():
     (0x1807, 'V'),
     (0x180B, 'I'),
     (0x180E, 'X'),
+    (0x180F, 'I'),
     (0x1810, 'V'),
     (0x181A, 'X'),
     (0x1820, 'V'),
@@ -1550,11 +1553,11 @@ def _seg_14():
     (0x1AA0, 'V'),
     (0x1AAE, 'X'),
     (0x1AB0, 'V'),
-    (0x1AC1, 'X'),
+    (0x1ACF, 'X'),
     (0x1B00, 'V'),
-    (0x1B4C, 'X'),
+    (0x1B4D, 'X'),
     (0x1B50, 'V'),
-    (0x1B7D, 'X'),
+    (0x1B7F, 'X'),
     (0x1B80, 'V'),
     (0x1BF4, 'X'),
     (0x1BFC, 'V'),
@@ -1562,11 +1565,11 @@ def _seg_14():
     (0x1C3B, 'V'),
     (0x1C4A, 'X'),
     (0x1C4D, 'V'),
+    (0x1C80, 'M', 'в'),
     ]
 
-def _seg_15():
+def _seg_15() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
-    (0x1C80, 'M', 'в'),
     (0x1C81, 'M', 'д'),
     (0x1C82, 'M', 'о'),
     (0x1C83, 'M', 'с'),
@@ -1666,11 +1669,11 @@ def _seg_15():
     (0x1D50, 'M', 'm'),
     (0x1D51, 'M', 'ŋ'),
     (0x1D52, 'M', 'o'),
+    (0x1D53, 'M', 'ɔ'),
     ]
 
-def _seg_16():
+def _seg_16() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
     return [
-    (0x1D53, 'M', 'ɔ'),
     (0x1D54, 'M', 'ᴖ'),
     (0x1D55, 'M', 'ᴗ'),
     (0x1D56, 'M', 'p'),
@@ -1735,8 +1738,6 @@ def _seg_16():
     (0x1DBE, 'M', 'ʒ'),
     (0x1DBF, 'M', 'θ'),
     (0x1DC0, 'V'),
-    (0x1DFA, 'X'),
-    (0x1DFB, 'V'),
     (0x1E00, 'M', 'ḁ'),
     (0x1E01, 'V'),
     (0x1E02, 'M', 'ḃ'),
@@ -1770,13 +1771,13 @@ def _seg_16():
     (0x1E1E, 'M', 'ḟ'),
     (0x1E1F, 'V'),
     (0x1E20, 'M', 'ḡ'),
-    ]
-
-def _seg_17():
-    return [
     (0x1E21, 'V'),
     (0x1E22, 'M', 'ḣ'),
     (0x1E23, 'V'),
+    ]
+
+def _seg_17() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1E24, 'M', 'ḥ'),
     (0x1E25, 'V'),
     (0x1E26, 'M', 'ḧ'),
@@ -1874,13 +1875,13 @@ def _seg_17():
     (0x1E82, 'M', 'ẃ'),
     (0x1E83, 'V'),
     (0x1E84, 'M', 'ẅ'),
-    ]
-
-def _seg_18():
-    return [
     (0x1E85, 'V'),
     (0x1E86, 'M', 'ẇ'),
     (0x1E87, 'V'),
+    ]
+
+def _seg_18() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1E88, 'M', 'ẉ'),
     (0x1E89, 'V'),
     (0x1E8A, 'M', 'ẋ'),
@@ -1978,13 +1979,13 @@ def _seg_18():
     (0x1EEB, 'V'),
     (0x1EEC, 'M', 'ử'),
     (0x1EED, 'V'),
-    ]
-
-def _seg_19():
-    return [
     (0x1EEE, 'M', 'ữ'),
     (0x1EEF, 'V'),
     (0x1EF0, 'M', 'ự'),
+    ]
+
+def _seg_19() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1EF1, 'V'),
     (0x1EF2, 'M', 'ỳ'),
     (0x1EF3, 'V'),
@@ -2082,13 +2083,13 @@ def _seg_19():
     (0x1F82, 'M', 'ἂι'),
     (0x1F83, 'M', 'ἃι'),
     (0x1F84, 'M', 'ἄι'),
-    ]
-
-def _seg_20():
-    return [
     (0x1F85, 'M', 'ἅι'),
     (0x1F86, 'M', 'ἆι'),
     (0x1F87, 'M', 'ἇι'),
+    ]
+
+def _seg_20() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1F88, 'M', 'ἀι'),
     (0x1F89, 'M', 'ἁι'),
     (0x1F8A, 'M', 'ἂι'),
@@ -2186,13 +2187,13 @@ def _seg_20():
     (0x1FF0, 'X'),
     (0x1FF2, 'M', 'ὼι'),
     (0x1FF3, 'M', 'ωι'),
-    ]
-
-def _seg_21():
-    return [
     (0x1FF4, 'M', 'ώι'),
     (0x1FF5, 'X'),
     (0x1FF6, 'V'),
+    ]
+
+def _seg_21() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1FF7, 'M', 'ῶι'),
     (0x1FF8, 'M', 'ὸ'),
     (0x1FF9, 'M', 'ό'),
@@ -2285,18 +2286,18 @@ def _seg_21():
     (0x20A0, 'V'),
     (0x20A8, 'M', 'rs'),
     (0x20A9, 'V'),
-    (0x20C0, 'X'),
+    (0x20C1, 'X'),
     (0x20D0, 'V'),
     (0x20F1, 'X'),
     (0x2100, '3', 'a/c'),
     (0x2101, '3', 'a/s'),
-    ]
-
-def _seg_22():
-    return [
     (0x2102, 'M', 'c'),
     (0x2103, 'M', '°c'),
     (0x2104, 'V'),
+    ]
+
+def _seg_22() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2105, '3', 'c/o'),
     (0x2106, '3', 'c/u'),
     (0x2107, 'M', 'ɛ'),
@@ -2394,13 +2395,13 @@ def _seg_22():
     (0x2177, 'M', 'viii'),
     (0x2178, 'M', 'ix'),
     (0x2179, 'M', 'x'),
-    ]
-
-def _seg_23():
-    return [
     (0x217A, 'M', 'xi'),
     (0x217B, 'M', 'xii'),
     (0x217C, 'M', 'l'),
+    ]
+
+def _seg_23() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x217D, 'M', 'c'),
     (0x217E, 'M', 'd'),
     (0x217F, 'M', 'm'),
@@ -2498,13 +2499,13 @@ def _seg_23():
     (0x24B7, 'M', 'b'),
     (0x24B8, 'M', 'c'),
     (0x24B9, 'M', 'd'),
-    ]
-
-def _seg_24():
-    return [
     (0x24BA, 'M', 'e'),
     (0x24BB, 'M', 'f'),
     (0x24BC, 'M', 'g'),
+    ]
+
+def _seg_24() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x24BD, 'M', 'h'),
     (0x24BE, 'M', 'i'),
     (0x24BF, 'M', 'j'),
@@ -2602,22 +2603,21 @@ def _seg_24():
     (0x2C23, 'M', 'ⱓ'),
     (0x2C24, 'M', 'ⱔ'),
     (0x2C25, 'M', 'ⱕ'),
-    ]
-
-def _seg_25():
-    return [
     (0x2C26, 'M', 'ⱖ'),
     (0x2C27, 'M', 'ⱗ'),
     (0x2C28, 'M', 'ⱘ'),
+    ]
+
+def _seg_25() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2C29, 'M', 'ⱙ'),
     (0x2C2A, 'M', 'ⱚ'),
     (0x2C2B, 'M', 'ⱛ'),
     (0x2C2C, 'M', 'ⱜ'),
     (0x2C2D, 'M', 'ⱝ'),
     (0x2C2E, 'M', 'ⱞ'),
-    (0x2C2F, 'X'),
+    (0x2C2F, 'M', 'ⱟ'),
     (0x2C30, 'V'),
-    (0x2C5F, 'X'),
     (0x2C60, 'M', 'ⱡ'),
     (0x2C61, 'V'),
     (0x2C62, 'M', 'ɫ'),
@@ -2706,14 +2706,14 @@ def _seg_25():
     (0x2CBC, 'M', 'ⲽ'),
     (0x2CBD, 'V'),
     (0x2CBE, 'M', 'ⲿ'),
-    ]
-
-def _seg_26():
-    return [
     (0x2CBF, 'V'),
     (0x2CC0, 'M', 'ⳁ'),
     (0x2CC1, 'V'),
     (0x2CC2, 'M', 'ⳃ'),
+    ]
+
+def _seg_26() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2CC3, 'V'),
     (0x2CC4, 'M', 'ⳅ'),
     (0x2CC5, 'V'),
@@ -2784,7 +2784,7 @@ def _seg_26():
     (0x2DD8, 'V'),
     (0x2DDF, 'X'),
     (0x2DE0, 'V'),
-    (0x2E53, 'X'),
+    (0x2E5E, 'X'),
     (0x2E80, 'V'),
     (0x2E9A, 'X'),
     (0x2E9B, 'V'),
@@ -2810,14 +2810,14 @@ def _seg_26():
     (0x2F0F, 'M', '几'),
     (0x2F10, 'M', '凵'),
     (0x2F11, 'M', '刀'),
-    ]
-
-def _seg_27():
-    return [
     (0x2F12, 'M', '力'),
     (0x2F13, 'M', '勹'),
     (0x2F14, 'M', '匕'),
     (0x2F15, 'M', '匚'),
+    ]
+
+def _seg_27() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F16, 'M', '匸'),
     (0x2F17, 'M', '十'),
     (0x2F18, 'M', '卜'),
@@ -2914,14 +2914,14 @@ def _seg_27():
     (0x2F73, 'M', '穴'),
     (0x2F74, 'M', '立'),
     (0x2F75, 'M', '竹'),
-    ]
-
-def _seg_28():
-    return [
     (0x2F76, 'M', '米'),
     (0x2F77, 'M', '糸'),
     (0x2F78, 'M', '缶'),
     (0x2F79, 'M', '网'),
+    ]
+
+def _seg_28() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F7A, 'M', '羊'),
     (0x2F7B, 'M', '羽'),
     (0x2F7C, 'M', '老'),
@@ -3018,14 +3018,14 @@ def _seg_28():
     (0x3000, '3', ' '),
     (0x3001, 'V'),
     (0x3002, 'M', '.'),
-    ]
-
-def _seg_29():
-    return [
     (0x3003, 'V'),
     (0x3036, 'M', '〒'),
     (0x3037, 'V'),
     (0x3038, 'M', '十'),
+    ]
+
+def _seg_29() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x3039, 'M', '卄'),
     (0x303A, 'M', '卅'),
     (0x303B, 'V'),
@@ -3122,14 +3122,14 @@ def _seg_29():
     (0x317E, 'M', 'ᄶ'),
     (0x317F, 'M', 'ᅀ'),
     (0x3180, 'M', 'ᅇ'),
-    ]
-
-def _seg_30():
-    return [
     (0x3181, 'M', 'ᅌ'),
     (0x3182, 'M', 'ᇱ'),
     (0x3183, 'M', 'ᇲ'),
     (0x3184, 'M', 'ᅗ'),
+    ]
+
+def _seg_30() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x3185, 'M', 'ᅘ'),
     (0x3186, 'M', 'ᅙ'),
     (0x3187, 'M', 'ᆄ'),
@@ -3226,14 +3226,14 @@ def _seg_30():
     (0x3240, '3', '(祭)'),
     (0x3241, '3', '(休)'),
     (0x3242, '3', '(自)'),
-    ]
-
-def _seg_31():
-    return [
     (0x3243, '3', '(至)'),
     (0x3244, 'M', '問'),
     (0x3245, 'M', '幼'),
     (0x3246, 'M', '文'),
+    ]
+
+def _seg_31() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x3247, 'M', '箏'),
     (0x3248, 'V'),
     (0x3250, 'M', 'pte'),
@@ -3330,14 +3330,14 @@ def _seg_31():
     (0x32AB, 'M', '学'),
     (0x32AC, 'M', '監'),
     (0x32AD, 'M', '企'),
-    ]
-
-def _seg_32():
-    return [
     (0x32AE, 'M', '資'),
     (0x32AF, 'M', '協'),
     (0x32B0, 'M', '夜'),
     (0x32B1, 'M', '36'),
+    ]
+
+def _seg_32() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x32B2, 'M', '37'),
     (0x32B3, 'M', '38'),
     (0x32B4, 'M', '39'),
@@ -3434,14 +3434,14 @@ def _seg_32():
     (0x330F, 'M', 'ガンマ'),
     (0x3310, 'M', 'ギガ'),
     (0x3311, 'M', 'ギニー'),
-    ]
-
-def _seg_33():
-    return [
     (0x3312, 'M', 'キュリー'),
     (0x3313, 'M', 'ギルダー'),
     (0x3314, 'M', 'キロ'),
     (0x3315, 'M', 'キログラム'),
+    ]
+
+def _seg_33() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x3316, 'M', 'キロメートル'),
     (0x3317, 'M', 'キロワット'),
     (0x3318, 'M', 'グラム'),
@@ -3538,14 +3538,14 @@ def _seg_33():
     (0x3373, 'M', 'au'),
     (0x3374, 'M', 'bar'),
     (0x3375, 'M', 'ov'),
-    ]
-
-def _seg_34():
-    return [
     (0x3376, 'M', 'pc'),
     (0x3377, 'M', 'dm'),
     (0x3378, 'M', 'dm2'),
     (0x3379, 'M', 'dm3'),
+    ]
+
+def _seg_34() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x337A, 'M', 'iu'),
     (0x337B, 'M', '平成'),
     (0x337C, 'M', '昭和'),
@@ -3642,14 +3642,14 @@ def _seg_34():
     (0x33D7, 'M', 'ph'),
     (0x33D8, 'X'),
     (0x33D9, 'M', 'ppm'),
-    ]
-
-def _seg_35():
-    return [
     (0x33DA, 'M', 'pr'),
     (0x33DB, 'M', 'sr'),
     (0x33DC, 'M', 'sv'),
     (0x33DD, 'M', 'wb'),
+    ]
+
+def _seg_35() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x33DE, 'M', 'v∕m'),
     (0x33DF, 'M', 'a∕m'),
     (0x33E0, 'M', '1日'),
@@ -3685,8 +3685,6 @@ def _seg_35():
     (0x33FE, 'M', '31日'),
     (0x33FF, 'M', 'gal'),
     (0x3400, 'V'),
-    (0x9FFD, 'X'),
-    (0xA000, 'V'),
     (0xA48D, 'X'),
     (0xA490, 'V'),
     (0xA4C7, 'X'),
@@ -3746,16 +3744,16 @@ def _seg_35():
     (0xA685, 'V'),
     (0xA686, 'M', 'ꚇ'),
     (0xA687, 'V'),
-    ]
-
-def _seg_36():
-    return [
     (0xA688, 'M', 'ꚉ'),
     (0xA689, 'V'),
     (0xA68A, 'M', 'ꚋ'),
     (0xA68B, 'V'),
     (0xA68C, 'M', 'ꚍ'),
     (0xA68D, 'V'),
+    ]
+
+def _seg_36() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xA68E, 'M', 'ꚏ'),
     (0xA68F, 'V'),
     (0xA690, 'M', 'ꚑ'),
@@ -3850,16 +3848,16 @@ def _seg_36():
     (0xA76C, 'M', 'ꝭ'),
     (0xA76D, 'V'),
     (0xA76E, 'M', 'ꝯ'),
-    ]
-
-def _seg_37():
-    return [
     (0xA76F, 'V'),
     (0xA770, 'M', 'ꝯ'),
     (0xA771, 'V'),
     (0xA779, 'M', 'ꝺ'),
     (0xA77A, 'V'),
     (0xA77B, 'M', 'ꝼ'),
+    ]
+
+def _seg_37() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xA77C, 'V'),
     (0xA77D, 'M', 'ᵹ'),
     (0xA77E, 'M', 'ꝿ'),
@@ -3922,7 +3920,8 @@ def _seg_37():
     (0xA7BD, 'V'),
     (0xA7BE, 'M', 'ꞿ'),
     (0xA7BF, 'V'),
-    (0xA7C0, 'X'),
+    (0xA7C0, 'M', 'ꟁ'),
+    (0xA7C1, 'V'),
     (0xA7C2, 'M', 'ꟃ'),
     (0xA7C3, 'V'),
     (0xA7C4, 'M', 'ꞔ'),
@@ -3933,6 +3932,20 @@ def _seg_37():
     (0xA7C9, 'M', 'ꟊ'),
     (0xA7CA, 'V'),
     (0xA7CB, 'X'),
+    (0xA7D0, 'M', 'ꟑ'),
+    (0xA7D1, 'V'),
+    (0xA7D2, 'X'),
+    (0xA7D3, 'V'),
+    (0xA7D4, 'X'),
+    (0xA7D5, 'V'),
+    (0xA7D6, 'M', 'ꟗ'),
+    (0xA7D7, 'V'),
+    (0xA7D8, 'M', 'ꟙ'),
+    (0xA7D9, 'V'),
+    (0xA7DA, 'X'),
+    (0xA7F2, 'M', 'c'),
+    (0xA7F3, 'M', 'f'),
+    (0xA7F4, 'M', 'q'),
     (0xA7F5, 'M', 'ꟶ'),
     (0xA7F6, 'V'),
     (0xA7F8, 'M', 'ħ'),
@@ -3945,6 +3958,10 @@ def _seg_37():
     (0xA878, 'X'),
     (0xA880, 'V'),
     (0xA8C6, 'X'),
+    ]
+
+def _seg_38() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xA8CE, 'V'),
     (0xA8DA, 'X'),
     (0xA8E0, 'V'),
@@ -3954,10 +3971,6 @@ def _seg_37():
     (0xA980, 'V'),
     (0xA9CE, 'X'),
     (0xA9CF, 'V'),
-    ]
-
-def _seg_38():
-    return [
     (0xA9DA, 'X'),
     (0xA9DE, 'V'),
     (0xA9FF, 'X'),
@@ -4049,6 +4062,10 @@ def _seg_38():
     (0xABA8, 'M', 'Ꮨ'),
     (0xABA9, 'M', 'Ꮩ'),
     (0xABAA, 'M', 'Ꮪ'),
+    ]
+
+def _seg_39() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xABAB, 'M', 'Ꮫ'),
     (0xABAC, 'M', 'Ꮬ'),
     (0xABAD, 'M', 'Ꮭ'),
@@ -4058,10 +4075,6 @@ def _seg_38():
     (0xABB1, 'M', 'Ꮱ'),
     (0xABB2, 'M', 'Ꮲ'),
     (0xABB3, 'M', 'Ꮳ'),
-    ]
-
-def _seg_39():
-    return [
     (0xABB4, 'M', 'Ꮴ'),
     (0xABB5, 'M', 'Ꮵ'),
     (0xABB6, 'M', 'Ꮶ'),
@@ -4153,6 +4166,10 @@ def _seg_39():
     (0xF943, 'M', '弄'),
     (0xF944, 'M', '籠'),
     (0xF945, 'M', '聾'),
+    ]
+
+def _seg_40() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xF946, 'M', '牢'),
     (0xF947, 'M', '磊'),
     (0xF948, 'M', '賂'),
@@ -4162,10 +4179,6 @@ def _seg_39():
     (0xF94C, 'M', '樓'),
     (0xF94D, 'M', '淚'),
     (0xF94E, 'M', '漏'),
-    ]
-
-def _seg_40():
-    return [
     (0xF94F, 'M', '累'),
     (0xF950, 'M', '縷'),
     (0xF951, 'M', '陋'),
@@ -4257,6 +4270,10 @@ def _seg_40():
     (0xF9A7, 'M', '獵'),
     (0xF9A8, 'M', '令'),
     (0xF9A9, 'M', '囹'),
+    ]
+
+def _seg_41() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xF9AA, 'M', '寧'),
     (0xF9AB, 'M', '嶺'),
     (0xF9AC, 'M', '怜'),
@@ -4266,10 +4283,6 @@ def _seg_40():
     (0xF9B0, 'M', '聆'),
     (0xF9B1, 'M', '鈴'),
     (0xF9B2, 'M', '零'),
-    ]
-
-def _seg_41():
-    return [
     (0xF9B3, 'M', '靈'),
     (0xF9B4, 'M', '領'),
     (0xF9B5, 'M', '例'),
@@ -4361,6 +4374,10 @@ def _seg_41():
     (0xFA0B, 'M', '廓'),
     (0xFA0C, 'M', '兀'),
     (0xFA0D, 'M', '嗀'),
+    ]
+
+def _seg_42() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFA0E, 'V'),
     (0xFA10, 'M', '塚'),
     (0xFA11, 'V'),
@@ -4370,10 +4387,6 @@ def _seg_41():
     (0xFA16, 'M', '猪'),
     (0xFA17, 'M', '益'),
     (0xFA18, 'M', '礼'),
-    ]
-
-def _seg_42():
-    return [
     (0xFA19, 'M', '神'),
     (0xFA1A, 'M', '祥'),
     (0xFA1B, 'M', '福'),
@@ -4465,6 +4478,10 @@ def _seg_42():
     (0xFA76, 'M', '勇'),
     (0xFA77, 'M', '勺'),
     (0xFA78, 'M', '喝'),
+    ]
+
+def _seg_43() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFA79, 'M', '啕'),
     (0xFA7A, 'M', '喙'),
     (0xFA7B, 'M', '嗢'),
@@ -4474,10 +4491,6 @@ def _seg_42():
     (0xFA7F, 'M', '奔'),
     (0xFA80, 'M', '婢'),
     (0xFA81, 'M', '嬨'),
-    ]
-
-def _seg_43():
-    return [
     (0xFA82, 'M', '廒'),
     (0xFA83, 'M', '廙'),
     (0xFA84, 'M', '彩'),
@@ -4569,6 +4582,10 @@ def _seg_43():
     (0xFADA, 'X'),
     (0xFB00, 'M', 'ff'),
     (0xFB01, 'M', 'fi'),
+    ]
+
+def _seg_44() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFB02, 'M', 'fl'),
     (0xFB03, 'M', 'ffi'),
     (0xFB04, 'M', 'ffl'),
@@ -4578,10 +4595,6 @@ def _seg_43():
     (0xFB14, 'M', 'մե'),
     (0xFB15, 'M', 'մի'),
     (0xFB16, 'M', 'վն'),
-    ]
-
-def _seg_44():
-    return [
     (0xFB17, 'M', 'մխ'),
     (0xFB18, 'X'),
     (0xFB1D, 'M', 'יִ'),
@@ -4666,13 +4679,17 @@ def _seg_44():
     (0xFBAE, 'M', 'ے'),
     (0xFBB0, 'M', 'ۓ'),
     (0xFBB2, 'V'),
-    (0xFBC2, 'X'),
+    (0xFBC3, 'X'),
     (0xFBD3, 'M', 'ڭ'),
     (0xFBD7, 'M', 'ۇ'),
     (0xFBD9, 'M', 'ۆ'),
     (0xFBDB, 'M', 'ۈ'),
     (0xFBDD, 'M', 'ۇٴ'),
     (0xFBDE, 'M', 'ۋ'),
+    ]
+
+def _seg_45() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFBE0, 'M', 'ۅ'),
     (0xFBE2, 'M', 'ۉ'),
     (0xFBE4, 'M', 'ې'),
@@ -4682,10 +4699,6 @@ def _seg_44():
     (0xFBEE, 'M', 'ئو'),
     (0xFBF0, 'M', 'ئۇ'),
     (0xFBF2, 'M', 'ئۆ'),
-    ]
-
-def _seg_45():
-    return [
     (0xFBF4, 'M', 'ئۈ'),
     (0xFBF6, 'M', 'ئې'),
     (0xFBF9, 'M', 'ئى'),
@@ -4777,6 +4790,10 @@ def _seg_45():
     (0xFC54, 'M', 'هي'),
     (0xFC55, 'M', 'يج'),
     (0xFC56, 'M', 'يح'),
+    ]
+
+def _seg_46() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFC57, 'M', 'يخ'),
     (0xFC58, 'M', 'يم'),
     (0xFC59, 'M', 'يى'),
@@ -4786,10 +4803,6 @@ def _seg_45():
     (0xFC5D, 'M', 'ىٰ'),
     (0xFC5E, '3', ' ٌّ'),
     (0xFC5F, '3', ' ٍّ'),
-    ]
-
-def _seg_46():
-    return [
     (0xFC60, '3', ' َّ'),
     (0xFC61, '3', ' ُّ'),
     (0xFC62, '3', ' ِّ'),
@@ -4881,6 +4894,10 @@ def _seg_46():
     (0xFCB8, 'M', 'طح'),
     (0xFCB9, 'M', 'ظم'),
     (0xFCBA, 'M', 'عج'),
+    ]
+
+def _seg_47() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFCBB, 'M', 'عم'),
     (0xFCBC, 'M', 'غج'),
     (0xFCBD, 'M', 'غم'),
@@ -4890,10 +4907,6 @@ def _seg_46():
     (0xFCC1, 'M', 'فم'),
     (0xFCC2, 'M', 'قح'),
     (0xFCC3, 'M', 'قم'),
-    ]
-
-def _seg_47():
-    return [
     (0xFCC4, 'M', 'كج'),
     (0xFCC5, 'M', 'كح'),
     (0xFCC6, 'M', 'كخ'),
@@ -4985,6 +4998,10 @@ def _seg_47():
     (0xFD1C, 'M', 'حي'),
     (0xFD1D, 'M', 'جى'),
     (0xFD1E, 'M', 'جي'),
+    ]
+
+def _seg_48() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFD1F, 'M', 'خى'),
     (0xFD20, 'M', 'خي'),
     (0xFD21, 'M', 'صى'),
@@ -4994,10 +5011,6 @@ def _seg_47():
     (0xFD25, 'M', 'شج'),
     (0xFD26, 'M', 'شح'),
     (0xFD27, 'M', 'شخ'),
-    ]
-
-def _seg_48():
-    return [
     (0xFD28, 'M', 'شم'),
     (0xFD29, 'M', 'شر'),
     (0xFD2A, 'M', 'سر'),
@@ -5020,7 +5033,6 @@ def _seg_48():
     (0xFD3B, 'M', 'ظم'),
     (0xFD3C, 'M', 'اً'),
     (0xFD3E, 'V'),
-    (0xFD40, 'X'),
     (0xFD50, 'M', 'تجم'),
     (0xFD51, 'M', 'تحج'),
     (0xFD53, 'M', 'تحم'),
@@ -5090,6 +5102,10 @@ def _seg_48():
     (0xFDA4, 'M', 'تمى'),
     (0xFDA5, 'M', 'جمي'),
     (0xFDA6, 'M', 'جحى'),
+    ]
+
+def _seg_49() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFDA7, 'M', 'جمى'),
     (0xFDA8, 'M', 'سخى'),
     (0xFDA9, 'M', 'صحي'),
@@ -5098,10 +5114,6 @@ def _seg_48():
     (0xFDAC, 'M', 'لجي'),
     (0xFDAD, 'M', 'لمي'),
     (0xFDAE, 'M', 'يحي'),
-    ]
-
-def _seg_49():
-    return [
     (0xFDAF, 'M', 'يجي'),
     (0xFDB0, 'M', 'يمي'),
     (0xFDB1, 'M', 'ممي'),
@@ -5128,6 +5140,8 @@ def _seg_49():
     (0xFDC6, 'M', 'سخي'),
     (0xFDC7, 'M', 'نجي'),
     (0xFDC8, 'X'),
+    (0xFDCF, 'V'),
+    (0xFDD0, 'X'),
     (0xFDF0, 'M', 'صلے'),
     (0xFDF1, 'M', 'قلے'),
     (0xFDF2, 'M', 'الله'),
@@ -5142,7 +5156,6 @@ def _seg_49():
     (0xFDFB, '3', 'جل جلاله'),
     (0xFDFC, 'M', 'ریال'),
     (0xFDFD, 'V'),
-    (0xFDFE, 'X'),
     (0xFE00, 'I'),
     (0xFE10, '3', ','),
     (0xFE11, 'M', '、'),
@@ -5193,6 +5206,10 @@ def _seg_49():
     (0xFE5B, '3', '{'),
     (0xFE5C, '3', '}'),
     (0xFE5D, 'M', '〔'),
+    ]
+
+def _seg_50() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFE5E, 'M', '〕'),
     (0xFE5F, '3', '#'),
     (0xFE60, '3', '&'),
@@ -5202,10 +5219,6 @@ def _seg_49():
     (0xFE64, '3', '<'),
     (0xFE65, '3', '>'),
     (0xFE66, '3', '='),
-    ]
-
-def _seg_50():
-    return [
     (0xFE67, 'X'),
     (0xFE68, '3', '\\'),
     (0xFE69, '3', '$'),
@@ -5297,6 +5310,10 @@ def _seg_50():
     (0xFF18, 'M', '8'),
     (0xFF19, 'M', '9'),
     (0xFF1A, '3', ':'),
+    ]
+
+def _seg_51() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFF1B, '3', ';'),
     (0xFF1C, '3', '<'),
     (0xFF1D, '3', '='),
@@ -5306,10 +5323,6 @@ def _seg_50():
     (0xFF21, 'M', 'a'),
     (0xFF22, 'M', 'b'),
     (0xFF23, 'M', 'c'),
-    ]
-
-def _seg_51():
-    return [
     (0xFF24, 'M', 'd'),
     (0xFF25, 'M', 'e'),
     (0xFF26, 'M', 'f'),
@@ -5401,6 +5414,10 @@ def _seg_51():
     (0xFF7C, 'M', 'シ'),
     (0xFF7D, 'M', 'ス'),
     (0xFF7E, 'M', 'セ'),
+    ]
+
+def _seg_52() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFF7F, 'M', 'ソ'),
     (0xFF80, 'M', 'タ'),
     (0xFF81, 'M', 'チ'),
@@ -5410,10 +5427,6 @@ def _seg_51():
     (0xFF85, 'M', 'ナ'),
     (0xFF86, 'M', 'ニ'),
     (0xFF87, 'M', 'ヌ'),
-    ]
-
-def _seg_52():
-    return [
     (0xFF88, 'M', 'ネ'),
     (0xFF89, 'M', 'ノ'),
     (0xFF8A, 'M', 'ハ'),
@@ -5505,6 +5518,10 @@ def _seg_52():
     (0xFFE7, 'X'),
     (0xFFE8, 'M', '│'),
     (0xFFE9, 'M', '←'),
+    ]
+
+def _seg_53() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0xFFEA, 'M', '↑'),
     (0xFFEB, 'M', '→'),
     (0xFFEC, 'M', '↓'),
@@ -5514,10 +5531,6 @@ def _seg_52():
     (0x10000, 'V'),
     (0x1000C, 'X'),
     (0x1000D, 'V'),
-    ]
-
-def _seg_53():
-    return [
     (0x10027, 'X'),
     (0x10028, 'V'),
     (0x1003B, 'X'),
@@ -5609,6 +5622,10 @@ def _seg_53():
     (0x104B3, 'M', '𐓛'),
     (0x104B4, 'M', '𐓜'),
     (0x104B5, 'M', '𐓝'),
+    ]
+
+def _seg_54() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x104B6, 'M', '𐓞'),
     (0x104B7, 'M', '𐓟'),
     (0x104B8, 'M', '𐓠'),
@@ -5618,10 +5635,6 @@ def _seg_53():
     (0x104BC, 'M', '𐓤'),
     (0x104BD, 'M', '𐓥'),
     (0x104BE, 'M', '𐓦'),
-    ]
-
-def _seg_54():
-    return [
     (0x104BF, 'M', '𐓧'),
     (0x104C0, 'M', '𐓨'),
     (0x104C1, 'M', '𐓩'),
@@ -5651,13 +5664,123 @@ def _seg_54():
     (0x10530, 'V'),
     (0x10564, 'X'),
     (0x1056F, 'V'),
-    (0x10570, 'X'),
+    (0x10570, 'M', '𐖗'),
+    (0x10571, 'M', '𐖘'),
+    (0x10572, 'M', '𐖙'),
+    (0x10573, 'M', '𐖚'),
+    (0x10574, 'M', '𐖛'),
+    (0x10575, 'M', '𐖜'),
+    (0x10576, 'M', '𐖝'),
+    (0x10577, 'M', '𐖞'),
+    (0x10578, 'M', '𐖟'),
+    (0x10579, 'M', '𐖠'),
+    (0x1057A, 'M', '𐖡'),
+    (0x1057B, 'X'),
+    (0x1057C, 'M', '𐖣'),
+    (0x1057D, 'M', '𐖤'),
+    (0x1057E, 'M', '𐖥'),
+    (0x1057F, 'M', '𐖦'),
+    (0x10580, 'M', '𐖧'),
+    (0x10581, 'M', '𐖨'),
+    (0x10582, 'M', '𐖩'),
+    (0x10583, 'M', '𐖪'),
+    (0x10584, 'M', '𐖫'),
+    (0x10585, 'M', '𐖬'),
+    (0x10586, 'M', '𐖭'),
+    (0x10587, 'M', '𐖮'),
+    (0x10588, 'M', '𐖯'),
+    (0x10589, 'M', '𐖰'),
+    (0x1058A, 'M', '𐖱'),
+    (0x1058B, 'X'),
+    (0x1058C, 'M', '𐖳'),
+    (0x1058D, 'M', '𐖴'),
+    (0x1058E, 'M', '𐖵'),
+    (0x1058F, 'M', '𐖶'),
+    (0x10590, 'M', '𐖷'),
+    (0x10591, 'M', '𐖸'),
+    (0x10592, 'M', '𐖹'),
+    (0x10593, 'X'),
+    (0x10594, 'M', '𐖻'),
+    (0x10595, 'M', '𐖼'),
+    (0x10596, 'X'),
+    (0x10597, 'V'),
+    (0x105A2, 'X'),
+    (0x105A3, 'V'),
+    (0x105B2, 'X'),
+    (0x105B3, 'V'),
+    (0x105BA, 'X'),
+    (0x105BB, 'V'),
+    (0x105BD, 'X'),
     (0x10600, 'V'),
     (0x10737, 'X'),
     (0x10740, 'V'),
     (0x10756, 'X'),
     (0x10760, 'V'),
     (0x10768, 'X'),
+    (0x10780, 'V'),
+    (0x10781, 'M', 'ː'),
+    (0x10782, 'M', 'ˑ'),
+    (0x10783, 'M', 'æ'),
+    (0x10784, 'M', 'ʙ'),
+    (0x10785, 'M', 'ɓ'),
+    (0x10786, 'X'),
+    (0x10787, 'M', 'ʣ'),
+    (0x10788, 'M', 'ꭦ'),
+    ]
+
+def _seg_55() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
+    (0x10789, 'M', 'ʥ'),
+    (0x1078A, 'M', 'ʤ'),
+    (0x1078B, 'M', 'ɖ'),
+    (0x1078C, 'M', 'ɗ'),
+    (0x1078D, 'M', 'ᶑ'),
+    (0x1078E, 'M', 'ɘ'),
+    (0x1078F, 'M', 'ɞ'),
+    (0x10790, 'M', 'ʩ'),
+    (0x10791, 'M', 'ɤ'),
+    (0x10792, 'M', 'ɢ'),
+    (0x10793, 'M', 'ɠ'),
+    (0x10794, 'M', 'ʛ'),
+    (0x10795, 'M', 'ħ'),
+    (0x10796, 'M', 'ʜ'),
+    (0x10797, 'M', 'ɧ'),
+    (0x10798, 'M', 'ʄ'),
+    (0x10799, 'M', 'ʪ'),
+    (0x1079A, 'M', 'ʫ'),
+    (0x1079B, 'M', 'ɬ'),
+    (0x1079C, 'M', '𝼄'),
+    (0x1079D, 'M', 'ꞎ'),
+    (0x1079E, 'M', 'ɮ'),
+    (0x1079F, 'M', '𝼅'),
+    (0x107A0, 'M', 'ʎ'),
+    (0x107A1, 'M', '𝼆'),
+    (0x107A2, 'M', 'ø'),
+    (0x107A3, 'M', 'ɶ'),
+    (0x107A4, 'M', 'ɷ'),
+    (0x107A5, 'M', 'q'),
+    (0x107A6, 'M', 'ɺ'),
+    (0x107A7, 'M', '𝼈'),
+    (0x107A8, 'M', 'ɽ'),
+    (0x107A9, 'M', 'ɾ'),
+    (0x107AA, 'M', 'ʀ'),
+    (0x107AB, 'M', 'ʨ'),
+    (0x107AC, 'M', 'ʦ'),
+    (0x107AD, 'M', 'ꭧ'),
+    (0x107AE, 'M', 'ʧ'),
+    (0x107AF, 'M', 'ʈ'),
+    (0x107B0, 'M', 'ⱱ'),
+    (0x107B1, 'X'),
+    (0x107B2, 'M', 'ʏ'),
+    (0x107B3, 'M', 'ʡ'),
+    (0x107B4, 'M', 'ʢ'),
+    (0x107B5, 'M', 'ʘ'),
+    (0x107B6, 'M', 'ǀ'),
+    (0x107B7, 'M', 'ǁ'),
+    (0x107B8, 'M', 'ǂ'),
+    (0x107B9, 'M', '𝼊'),
+    (0x107BA, 'M', '𝼞'),
+    (0x107BB, 'X'),
     (0x10800, 'V'),
     (0x10806, 'X'),
     (0x10808, 'V'),
@@ -5707,6 +5830,10 @@ def _seg_54():
     (0x10A60, 'V'),
     (0x10AA0, 'X'),
     (0x10AC0, 'V'),
+    ]
+
+def _seg_56() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x10AE7, 'X'),
     (0x10AEB, 'V'),
     (0x10AF7, 'X'),
@@ -5722,10 +5849,6 @@ def _seg_54():
     (0x10B9D, 'X'),
     (0x10BA9, 'V'),
     (0x10BB0, 'X'),
-    ]
-
-def _seg_55():
-    return [
     (0x10C00, 'V'),
     (0x10C49, 'X'),
     (0x10C80, 'M', '𐳀'),
@@ -5794,10 +5917,12 @@ def _seg_55():
     (0x10EAE, 'X'),
     (0x10EB0, 'V'),
     (0x10EB2, 'X'),
-    (0x10F00, 'V'),
+    (0x10EFD, 'V'),
     (0x10F28, 'X'),
     (0x10F30, 'V'),
     (0x10F5A, 'X'),
+    (0x10F70, 'V'),
+    (0x10F8A, 'X'),
     (0x10FB0, 'V'),
     (0x10FCC, 'X'),
     (0x10FE0, 'V'),
@@ -5805,11 +5930,15 @@ def _seg_55():
     (0x11000, 'V'),
     (0x1104E, 'X'),
     (0x11052, 'V'),
-    (0x11070, 'X'),
+    (0x11076, 'X'),
     (0x1107F, 'V'),
     (0x110BD, 'X'),
     (0x110BE, 'V'),
-    (0x110C2, 'X'),
+    ]
+
+def _seg_57() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
+    (0x110C3, 'X'),
     (0x110D0, 'V'),
     (0x110E9, 'X'),
     (0x110F0, 'V'),
@@ -5826,12 +5955,8 @@ def _seg_55():
     (0x111F5, 'X'),
     (0x11200, 'V'),
     (0x11212, 'X'),
-    ]
-
-def _seg_56():
-    return [
     (0x11213, 'V'),
-    (0x1123F, 'X'),
+    (0x11242, 'X'),
     (0x11280, 'V'),
     (0x11287, 'X'),
     (0x11288, 'V'),
@@ -5895,7 +6020,7 @@ def _seg_56():
     (0x11660, 'V'),
     (0x1166D, 'X'),
     (0x11680, 'V'),
-    (0x116B9, 'X'),
+    (0x116BA, 'X'),
     (0x116C0, 'V'),
     (0x116CA, 'X'),
     (0x11700, 'V'),
@@ -5903,7 +6028,7 @@ def _seg_56():
     (0x1171D, 'V'),
     (0x1172C, 'X'),
     (0x11730, 'V'),
-    (0x11740, 'X'),
+    (0x11747, 'X'),
     (0x11800, 'V'),
     (0x1183C, 'X'),
     (0x118A0, 'M', '𑣀'),
@@ -5913,6 +6038,10 @@ def _seg_56():
     (0x118A4, 'M', '𑣄'),
     (0x118A5, 'M', '𑣅'),
     (0x118A6, 'M', '𑣆'),
+    ]
+
+def _seg_58() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x118A7, 'M', '𑣇'),
     (0x118A8, 'M', '𑣈'),
     (0x118A9, 'M', '𑣉'),
@@ -5930,10 +6059,6 @@ def _seg_56():
     (0x118B5, 'M', '𑣕'),
     (0x118B6, 'M', '𑣖'),
     (0x118B7, 'M', '𑣗'),
-    ]
-
-def _seg_57():
-    return [
     (0x118B8, 'M', '𑣘'),
     (0x118B9, 'M', '𑣙'),
     (0x118BA, 'M', '𑣚'),
@@ -5970,8 +6095,10 @@ def _seg_57():
     (0x11A48, 'X'),
     (0x11A50, 'V'),
     (0x11AA3, 'X'),
-    (0x11AC0, 'V'),
+    (0x11AB0, 'V'),
     (0x11AF9, 'X'),
+    (0x11B00, 'V'),
+    (0x11B0A, 'X'),
     (0x11C00, 'V'),
     (0x11C09, 'X'),
     (0x11C0A, 'V'),
@@ -6014,6 +6141,16 @@ def _seg_57():
     (0x11DAA, 'X'),
     (0x11EE0, 'V'),
     (0x11EF9, 'X'),
+    (0x11F00, 'V'),
+    ]
+
+def _seg_59() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
+    (0x11F11, 'X'),
+    (0x11F12, 'V'),
+    (0x11F3B, 'X'),
+    (0x11F3E, 'V'),
+    (0x11F5A, 'X'),
     (0x11FB0, 'V'),
     (0x11FB1, 'X'),
     (0x11FC0, 'V'),
@@ -6026,22 +6163,24 @@ def _seg_57():
     (0x12475, 'X'),
     (0x12480, 'V'),
     (0x12544, 'X'),
+    (0x12F90, 'V'),
+    (0x12FF3, 'X'),
     (0x13000, 'V'),
-    (0x1342F, 'X'),
+    (0x13430, 'X'),
+    (0x13440, 'V'),
+    (0x13456, 'X'),
     (0x14400, 'V'),
     (0x14647, 'X'),
     (0x16800, 'V'),
     (0x16A39, 'X'),
     (0x16A40, 'V'),
     (0x16A5F, 'X'),
-    ]
-
-def _seg_58():
-    return [
     (0x16A60, 'V'),
     (0x16A6A, 'X'),
     (0x16A6E, 'V'),
-    (0x16A70, 'X'),
+    (0x16ABF, 'X'),
+    (0x16AC0, 'V'),
+    (0x16ACA, 'X'),
     (0x16AD0, 'V'),
     (0x16AEE, 'X'),
     (0x16AF0, 'V'),
@@ -6106,10 +6245,24 @@ def _seg_58():
     (0x18CD6, 'X'),
     (0x18D00, 'V'),
     (0x18D09, 'X'),
+    (0x1AFF0, 'V'),
+    ]
+
+def _seg_60() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
+    (0x1AFF4, 'X'),
+    (0x1AFF5, 'V'),
+    (0x1AFFC, 'X'),
+    (0x1AFFD, 'V'),
+    (0x1AFFF, 'X'),
     (0x1B000, 'V'),
-    (0x1B11F, 'X'),
+    (0x1B123, 'X'),
+    (0x1B132, 'V'),
+    (0x1B133, 'X'),
     (0x1B150, 'V'),
     (0x1B153, 'X'),
+    (0x1B155, 'V'),
+    (0x1B156, 'X'),
     (0x1B164, 'V'),
     (0x1B168, 'X'),
     (0x1B170, 'V'),
@@ -6125,6 +6278,12 @@ def _seg_58():
     (0x1BC9C, 'V'),
     (0x1BCA0, 'I'),
     (0x1BCA4, 'X'),
+    (0x1CF00, 'V'),
+    (0x1CF2E, 'X'),
+    (0x1CF30, 'V'),
+    (0x1CF47, 'X'),
+    (0x1CF50, 'V'),
+    (0x1CFC4, 'X'),
     (0x1D000, 'V'),
     (0x1D0F6, 'X'),
     (0x1D100, 'V'),
@@ -6138,10 +6297,6 @@ def _seg_58():
     (0x1D163, 'M', '𝅘𝅥𝅱'),
     (0x1D164, 'M', '𝅘𝅥𝅲'),
     (0x1D165, 'V'),
-    ]
-
-def _seg_59():
-    return [
     (0x1D173, 'X'),
     (0x1D17B, 'V'),
     (0x1D1BB, 'M', '𝆹𝅥'),
@@ -6151,9 +6306,11 @@ def _seg_59():
     (0x1D1BF, 'M', '𝆹𝅥𝅯'),
     (0x1D1C0, 'M', '𝆺𝅥𝅯'),
     (0x1D1C1, 'V'),
-    (0x1D1E9, 'X'),
+    (0x1D1EB, 'X'),
     (0x1D200, 'V'),
     (0x1D246, 'X'),
+    (0x1D2C0, 'V'),
+    (0x1D2D4, 'X'),
     (0x1D2E0, 'V'),
     (0x1D2F4, 'X'),
     (0x1D300, 'V'),
@@ -6193,6 +6350,10 @@ def _seg_59():
     (0x1D41E, 'M', 'e'),
     (0x1D41F, 'M', 'f'),
     (0x1D420, 'M', 'g'),
+    ]
+
+def _seg_61() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D421, 'M', 'h'),
     (0x1D422, 'M', 'i'),
     (0x1D423, 'M', 'j'),
@@ -6242,10 +6403,6 @@ def _seg_59():
     (0x1D44F, 'M', 'b'),
     (0x1D450, 'M', 'c'),
     (0x1D451, 'M', 'd'),
-    ]
-
-def _seg_60():
-    return [
     (0x1D452, 'M', 'e'),
     (0x1D453, 'M', 'f'),
     (0x1D454, 'M', 'g'),
@@ -6297,6 +6454,10 @@ def _seg_60():
     (0x1D482, 'M', 'a'),
     (0x1D483, 'M', 'b'),
     (0x1D484, 'M', 'c'),
+    ]
+
+def _seg_62() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D485, 'M', 'd'),
     (0x1D486, 'M', 'e'),
     (0x1D487, 'M', 'f'),
@@ -6346,10 +6507,6 @@ def _seg_60():
     (0x1D4B6, 'M', 'a'),
     (0x1D4B7, 'M', 'b'),
     (0x1D4B8, 'M', 'c'),
-    ]
-
-def _seg_61():
-    return [
     (0x1D4B9, 'M', 'd'),
     (0x1D4BA, 'X'),
     (0x1D4BB, 'M', 'f'),
@@ -6401,6 +6558,10 @@ def _seg_61():
     (0x1D4E9, 'M', 'z'),
     (0x1D4EA, 'M', 'a'),
     (0x1D4EB, 'M', 'b'),
+    ]
+
+def _seg_63() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D4EC, 'M', 'c'),
     (0x1D4ED, 'M', 'd'),
     (0x1D4EE, 'M', 'e'),
@@ -6450,10 +6611,6 @@ def _seg_61():
     (0x1D51B, 'M', 'x'),
     (0x1D51C, 'M', 'y'),
     (0x1D51D, 'X'),
-    ]
-
-def _seg_62():
-    return [
     (0x1D51E, 'M', 'a'),
     (0x1D51F, 'M', 'b'),
     (0x1D520, 'M', 'c'),
@@ -6505,6 +6662,10 @@ def _seg_62():
     (0x1D550, 'M', 'y'),
     (0x1D551, 'X'),
     (0x1D552, 'M', 'a'),
+    ]
+
+def _seg_64() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D553, 'M', 'b'),
     (0x1D554, 'M', 'c'),
     (0x1D555, 'M', 'd'),
@@ -6554,10 +6715,6 @@ def _seg_62():
     (0x1D581, 'M', 'v'),
     (0x1D582, 'M', 'w'),
     (0x1D583, 'M', 'x'),
-    ]
-
-def _seg_63():
-    return [
     (0x1D584, 'M', 'y'),
     (0x1D585, 'M', 'z'),
     (0x1D586, 'M', 'a'),
@@ -6609,6 +6766,10 @@ def _seg_63():
     (0x1D5B4, 'M', 'u'),
     (0x1D5B5, 'M', 'v'),
     (0x1D5B6, 'M', 'w'),
+    ]
+
+def _seg_65() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D5B7, 'M', 'x'),
     (0x1D5B8, 'M', 'y'),
     (0x1D5B9, 'M', 'z'),
@@ -6658,10 +6819,6 @@ def _seg_63():
     (0x1D5E5, 'M', 'r'),
     (0x1D5E6, 'M', 's'),
     (0x1D5E7, 'M', 't'),
-    ]
-
-def _seg_64():
-    return [
     (0x1D5E8, 'M', 'u'),
     (0x1D5E9, 'M', 'v'),
     (0x1D5EA, 'M', 'w'),
@@ -6713,6 +6870,10 @@ def _seg_64():
     (0x1D618, 'M', 'q'),
     (0x1D619, 'M', 'r'),
     (0x1D61A, 'M', 's'),
+    ]
+
+def _seg_66() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D61B, 'M', 't'),
     (0x1D61C, 'M', 'u'),
     (0x1D61D, 'M', 'v'),
@@ -6762,10 +6923,6 @@ def _seg_64():
     (0x1D649, 'M', 'n'),
     (0x1D64A, 'M', 'o'),
     (0x1D64B, 'M', 'p'),
-    ]
-
-def _seg_65():
-    return [
     (0x1D64C, 'M', 'q'),
     (0x1D64D, 'M', 'r'),
     (0x1D64E, 'M', 's'),
@@ -6817,6 +6974,10 @@ def _seg_65():
     (0x1D67C, 'M', 'm'),
     (0x1D67D, 'M', 'n'),
     (0x1D67E, 'M', 'o'),
+    ]
+
+def _seg_67() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D67F, 'M', 'p'),
     (0x1D680, 'M', 'q'),
     (0x1D681, 'M', 'r'),
@@ -6866,10 +7027,6 @@ def _seg_65():
     (0x1D6AE, 'M', 'η'),
     (0x1D6AF, 'M', 'θ'),
     (0x1D6B0, 'M', 'ι'),
-    ]
-
-def _seg_66():
-    return [
     (0x1D6B1, 'M', 'κ'),
     (0x1D6B2, 'M', 'λ'),
     (0x1D6B3, 'M', 'μ'),
@@ -6921,6 +7078,10 @@ def _seg_66():
     (0x1D6E2, 'M', 'α'),
     (0x1D6E3, 'M', 'β'),
     (0x1D6E4, 'M', 'γ'),
+    ]
+
+def _seg_68() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D6E5, 'M', 'δ'),
     (0x1D6E6, 'M', 'ε'),
     (0x1D6E7, 'M', 'ζ'),
@@ -6970,10 +7131,6 @@ def _seg_66():
     (0x1D714, 'M', 'ω'),
     (0x1D715, 'M', '∂'),
     (0x1D716, 'M', 'ε'),
-    ]
-
-def _seg_67():
-    return [
     (0x1D717, 'M', 'θ'),
     (0x1D718, 'M', 'κ'),
     (0x1D719, 'M', 'φ'),
@@ -7025,6 +7182,10 @@ def _seg_67():
     (0x1D747, 'M', 'σ'),
     (0x1D749, 'M', 'τ'),
     (0x1D74A, 'M', 'υ'),
+    ]
+
+def _seg_69() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D74B, 'M', 'φ'),
     (0x1D74C, 'M', 'χ'),
     (0x1D74D, 'M', 'ψ'),
@@ -7074,10 +7235,6 @@ def _seg_67():
     (0x1D779, 'M', 'κ'),
     (0x1D77A, 'M', 'λ'),
     (0x1D77B, 'M', 'μ'),
-    ]
-
-def _seg_68():
-    return [
     (0x1D77C, 'M', 'ν'),
     (0x1D77D, 'M', 'ξ'),
     (0x1D77E, 'M', 'ο'),
@@ -7129,6 +7286,10 @@ def _seg_68():
     (0x1D7AD, 'M', 'δ'),
     (0x1D7AE, 'M', 'ε'),
     (0x1D7AF, 'M', 'ζ'),
+    ]
+
+def _seg_70() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1D7B0, 'M', 'η'),
     (0x1D7B1, 'M', 'θ'),
     (0x1D7B2, 'M', 'ι'),
@@ -7178,10 +7339,6 @@ def _seg_68():
     (0x1D7E1, 'M', '9'),
     (0x1D7E2, 'M', '0'),
     (0x1D7E3, 'M', '1'),
-    ]
-
-def _seg_69():
-    return [
     (0x1D7E4, 'M', '2'),
     (0x1D7E5, 'M', '3'),
     (0x1D7E6, 'M', '4'),
@@ -7216,6 +7373,10 @@ def _seg_69():
     (0x1DAA0, 'X'),
     (0x1DAA1, 'V'),
     (0x1DAB0, 'X'),
+    (0x1DF00, 'V'),
+    (0x1DF1F, 'X'),
+    (0x1DF25, 'V'),
+    (0x1DF2B, 'X'),
     (0x1E000, 'V'),
     (0x1E007, 'X'),
     (0x1E008, 'V'),
@@ -7226,6 +7387,75 @@ def _seg_69():
     (0x1E025, 'X'),
     (0x1E026, 'V'),
     (0x1E02B, 'X'),
+    (0x1E030, 'M', 'а'),
+    (0x1E031, 'M', 'б'),
+    (0x1E032, 'M', 'в'),
+    ]
+
+def _seg_71() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
+    (0x1E033, 'M', 'г'),
+    (0x1E034, 'M', 'д'),
+    (0x1E035, 'M', 'е'),
+    (0x1E036, 'M', 'ж'),
+    (0x1E037, 'M', 'з'),
+    (0x1E038, 'M', 'и'),
+    (0x1E039, 'M', 'к'),
+    (0x1E03A, 'M', 'л'),
+    (0x1E03B, 'M', 'м'),
+    (0x1E03C, 'M', 'о'),
+    (0x1E03D, 'M', 'п'),
+    (0x1E03E, 'M', 'р'),
+    (0x1E03F, 'M', 'с'),
+    (0x1E040, 'M', 'т'),
+    (0x1E041, 'M', 'у'),
+    (0x1E042, 'M', 'ф'),
+    (0x1E043, 'M', 'х'),
+    (0x1E044, 'M', 'ц'),
+    (0x1E045, 'M', 'ч'),
+    (0x1E046, 'M', 'ш'),
+    (0x1E047, 'M', 'ы'),
+    (0x1E048, 'M', 'э'),
+    (0x1E049, 'M', 'ю'),
+    (0x1E04A, 'M', 'ꚉ'),
+    (0x1E04B, 'M', 'ә'),
+    (0x1E04C, 'M', 'і'),
+    (0x1E04D, 'M', 'ј'),
+    (0x1E04E, 'M', 'ө'),
+    (0x1E04F, 'M', 'ү'),
+    (0x1E050, 'M', 'ӏ'),
+    (0x1E051, 'M', 'а'),
+    (0x1E052, 'M', 'б'),
+    (0x1E053, 'M', 'в'),
+    (0x1E054, 'M', 'г'),
+    (0x1E055, 'M', 'д'),
+    (0x1E056, 'M', 'е'),
+    (0x1E057, 'M', 'ж'),
+    (0x1E058, 'M', 'з'),
+    (0x1E059, 'M', 'и'),
+    (0x1E05A, 'M', 'к'),
+    (0x1E05B, 'M', 'л'),
+    (0x1E05C, 'M', 'о'),
+    (0x1E05D, 'M', 'п'),
+    (0x1E05E, 'M', 'с'),
+    (0x1E05F, 'M', 'у'),
+    (0x1E060, 'M', 'ф'),
+    (0x1E061, 'M', 'х'),
+    (0x1E062, 'M', 'ц'),
+    (0x1E063, 'M', 'ч'),
+    (0x1E064, 'M', 'ш'),
+    (0x1E065, 'M', 'ъ'),
+    (0x1E066, 'M', 'ы'),
+    (0x1E067, 'M', 'ґ'),
+    (0x1E068, 'M', 'і'),
+    (0x1E069, 'M', 'ѕ'),
+    (0x1E06A, 'M', 'џ'),
+    (0x1E06B, 'M', 'ҫ'),
+    (0x1E06C, 'M', 'ꙑ'),
+    (0x1E06D, 'M', 'ұ'),
+    (0x1E06E, 'X'),
+    (0x1E08F, 'V'),
+    (0x1E090, 'X'),
     (0x1E100, 'V'),
     (0x1E12D, 'X'),
     (0x1E130, 'V'),
@@ -7234,10 +7464,22 @@ def _seg_69():
     (0x1E14A, 'X'),
     (0x1E14E, 'V'),
     (0x1E150, 'X'),
+    (0x1E290, 'V'),
+    (0x1E2AF, 'X'),
     (0x1E2C0, 'V'),
     (0x1E2FA, 'X'),
     (0x1E2FF, 'V'),
     (0x1E300, 'X'),
+    (0x1E4D0, 'V'),
+    (0x1E4FA, 'X'),
+    (0x1E7E0, 'V'),
+    (0x1E7E7, 'X'),
+    (0x1E7E8, 'V'),
+    (0x1E7EC, 'X'),
+    (0x1E7ED, 'V'),
+    (0x1E7EF, 'X'),
+    (0x1E7F0, 'V'),
+    (0x1E7FF, 'X'),
     (0x1E800, 'V'),
     (0x1E8C5, 'X'),
     (0x1E8C7, 'V'),
@@ -7252,6 +7494,10 @@ def _seg_69():
     (0x1E907, 'M', '𞤩'),
     (0x1E908, 'M', '𞤪'),
     (0x1E909, 'M', '𞤫'),
+    ]
+
+def _seg_72() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1E90A, 'M', '𞤬'),
     (0x1E90B, 'M', '𞤭'),
     (0x1E90C, 'M', '𞤮'),
@@ -7282,10 +7528,6 @@ def _seg_69():
     (0x1E95A, 'X'),
     (0x1E95E, 'V'),
     (0x1E960, 'X'),
-    ]
-
-def _seg_70():
-    return [
     (0x1EC71, 'V'),
     (0x1ECB5, 'X'),
     (0x1ED01, 'V'),
@@ -7356,6 +7598,10 @@ def _seg_70():
     (0x1EE48, 'X'),
     (0x1EE49, 'M', 'ي'),
     (0x1EE4A, 'X'),
+    ]
+
+def _seg_73() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1EE4B, 'M', 'ل'),
     (0x1EE4C, 'X'),
     (0x1EE4D, 'M', 'ن'),
@@ -7386,10 +7632,6 @@ def _seg_70():
     (0x1EE68, 'M', 'ط'),
     (0x1EE69, 'M', 'ي'),
     (0x1EE6A, 'M', 'ك'),
-    ]
-
-def _seg_71():
-    return [
     (0x1EE6B, 'X'),
     (0x1EE6C, 'M', 'م'),
     (0x1EE6D, 'M', 'ن'),
@@ -7460,6 +7702,10 @@ def _seg_71():
     (0x1EEB2, 'M', 'ق'),
     (0x1EEB3, 'M', 'ر'),
     (0x1EEB4, 'M', 'ش'),
+    ]
+
+def _seg_74() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1EEB5, 'M', 'ت'),
     (0x1EEB6, 'M', 'ث'),
     (0x1EEB7, 'M', 'خ'),
@@ -7490,10 +7736,6 @@ def _seg_71():
     (0x1F106, '3', '5,'),
     (0x1F107, '3', '6,'),
     (0x1F108, '3', '7,'),
-    ]
-
-def _seg_72():
-    return [
     (0x1F109, '3', '8,'),
     (0x1F10A, '3', '9,'),
     (0x1F10B, 'V'),
@@ -7564,6 +7806,10 @@ def _seg_72():
     (0x1F150, 'V'),
     (0x1F16A, 'M', 'mc'),
     (0x1F16B, 'M', 'md'),
+    ]
+
+def _seg_75() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1F16C, 'M', 'mr'),
     (0x1F16D, 'V'),
     (0x1F190, 'M', 'dj'),
@@ -7594,10 +7840,6 @@ def _seg_72():
     (0x1F221, 'M', '終'),
     (0x1F222, 'M', '生'),
     (0x1F223, 'M', '販'),
-    ]
-
-def _seg_73():
-    return [
     (0x1F224, 'M', '声'),
     (0x1F225, 'M', '吹'),
     (0x1F226, 'M', '演'),
@@ -7640,16 +7882,18 @@ def _seg_73():
     (0x1F266, 'X'),
     (0x1F300, 'V'),
     (0x1F6D8, 'X'),
-    (0x1F6E0, 'V'),
+    (0x1F6DC, 'V'),
     (0x1F6ED, 'X'),
     (0x1F6F0, 'V'),
     (0x1F6FD, 'X'),
     (0x1F700, 'V'),
-    (0x1F774, 'X'),
-    (0x1F780, 'V'),
-    (0x1F7D9, 'X'),
+    (0x1F777, 'X'),
+    (0x1F77B, 'V'),
+    (0x1F7DA, 'X'),
     (0x1F7E0, 'V'),
     (0x1F7EC, 'X'),
+    (0x1F7F0, 'V'),
+    (0x1F7F1, 'X'),
     (0x1F800, 'V'),
     (0x1F80C, 'X'),
     (0x1F810, 'V'),
@@ -7663,27 +7907,27 @@ def _seg_73():
     (0x1F8B0, 'V'),
     (0x1F8B2, 'X'),
     (0x1F900, 'V'),
-    (0x1F979, 'X'),
-    (0x1F97A, 'V'),
-    (0x1F9CC, 'X'),
-    (0x1F9CD, 'V'),
     (0x1FA54, 'X'),
     (0x1FA60, 'V'),
     (0x1FA6E, 'X'),
+    ]
+
+def _seg_76() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x1FA70, 'V'),
-    (0x1FA75, 'X'),
-    (0x1FA78, 'V'),
-    (0x1FA7B, 'X'),
+    (0x1FA7D, 'X'),
     (0x1FA80, 'V'),
-    (0x1FA87, 'X'),
+    (0x1FA89, 'X'),
     (0x1FA90, 'V'),
-    (0x1FAA9, 'X'),
-    (0x1FAB0, 'V'),
-    (0x1FAB7, 'X'),
-    (0x1FAC0, 'V'),
-    (0x1FAC3, 'X'),
-    (0x1FAD0, 'V'),
-    (0x1FAD7, 'X'),
+    (0x1FABE, 'X'),
+    (0x1FABF, 'V'),
+    (0x1FAC6, 'X'),
+    (0x1FACE, 'V'),
+    (0x1FADC, 'X'),
+    (0x1FAE0, 'V'),
+    (0x1FAE9, 'X'),
+    (0x1FAF0, 'V'),
+    (0x1FAF9, 'X'),
     (0x1FB00, 'V'),
     (0x1FB93, 'X'),
     (0x1FB94, 'V'),
@@ -7698,15 +7942,11 @@ def _seg_73():
     (0x1FBF7, 'M', '7'),
     (0x1FBF8, 'M', '8'),
     (0x1FBF9, 'M', '9'),
-    ]
-
-def _seg_74():
-    return [
     (0x1FBFA, 'X'),
     (0x20000, 'V'),
-    (0x2A6DE, 'X'),
+    (0x2A6E0, 'X'),
     (0x2A700, 'V'),
-    (0x2B735, 'X'),
+    (0x2B73A, 'X'),
     (0x2B740, 'V'),
     (0x2B81E, 'X'),
     (0x2B820, 'V'),
@@ -7774,6 +8014,10 @@ def _seg_74():
     (0x2F83C, 'M', '咞'),
     (0x2F83D, 'M', '吸'),
     (0x2F83E, 'M', '呈'),
+    ]
+
+def _seg_77() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F83F, 'M', '周'),
     (0x2F840, 'M', '咢'),
     (0x2F841, 'M', '哶'),
@@ -7802,10 +8046,6 @@ def _seg_74():
     (0x2F859, 'M', '𡓤'),
     (0x2F85A, 'M', '売'),
     (0x2F85B, 'M', '壷'),
-    ]
-
-def _seg_75():
-    return [
     (0x2F85C, 'M', '夆'),
     (0x2F85D, 'M', '多'),
     (0x2F85E, 'M', '夢'),
@@ -7878,6 +8118,10 @@ def _seg_75():
     (0x2F8A4, 'M', '𢛔'),
     (0x2F8A5, 'M', '惇'),
     (0x2F8A6, 'M', '慈'),
+    ]
+
+def _seg_78() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F8A7, 'M', '慌'),
     (0x2F8A8, 'M', '慎'),
     (0x2F8A9, 'M', '慌'),
@@ -7906,10 +8150,6 @@ def _seg_75():
     (0x2F8C0, 'M', '揅'),
     (0x2F8C1, 'M', '掩'),
     (0x2F8C2, 'M', '㨮'),
-    ]
-
-def _seg_76():
-    return [
     (0x2F8C3, 'M', '摩'),
     (0x2F8C4, 'M', '摾'),
     (0x2F8C5, 'M', '撝'),
@@ -7982,6 +8222,10 @@ def _seg_76():
     (0x2F908, 'M', '港'),
     (0x2F909, 'M', '湮'),
     (0x2F90A, 'M', '㴳'),
+    ]
+
+def _seg_79() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F90B, 'M', '滋'),
     (0x2F90C, 'M', '滇'),
     (0x2F90D, 'M', '𣻑'),
@@ -8010,10 +8254,6 @@ def _seg_76():
     (0x2F924, 'M', '犀'),
     (0x2F925, 'M', '犕'),
     (0x2F926, 'M', '𤜵'),
-    ]
-
-def _seg_77():
-    return [
     (0x2F927, 'M', '𤠔'),
     (0x2F928, 'M', '獺'),
     (0x2F929, 'M', '王'),
@@ -8086,6 +8326,10 @@ def _seg_77():
     (0x2F96F, 'M', '縂'),
     (0x2F970, 'M', '繅'),
     (0x2F971, 'M', '䌴'),
+    ]
+
+def _seg_80() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F972, 'M', '𦈨'),
     (0x2F973, 'M', '𦉇'),
     (0x2F974, 'M', '䍙'),
@@ -8114,10 +8358,6 @@ def _seg_77():
     (0x2F98B, 'M', '舁'),
     (0x2F98C, 'M', '舄'),
     (0x2F98D, 'M', '辞'),
-    ]
-
-def _seg_78():
-    return [
     (0x2F98E, 'M', '䑫'),
     (0x2F98F, 'M', '芑'),
     (0x2F990, 'M', '芋'),
@@ -8190,6 +8430,10 @@ def _seg_78():
     (0x2F9D3, 'M', '𧲨'),
     (0x2F9D4, 'M', '貫'),
     (0x2F9D5, 'M', '賁'),
+    ]
+
+def _seg_81() -> List[Union[Tuple[int, str], Tuple[int, str, str]]]:
+    return [
     (0x2F9D6, 'M', '贛'),
     (0x2F9D7, 'M', '起'),
     (0x2F9D8, 'M', '𧼯'),
@@ -8218,10 +8462,6 @@ def _seg_78():
     (0x2F9EF, 'M', '䦕'),
     (0x2F9F0, 'M', '閷'),
     (0x2F9F1, 'M', '𨵷'),
-    ]
-
-def _seg_79():
-    return [
     (0x2F9F2, 'M', '䧦'),
     (0x2F9F3, 'M', '雃'),
     (0x2F9F4, 'M', '嶲'),
@@ -8268,6 +8508,8 @@ def _seg_79():
     (0x2FA1E, 'X'),
     (0x30000, 'V'),
     (0x3134B, 'X'),
+    (0x31350, 'V'),
+    (0x323B0, 'X'),
     (0xE0100, 'I'),
     (0xE01F0, 'X'),
     ]
@@ -8353,4 +8595,6 @@ uts46data = tuple(
     + _seg_77()
     + _seg_78()
     + _seg_79()
-)
+    + _seg_80()
+    + _seg_81()
+)  # type: Tuple[Union[Tuple[int, str], Tuple[int, str, str]], ...]
diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py b/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py
index d6705e22..1300b866 100644
--- a/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/msgpack/__init__.py
@@ -1,5 +1,4 @@
 # coding: utf-8
-from ._version import version
 from .exceptions import *
 from .ext import ExtType, Timestamp
 
@@ -7,6 +6,10 @@ import os
 import sys
 
 
+version = (1, 0, 5)
+__version__ = "1.0.5"
+
+
 if os.environ.get("MSGPACK_PUREPYTHON") or sys.version_info[0] == 2:
     from .fallback import Packer, unpackb, Unpacker
 else:
diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index add4afe4f30d9337b32aa61801fc95913ccfcd1b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1442
zcmYe~<>g{vU|^UdaWFNGg@NHQh=Ytd7#J8F7#J9eFEB7Lq%fo~<}l<kMlmvi*i1Q0
zAt0JLhdGxeiY1pdij|Qeg(ZbGhb@W?OtVL^r?O>nEZ|IGTgX`Km&%^SmBJ#)kiwqL
zRFsm!kiwC}oy!x&lgk^$o68r)$H<W9P$dBt=SLL}XUJ1yVMrCIT*Sx#f?zdhdLtR~
zm<$+FI8(S<7@`DIxKnsq7@~wycvJXV7@~wzg`-4Ld80&A1*61Lg`&h$Sc4ff`Cl?J
zFfeE`-eNCHEh^5;&(mbQ#i*spbc@}!q9mlUAoUh!NM>$oaY<rs!AnrE_(ci%2D=A1
zI(x?lga)|=M22|y`@LiW8Nz&vEg&&DJGJN*dud)lVsduUEsjtyBef_QqynTLgjpCE
z7+4t?7`#Ejs>Hy+P{NSLkjYTPw1lybv6i`paRFlu^8%(ChJ}m^K>^Je%%I6s6~U#T
zpr8P<K_NdWD>b=9At66OAu%sSp}Z)wBvm1^M4=>KA)&aWC^a!RfeWlUI5kzlDmf>y
zxY#NIq%*ZBK_M-_NFl$VBr`v+SP!hoPm{R_6w9|*!3N!80l8h1<rZW9EjEa0x7f1F
z6N}P|Z?S=-Qj1nH6bUjgF#Kw8wu%WYPAw{qNzF;gEQ;~ZOLZyAEK60;RS5O-408<%
z_6%_hR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy<%#KOTD~s{TOo}Pa
zEJ@V`S(BKaS{zf5S)d<ZmYSE6U!<Q~oDLG#kB`sH%PfhH*DI(j;$dK55C#P!C`=jH
z_!z+=$)HFDg)|6*LLMXw4s8)cXfuLBdjTUTl!F;G8LPs<fdL97^zbc8Eh#O^Qvg|>
znxc?YS&~{zLhx!bfkPMUFioZ+UIqq+B7P773PNx=76~yhFx+AVnV%#J@(jqy3~WUp
zkD+*lnSp@;?iC3J28J4j1q=%rYMDwHYnaj)GZ|{Yo&tNP2kae4`cp{EgZU|~C_fjT
zNc14y2ujQ>PAyhQaIGjQN_0sqNlZ{E&q&RKD^p0$&nrpH%qvz%1*w3903_`oCoqUz
zSd*A0(=C>w)Wnn`PH;vk;sf~~6bQFiQW8rNA)x>c4{%VhLGq6pC@et!WnkxEED{50
zmAJ(b56!7XpisKSm0FRU3Q5hkm_g11sV@TMu3Jp`#kZJ?D~oTjr{<Mq7Uk#NVopyj
zxy1w3AD@|*mVb*QEior2DKR-45=kKU6@d!GD9-p~Xo9=N?U`GUUsU2+RFq!?jz)0I
zfE{#;B_}^I<rXW5EWX8(Qkq+Eixor`Bl!v8F%FyD{FKt1R6CH{i$PhRhmnI(fQf^V
egIS7EjERX+f{}+&ikX9pgOh`Yg^`7cg%JQ-hiTpb

diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/_version.cpython-39.pyc
deleted file mode 100644
index 66be0c12af734ae3353ff772c42306861e6ea582..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 246
zcmYe~<>g{vU|^UdaWGYcfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?_G+UxH*_
zf|R~wVqjqK(`3BGUY1%^oSC1ulA(x|fdNANYH+rS2`x@7Dvn9bNy#jV@y|<jDatHM
zRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKLF3HS}
zNzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+BkFVfE~P6vsD_+Y2#6;$5hu*uC&
ODa}c>1G)G!$i)CgyFxPn

diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/exceptions.cpython-39.pyc
deleted file mode 100644
index db4c9815e830afe6373dd977e3050f29038a7de9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1880
zcmYe~<>g{vU|^UdaWK`Ag@NHQh=Yt-85kHG7#J9eD;O9U+!<0BQW#qpQW#Sinwg^*
z-5FAtQkYv9QkYX2o0+4S+!<0>QdnCUQdq%!W_N}ZwiNajh7|TxmQ==OmMB(th7^tz
z&K8CgPN)c5DoYf*J3|Ur3U>=b3U?}dGjkM2Dnk@!DoYesDt8o53QsVDCT}vbn?P(v
zn7afR7#LC+q8L*cqL@+`qnJ~ef*CZKZ}Erb6(lBSyH+Hp7L;V>=T)6{N-R!QNX|(t
zE>=j(FH$JZ&rMZGg-I7H6eVUBr=}>BXJqE2DwKjXXXd5rad9aqC@A>(hqzinMHO-r
zD<P^8+7<FkGE$2aN-`4j6pBleAhzVEf%T#}L{CA%Gfkl~zf_?-F|S0SBwrypu_QS|
zAu%UMA+@L|zeoon0M-k4zCvbRaY<@oiXK?lZzanuj`;Yz#N5>Q_*-1@@wxdar8yur
zPkek~X<`mkhCMz$B|kYnekDT@I|BoR_|@cW6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu
z5bEa{<{A|28R8hM;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfOSzMBt9g~_@
z7UPqd6jPj8lBx>|@5J=f;+TTW0{!^1)V!4ZBK_Rrbdb0{BBb>SDvLm|2g1cn3=9k$
zj9@<QDCR+l;$Q|%rdwQ2rD<uYMQ)`zIesgdi<m*aV*wGM^osB-gv9}p;ACK603~&p
zl^{MzR&x56miVW+B$g!l6@d(bm<<otBCsvo3=9l>pzH$m7>JMC7944p+bzE+H?hPO
zlp3nUJoCyDb23vDpdkrLyt#=benlV~u(|;hTtY~00P#t716ObfDEok&z!j38uaK8o
zT#}lC$68(n1_m)CYe9SrYe9|%7bglRaSF<|pn@cdB?Vl7M6sr@1v6-}-{N$wC@D$=
z1$tF8oT-qBlwDKv6hL_|6(m?vl$e>5nU}7Rl30=m&AK5OnZ-yM6<I4Nr|0M8R4U}>
zrRo-E<d-OD<mHzr6qgjGCgx`5rE7vS8>B3NWV~chLIV{)APi!I{NoJrG$<--7;6~f
z8ETkn7~&aI7=jrz8T~YwZgD^iNKLuLnhNraCi5+p;?$h9B7RV^1nEPHMNlFFW$nzo
z%#!$cRglS`WX-_H##ki;4*<RRc!+{zP$mMo1%yFt5C*#kq$`CHlvn(!<RC84NYYd&
zN=;79EK5yM06PT|PGIXb8H)r#?m<n@x7g$3i%W{)<26Ap0eO~zu}Tox9bj2MO*Zr_
z$ObYDlnRT4K`ex^U>3-mMWB2l2Qn9=mV=Rnje`X&=BLREig#$i4K5psI6;PhGSe-t
zu*96wRB+xX0;TLCP&&IM04ZgW<Upq1;tc>LVpt)6ix0#_sJX@KUzS>wmXlu&Htv=n
tNE$^595hG-$lbR%Y#_z09VoDiL4FkA6krix5n>TyWnmT&U}0oo1OT!Nru+Z^

diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/ext.cpython-39.pyc
deleted file mode 100644
index 8044173388082122097ef9782479206aeb36172b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6308
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
MJd8YyV$5Q^0Dv@FRsaA1

diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/msgpack/__pycache__/fallback.cpython-39.pyc
deleted file mode 100644
index 8f9a25be63168dd71d7fbebd50724904a01f0e92..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 26754
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
POgwCC%mVcc5Eu*qO%B`#

diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/_version.py b/env/Lib/site-packages/pip/_vendor/msgpack/_version.py
deleted file mode 100644
index 1c83c8ed..00000000
--- a/env/Lib/site-packages/pip/_vendor/msgpack/_version.py
+++ /dev/null
@@ -1 +0,0 @@
-version = (1, 0, 2)
diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/ext.py b/env/Lib/site-packages/pip/_vendor/msgpack/ext.py
index 4eb9dd65..23e0d6b4 100644
--- a/env/Lib/site-packages/pip/_vendor/msgpack/ext.py
+++ b/env/Lib/site-packages/pip/_vendor/msgpack/ext.py
@@ -56,10 +56,10 @@ class Timestamp(object):
         Note: Negative times (before the UNIX epoch) are represented as negative seconds + positive ns.
         """
         if not isinstance(seconds, int_types):
-            raise TypeError("seconds must be an interger")
+            raise TypeError("seconds must be an integer")
         if not isinstance(nanoseconds, int_types):
             raise TypeError("nanoseconds must be an integer")
-        if not (0 <= nanoseconds < 10 ** 9):
+        if not (0 <= nanoseconds < 10**9):
             raise ValueError(
                 "nanoseconds must be a non-negative integer less than 999999999."
             )
@@ -143,7 +143,7 @@ class Timestamp(object):
         :type unix_float: int or float.
         """
         seconds = int(unix_sec // 1)
-        nanoseconds = int((unix_sec % 1) * 10 ** 9)
+        nanoseconds = int((unix_sec % 1) * 10**9)
         return Timestamp(seconds, nanoseconds)
 
     def to_unix(self):
@@ -161,7 +161,7 @@ class Timestamp(object):
         :param int unix_ns: Posix timestamp in nanoseconds.
         :rtype: Timestamp
         """
-        return Timestamp(*divmod(unix_ns, 10 ** 9))
+        return Timestamp(*divmod(unix_ns, 10**9))
 
     def to_unix_nano(self):
         """Get the timestamp as a unixtime in nanoseconds.
@@ -169,7 +169,7 @@ class Timestamp(object):
         :returns: posix timestamp in nanoseconds
         :rtype: int
         """
-        return self.seconds * 10 ** 9 + self.nanoseconds
+        return self.seconds * 10**9 + self.nanoseconds
 
     def to_datetime(self):
         """Get the timestamp as a UTC datetime.
diff --git a/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py b/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py
index 0bfa94ea..e8cebc1b 100644
--- a/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py
+++ b/env/Lib/site-packages/pip/_vendor/msgpack/fallback.py
@@ -1,5 +1,4 @@
 """Fallback pure Python implementation of msgpack"""
-
 from datetime import datetime as _DateTime
 import sys
 import struct
@@ -12,7 +11,6 @@ if PY2:
     def dict_iteritems(d):
         return d.iteritems()
 
-
 else:
     int_types = int
     unicode = str
@@ -33,7 +31,6 @@ if sys.version_info < (3, 5):
             and e.args[0].startswith("maximum recursion depth exceeded")
         )
 
-
 else:
 
     def _is_recursionerror(e):
@@ -69,7 +66,6 @@ if hasattr(sys, "pypy_version_info"):
         def getvalue(self):
             return self.builder.build()
 
-
 else:
     USING_STRINGBUILDER = False
     from io import BytesIO as StringIO
@@ -144,10 +140,41 @@ if sys.version_info < (2, 7, 6):
         """Explicit type cast for legacy struct.unpack_from"""
         return struct.unpack_from(f, bytes(b), o)
 
-
 else:
     _unpack_from = struct.unpack_from
 
+_NO_FORMAT_USED = ""
+_MSGPACK_HEADERS = {
+    0xC4: (1, _NO_FORMAT_USED, TYPE_BIN),
+    0xC5: (2, ">H", TYPE_BIN),
+    0xC6: (4, ">I", TYPE_BIN),
+    0xC7: (2, "Bb", TYPE_EXT),
+    0xC8: (3, ">Hb", TYPE_EXT),
+    0xC9: (5, ">Ib", TYPE_EXT),
+    0xCA: (4, ">f"),
+    0xCB: (8, ">d"),
+    0xCC: (1, _NO_FORMAT_USED),
+    0xCD: (2, ">H"),
+    0xCE: (4, ">I"),
+    0xCF: (8, ">Q"),
+    0xD0: (1, "b"),
+    0xD1: (2, ">h"),
+    0xD2: (4, ">i"),
+    0xD3: (8, ">q"),
+    0xD4: (1, "b1s", TYPE_EXT),
+    0xD5: (2, "b2s", TYPE_EXT),
+    0xD6: (4, "b4s", TYPE_EXT),
+    0xD7: (8, "b8s", TYPE_EXT),
+    0xD8: (16, "b16s", TYPE_EXT),
+    0xD9: (1, _NO_FORMAT_USED, TYPE_RAW),
+    0xDA: (2, ">H", TYPE_RAW),
+    0xDB: (4, ">I", TYPE_RAW),
+    0xDC: (2, ">H", TYPE_ARRAY),
+    0xDD: (4, ">I", TYPE_ARRAY),
+    0xDE: (2, ">H", TYPE_MAP),
+    0xDF: (4, ">I", TYPE_MAP),
+}
+
 
 class Unpacker(object):
     """Streaming unpacker.
@@ -229,7 +256,7 @@ class Unpacker(object):
 
     Example of streaming deserialize from socket::
 
-        unpacker = Unpacker(max_buffer_size)
+        unpacker = Unpacker()
         while True:
             buf = sock.recv(1024**2)
             if not buf:
@@ -291,7 +318,7 @@ class Unpacker(object):
         self._buf_checkpoint = 0
 
         if not max_buffer_size:
-            max_buffer_size = 2 ** 31 - 1
+            max_buffer_size = 2**31 - 1
         if max_str_len == -1:
             max_str_len = max_buffer_size
         if max_bin_len == -1:
@@ -354,7 +381,7 @@ class Unpacker(object):
         self._buffer.extend(view)
 
     def _consume(self):
-        """ Gets rid of the used parts of the buffer. """
+        """Gets rid of the used parts of the buffer."""
         self._stream_offset += self._buff_i - self._buf_checkpoint
         self._buf_checkpoint = self._buff_i
 
@@ -396,6 +423,8 @@ class Unpacker(object):
 
         # Read from file
         remain_bytes = -remain_bytes
+        if remain_bytes + len(self._buffer) > self._max_buffer_size:
+            raise BufferFull
         while remain_bytes > 0:
             to_read_bytes = max(self._read_size, remain_bytes)
             read_data = self.file_like.read(to_read_bytes)
@@ -409,7 +438,7 @@ class Unpacker(object):
             self._buff_i = 0  # rollback
             raise OutOfData
 
-    def _read_header(self, execute=EX_CONSTRUCT):
+    def _read_header(self):
         typ = TYPE_IMMEDIATE
         n = 0
         obj = None
@@ -424,205 +453,95 @@ class Unpacker(object):
             n = b & 0b00011111
             typ = TYPE_RAW
             if n > self._max_str_len:
-                raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len)
+                raise ValueError("%s exceeds max_str_len(%s)" % (n, self._max_str_len))
             obj = self._read(n)
         elif b & 0b11110000 == 0b10010000:
             n = b & 0b00001111
             typ = TYPE_ARRAY
             if n > self._max_array_len:
-                raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len)
+                raise ValueError(
+                    "%s exceeds max_array_len(%s)" % (n, self._max_array_len)
+                )
         elif b & 0b11110000 == 0b10000000:
             n = b & 0b00001111
             typ = TYPE_MAP
             if n > self._max_map_len:
-                raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len)
+                raise ValueError("%s exceeds max_map_len(%s)" % (n, self._max_map_len))
         elif b == 0xC0:
             obj = None
         elif b == 0xC2:
             obj = False
         elif b == 0xC3:
             obj = True
-        elif b == 0xC4:
-            typ = TYPE_BIN
-            self._reserve(1)
-            n = self._buffer[self._buff_i]
-            self._buff_i += 1
-            if n > self._max_bin_len:
-                raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len))
-            obj = self._read(n)
-        elif b == 0xC5:
-            typ = TYPE_BIN
-            self._reserve(2)
-            n = _unpack_from(">H", self._buffer, self._buff_i)[0]
-            self._buff_i += 2
-            if n > self._max_bin_len:
-                raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len))
-            obj = self._read(n)
-        elif b == 0xC6:
-            typ = TYPE_BIN
-            self._reserve(4)
-            n = _unpack_from(">I", self._buffer, self._buff_i)[0]
-            self._buff_i += 4
+        elif 0xC4 <= b <= 0xC6:
+            size, fmt, typ = _MSGPACK_HEADERS[b]
+            self._reserve(size)
+            if len(fmt) > 0:
+                n = _unpack_from(fmt, self._buffer, self._buff_i)[0]
+            else:
+                n = self._buffer[self._buff_i]
+            self._buff_i += size
             if n > self._max_bin_len:
                 raise ValueError("%s exceeds max_bin_len(%s)" % (n, self._max_bin_len))
             obj = self._read(n)
-        elif b == 0xC7:  # ext 8
-            typ = TYPE_EXT
-            self._reserve(2)
-            L, n = _unpack_from("Bb", self._buffer, self._buff_i)
-            self._buff_i += 2
+        elif 0xC7 <= b <= 0xC9:
+            size, fmt, typ = _MSGPACK_HEADERS[b]
+            self._reserve(size)
+            L, n = _unpack_from(fmt, self._buffer, self._buff_i)
+            self._buff_i += size
             if L > self._max_ext_len:
                 raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len))
             obj = self._read(L)
-        elif b == 0xC8:  # ext 16
-            typ = TYPE_EXT
-            self._reserve(3)
-            L, n = _unpack_from(">Hb", self._buffer, self._buff_i)
-            self._buff_i += 3
-            if L > self._max_ext_len:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len))
-            obj = self._read(L)
-        elif b == 0xC9:  # ext 32
-            typ = TYPE_EXT
-            self._reserve(5)
-            L, n = _unpack_from(">Ib", self._buffer, self._buff_i)
-            self._buff_i += 5
-            if L > self._max_ext_len:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (L, self._max_ext_len))
-            obj = self._read(L)
-        elif b == 0xCA:
-            self._reserve(4)
-            obj = _unpack_from(">f", self._buffer, self._buff_i)[0]
-            self._buff_i += 4
-        elif b == 0xCB:
-            self._reserve(8)
-            obj = _unpack_from(">d", self._buffer, self._buff_i)[0]
-            self._buff_i += 8
-        elif b == 0xCC:
-            self._reserve(1)
-            obj = self._buffer[self._buff_i]
-            self._buff_i += 1
-        elif b == 0xCD:
-            self._reserve(2)
-            obj = _unpack_from(">H", self._buffer, self._buff_i)[0]
-            self._buff_i += 2
-        elif b == 0xCE:
-            self._reserve(4)
-            obj = _unpack_from(">I", self._buffer, self._buff_i)[0]
-            self._buff_i += 4
-        elif b == 0xCF:
-            self._reserve(8)
-            obj = _unpack_from(">Q", self._buffer, self._buff_i)[0]
-            self._buff_i += 8
-        elif b == 0xD0:
-            self._reserve(1)
-            obj = _unpack_from("b", self._buffer, self._buff_i)[0]
-            self._buff_i += 1
-        elif b == 0xD1:
-            self._reserve(2)
-            obj = _unpack_from(">h", self._buffer, self._buff_i)[0]
-            self._buff_i += 2
-        elif b == 0xD2:
-            self._reserve(4)
-            obj = _unpack_from(">i", self._buffer, self._buff_i)[0]
-            self._buff_i += 4
-        elif b == 0xD3:
-            self._reserve(8)
-            obj = _unpack_from(">q", self._buffer, self._buff_i)[0]
-            self._buff_i += 8
-        elif b == 0xD4:  # fixext 1
-            typ = TYPE_EXT
-            if self._max_ext_len < 1:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (1, self._max_ext_len))
-            self._reserve(2)
-            n, obj = _unpack_from("b1s", self._buffer, self._buff_i)
-            self._buff_i += 2
-        elif b == 0xD5:  # fixext 2
-            typ = TYPE_EXT
-            if self._max_ext_len < 2:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (2, self._max_ext_len))
-            self._reserve(3)
-            n, obj = _unpack_from("b2s", self._buffer, self._buff_i)
-            self._buff_i += 3
-        elif b == 0xD6:  # fixext 4
-            typ = TYPE_EXT
-            if self._max_ext_len < 4:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (4, self._max_ext_len))
-            self._reserve(5)
-            n, obj = _unpack_from("b4s", self._buffer, self._buff_i)
-            self._buff_i += 5
-        elif b == 0xD7:  # fixext 8
-            typ = TYPE_EXT
-            if self._max_ext_len < 8:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (8, self._max_ext_len))
-            self._reserve(9)
-            n, obj = _unpack_from("b8s", self._buffer, self._buff_i)
-            self._buff_i += 9
-        elif b == 0xD8:  # fixext 16
-            typ = TYPE_EXT
-            if self._max_ext_len < 16:
-                raise ValueError("%s exceeds max_ext_len(%s)" % (16, self._max_ext_len))
-            self._reserve(17)
-            n, obj = _unpack_from("b16s", self._buffer, self._buff_i)
-            self._buff_i += 17
-        elif b == 0xD9:
-            typ = TYPE_RAW
-            self._reserve(1)
-            n = self._buffer[self._buff_i]
-            self._buff_i += 1
-            if n > self._max_str_len:
-                raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len)
-            obj = self._read(n)
-        elif b == 0xDA:
-            typ = TYPE_RAW
-            self._reserve(2)
-            (n,) = _unpack_from(">H", self._buffer, self._buff_i)
-            self._buff_i += 2
-            if n > self._max_str_len:
-                raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len)
-            obj = self._read(n)
-        elif b == 0xDB:
-            typ = TYPE_RAW
-            self._reserve(4)
-            (n,) = _unpack_from(">I", self._buffer, self._buff_i)
-            self._buff_i += 4
+        elif 0xCA <= b <= 0xD3:
+            size, fmt = _MSGPACK_HEADERS[b]
+            self._reserve(size)
+            if len(fmt) > 0:
+                obj = _unpack_from(fmt, self._buffer, self._buff_i)[0]
+            else:
+                obj = self._buffer[self._buff_i]
+            self._buff_i += size
+        elif 0xD4 <= b <= 0xD8:
+            size, fmt, typ = _MSGPACK_HEADERS[b]
+            if self._max_ext_len < size:
+                raise ValueError(
+                    "%s exceeds max_ext_len(%s)" % (size, self._max_ext_len)
+                )
+            self._reserve(size + 1)
+            n, obj = _unpack_from(fmt, self._buffer, self._buff_i)
+            self._buff_i += size + 1
+        elif 0xD9 <= b <= 0xDB:
+            size, fmt, typ = _MSGPACK_HEADERS[b]
+            self._reserve(size)
+            if len(fmt) > 0:
+                (n,) = _unpack_from(fmt, self._buffer, self._buff_i)
+            else:
+                n = self._buffer[self._buff_i]
+            self._buff_i += size
             if n > self._max_str_len:
-                raise ValueError("%s exceeds max_str_len(%s)", n, self._max_str_len)
+                raise ValueError("%s exceeds max_str_len(%s)" % (n, self._max_str_len))
             obj = self._read(n)
-        elif b == 0xDC:
-            typ = TYPE_ARRAY
-            self._reserve(2)
-            (n,) = _unpack_from(">H", self._buffer, self._buff_i)
-            self._buff_i += 2
+        elif 0xDC <= b <= 0xDD:
+            size, fmt, typ = _MSGPACK_HEADERS[b]
+            self._reserve(size)
+            (n,) = _unpack_from(fmt, self._buffer, self._buff_i)
+            self._buff_i += size
             if n > self._max_array_len:
-                raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len)
-        elif b == 0xDD:
-            typ = TYPE_ARRAY
-            self._reserve(4)
-            (n,) = _unpack_from(">I", self._buffer, self._buff_i)
-            self._buff_i += 4
-            if n > self._max_array_len:
-                raise ValueError("%s exceeds max_array_len(%s)", n, self._max_array_len)
-        elif b == 0xDE:
-            self._reserve(2)
-            (n,) = _unpack_from(">H", self._buffer, self._buff_i)
-            self._buff_i += 2
-            if n > self._max_map_len:
-                raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len)
-            typ = TYPE_MAP
-        elif b == 0xDF:
-            self._reserve(4)
-            (n,) = _unpack_from(">I", self._buffer, self._buff_i)
-            self._buff_i += 4
+                raise ValueError(
+                    "%s exceeds max_array_len(%s)" % (n, self._max_array_len)
+                )
+        elif 0xDE <= b <= 0xDF:
+            size, fmt, typ = _MSGPACK_HEADERS[b]
+            self._reserve(size)
+            (n,) = _unpack_from(fmt, self._buffer, self._buff_i)
+            self._buff_i += size
             if n > self._max_map_len:
-                raise ValueError("%s exceeds max_map_len(%s)", n, self._max_map_len)
-            typ = TYPE_MAP
+                raise ValueError("%s exceeds max_map_len(%s)" % (n, self._max_map_len))
         else:
             raise FormatError("Unknown header: 0x%x" % b)
         return typ, n, obj
 
     def _unpack(self, execute=EX_CONSTRUCT):
-        typ, n, obj = self._read_header(execute)
+        typ, n, obj = self._read_header()
 
         if execute == EX_READ_ARRAY_HEADER:
             if typ != TYPE_ARRAY:
@@ -883,20 +802,20 @@ class Packer(object):
                 raise OverflowError("Integer value out of range")
             if check(obj, (bytes, bytearray)):
                 n = len(obj)
-                if n >= 2 ** 32:
+                if n >= 2**32:
                     raise ValueError("%s is too large" % type(obj).__name__)
                 self._pack_bin_header(n)
                 return self._buffer.write(obj)
             if check(obj, unicode):
                 obj = obj.encode("utf-8", self._unicode_errors)
                 n = len(obj)
-                if n >= 2 ** 32:
+                if n >= 2**32:
                     raise ValueError("String is too large")
                 self._pack_raw_header(n)
                 return self._buffer.write(obj)
             if check(obj, memoryview):
-                n = len(obj) * obj.itemsize
-                if n >= 2 ** 32:
+                n = obj.nbytes
+                if n >= 2**32:
                     raise ValueError("Memoryview is too large")
                 self._pack_bin_header(n)
                 return self._buffer.write(obj)
@@ -953,6 +872,10 @@ class Packer(object):
                 obj = self._default(obj)
                 default_used = 1
                 continue
+
+            if self._datetime and check(obj, _DateTime):
+                raise ValueError("Cannot serialize %r where tzinfo=None" % (obj,))
+
             raise TypeError("Cannot serialize %r" % (obj,))
 
     def pack(self, obj):
@@ -974,7 +897,7 @@ class Packer(object):
             return ret
 
     def pack_array_header(self, n):
-        if n >= 2 ** 32:
+        if n >= 2**32:
             raise ValueError
         self._pack_array_header(n)
         if self._autoreset:
@@ -983,7 +906,7 @@ class Packer(object):
             return ret
 
     def pack_map_header(self, n):
-        if n >= 2 ** 32:
+        if n >= 2**32:
             raise ValueError
         self._pack_map_header(n)
         if self._autoreset:
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__about__.py b/env/Lib/site-packages/pip/_vendor/packaging/__about__.py
index 4c43a968..3551bc2d 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/__about__.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/__about__.py
@@ -1,7 +1,6 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 __all__ = [
     "__title__",
@@ -18,7 +17,7 @@ __title__ = "packaging"
 __summary__ = "Core utilities for Python packages"
 __uri__ = "https://github.com/pypa/packaging"
 
-__version__ = "20.9"
+__version__ = "21.3"
 
 __author__ = "Donald Stufft and individual contributors"
 __email__ = "donald@stufft.io"
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__init__.py b/env/Lib/site-packages/pip/_vendor/packaging/__init__.py
index a0cf67df..3c50c5dc 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/__init__.py
@@ -1,7 +1,6 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 from .__about__ import (
     __author__,
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__about__.cpython-39.pyc
deleted file mode 100644
index fecdb66800010426132b32b6f20e103bfe7cc6e0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 717
zcmYe~<>g{vU|^UdaWM5769dCz5C<7EF)%PVFfcF_yD%^?q%fo~<}l<kMlt3xMKR?v
zM=>)pq%)*2En<vfNnws+O<{>*OJR*-PhpGVNMVoSOyP*)O5u#+PT@-B6k~|uN#PD=
z(ByduGGCMV7Jp(=aehu|Noss%Zb5!g$t{kQ%(Bel%>2Atd<8|Bc_r~_rFqFEnfZB|
z9Je^*<4ZD2a#G{tZ*j-R7nkPdCKgr3$KPU)k1s9Cgou`<7J+of$KT?Lk54Qu$;dB?
zj|b^Y%}vbAfvCyJOis-!1{uQ}AD^6GP+63jo>2l)R*;ySotU1PmtLjhoL`ixP+F3i
zlUb6PTC9+kU!)LFS(1^TrvOouT3n@=QBqP+Y^ATCo>`JnnxvPUpQ~R`S&*m?Q2{cB
z#mGR<vP#n>KQA#SMIpGPG%c+}Au%sSAu|u;(Uj7}9EIfkypp2Kq|%c7qT(un6tGf<
zVz5%Z%={`Tr(hRdBVFg5#M0tah5RA~$AZM<j8t7CJ%cJ9BLhPdT_XcSO9j<pKTTec
zr_)MHN{dqC<BLGiR>aJ}z)-}(z`y_srNo?^`1m4LkPsV)U<VN#Ac7M_fKovbH;Bc<
zz`(GQp-2G41`)rSovmU*i&Kk=V^VWcGK*sT^HN=kGRsmGbQMDVJi}arf;~eVgB3je
zT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+^U7j;GLvG8GfPr+AwiW|
z98-{4pdVkBnwOGaga|+V`1r)6{L+&6c)fzkTO2mI`6;D2sdga$6bmshFo-a5aI-M7
MFtRYQFo8)%03R>ahX4Qo

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 200d3c409305fe272db30a88f5ce1adce2408cd1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 573
zcmYe~<>g{vU|^UdaWK`0iGkrUh=Yuo7#J8F7#J9eJs21mQW#Pga~N_NqZo6UqL^}-
zqnH^PQkYVhb69d&qgZp<qS$iTqu6sfqBwFnqd0T9qPTLoqquW<qIeh?(iu`%7BNQg
zrmzMxXtKQo*`djNi$5``I6tSfBsD%Ww;;c$<Q7LtW?5!&W`5o+zJj96yps5|(!Au7
z%>2BUj0_A6njE*d;^PxbOEU6{;^S}e#>Xe;7gQEyre~DI$KT?Nk5A1_%*=_8zr`IN
zpOcxKnpd0(;S`tV<|Y<ZLKKx`mgIoM+2i9&i!vb!%2JC!w#LV6aujhhFfbH>f~AND
z#Nq`JY#@RIL~w!#b_NCpKTST6Ytl+fN{dqC<BLE+Rm2REWno}o0J$bHDZjKNKE4R7
z8Kk8MVFK8EuuX7FZn4M5C+6hD$FF245(Jq8B7QYFTg8MHrxq2*q~@e#7RC7IrMeVl
zmZd7_DunuZhPeg>dxkg$D|q_3`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-a
zX2+!FmBsjECdCwImZa(yBqnDkrl%Ii6l50Y$Cst%rQ{dsLj*JP()HuxGxIV_;^XxS
YDsOSv<mRW8=A_zzd{zu1M3^+V0kP7XzyJUM

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_compat.cpython-39.pyc
deleted file mode 100644
index 435f600ff43a89ee86ef147b255333fefc321460..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1171
zcmYe~<>g{vU|^UdaWFN5g@NHQh=Yuo7#J8F7#J9e>lhdqQW#Pga~N_NqZo6UqL^}-
zqnH^%VoW(KQ7kFUDJ(gxxolBvj0~x4MJ_1}DXcl{xg1d(xtvj)xm;0Px!h6Qj0~wP
zSv)BWk_;(q*-TNqa2|U$Qxsn+Ur|mfe;Q+yKptDFAc#)kNa1W@h!RR+3TDvcdI@rw
zCi5-+#H8Z<oYIoi_{`jb{GyUu94VP)nZ=p;dAIlqiZb&`;?qj=l1no4^ZZ^iGB7Y`
zGT!11i41U!clK~~_V)C1*JQcH?3h=1i^U}~x#SjWNNGV%>MfR#%7WCFAP>J}W?*1Q
z2I&M@2*Mx%HU<U;c2H2LF)%Q=Gqf|bGo~@6Fs3lIaHKGGFg7#SGL<kaV60&R1w|&q
zLY80#P1Y)XE(HYz1?QsF#FA8nM1`cp;#7s?oW$Z{h4Rdj42496+|-gpuz(&|WirS*
zWDK$z#4na&U|>jPh+<4(h+;yvJc>DmIha9{rAiTGVm!h;o1FaQ#GGO~J-ARZ3&<oW
z2C+d{8004&1_p)>#u~;Bh8pH(ka3KDD;Yq+l$=w1izP2HH}w`*Nk(RIJjesZw-{4a
zGTmZ@uvtLH7x6MMF#KwCwu%WYPAw{qNzF;gEQ;~ZOLZyAEK60;RS5O-408<%_6%_h
zR`B$5@%M8L_H>L1cJ*})4si`qFpCKY@QFz@(ap(E&nzy<%#KOTD~s{TOo}PaEJ@WZ
zNKDR7OiwM2Dab6)k1tEjOUW<NhX`iorR&Eh=jRqAmgp5!-eQlB&r2<jk5>Zu3KW?P
zOjVi$14a+3%TJT#7Ds$M$iMONx47ctbMsS5b5i5uZ}G&(7nUaGKxB%<7#JA9UM>=X
zvqTvf7;bTb0s|bKiZBOoFcyKL?iPPZDk!xk7FEWB6@c|?GTmY+sVqnZo2bcLBmy!H
z6eD0gU?mVMz^3z|dPEXr1t<y`IK)_sWI-ui806@*(vs4m)cE)!kpGK738)C9>K1cx
zW$`Wc_>#(k%)Im>P<p<_2IYVfb`b~2a!wEdDim(<l%*DdGF5zLURwSw=72~e5Mg|a
zxwxe07Ef_WQD$B`$gtGnTU_9z02Tqe1LAN{nt-stuII3Ugr*(HF~uOCiZF37@i4J4
RN-*;=^0BZmaxk$m0{|8HDbD}^

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_structures.cpython-39.pyc
deleted file mode 100644
index 58a941566764676660502683697a93452f777b43..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2925
zcmYe~<>g{vU|^UdaWM56I|IXG5C<8vFfcGUFfcF_yD%^?q%fo~<}l<kMlt3xMKR?v
zM=>)pxHF_Mr7*WJq%fzlG&4uBrm{9OM6tOuq_Cv0wlJiyf<@U=*_#=nI8xYx88q2n
zg3Q-szQv!IRGgnvT9O){nOl%wRC0?WC9^EEI5R)*7GFV8W?o5rT4`Q#NoIatGDrt9
zW`emYgn@w}l_82Tg&~S5g)xPxg&~SLg*k<#g&~S1g*An(g&~SHg*}C%g&~S9g)@b#
zg&~SPg*%0(1>_pu6uuUQD9#lA6oD3oD6SO26rmP|DDD*DU<OT*TRfh5X_<MMC6ytS
z1*yr5NY;bcAnXhZ7f=ADFa|SdGWp%&fN5FDu#)i>OL1yWS`j+~0|S`&)#_{&6Iz^F
zR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&58l+$r
z6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6U!)Ha
z%*;#Ik1sAMDorjaElMrcE2zB15g%WaT2K@p&jE5iC?pw}szhNf2YFTxrUJv)%nS?+
zU|;hvFff!blrYvXG&43c1~aT=^jpbvizOqmIO7%z$oL|V>0p0D2v8~mSq)MV9}m)A
zjKgY(ie#`XG|)k8i~wKB<mU!9dnHp5Cj$e+E!O;!jMO5q5QG5R$rc}<QxYF9faF<W
zG|z(M3ENjB2#d)gAvg;hyKs9_<Kso}*^?R{k6{m5kk&BPFk~?{GX*mgfdXkI(=D#d
z;>^6_lEl2^)LWeK@yR)f#l`XQxZIFh7#}Zz#|<EP+-~3lM=Q(?JPc4*6p4X6jKkM?
zsqyhLcx(j8W7vo-HbWq>hQpfllK6N9Jl25Z30qSn4e|*%)^ORA8XvEM&mK@Df}9Uc
zn+zZ}2!rzls5B^n1)C=0EdjsO^u&_PvQ$`-!<sMH<Ky#E)8peckn9zK>44@)umZo8
zJfKXJmzbLxAAgH0K0Y@;r8Eb`=82ClEKSUT$P{sdd<jbOMWFOpBnsk6f(R)P0gA06
zSrAJeM1VsBL4Z<o5i0`&14yVC6iOV794x31EI%NnvIu&Bf`SL5oI;5YXz5(VsS68I
zNJ7I>LV*L$5GfX9u~|n(`3TO;MZBQk#%3)js!WNnme{fpe=-Lr3QHvGq;dF?$bu1X
zo&qO6TVgB&Wh_uh56f5}HvZBPXSq}aO6-nASW4aEun3gBT#2xjxH1ucjZ*~5#-2o2
zMr6r|w|WB?7rw+;28u;c_JhSDhz-KnipL^0Tp0pXFa;u6Cxat}LQ2IVP{jbr)SyBO
z!UC6Lppx7GWDbsU3?%QT$q6b-(@H^2r1<zEP`WDuCA=a~X?}|>KPf9UxddF~K^zRy
jR3ry-I>I(E3uNUj4jV|JYzNX^49e{y%mQj`%mQiv!pJ7Y

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/_typing.cpython-39.pyc
deleted file mode 100644
index 5c88f89de500b5c0b72e8e3320665be133bada84..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1528
zcmYe~<>g{vU|^UdaWGYZoq^#oh=Yuo7#J8F7#J9e^%xi!QW&BbQW#U1(wU+dQ<$Te
zQkjaBQdm-0bC`2kqF5Li@;Fl1QkYs8qF7ScgBdhA65UxC7~JxU6!KCNOL8g|GII-Z
zQgc)DN;31(6^cs|OEQxcN-7ILyv#g>g2d$P#PrO(bUiMvgxt!4$^->ng_4X^B$cTO
ziFt`RmBpFG3MKjZISS>e3Z=!V3c4V&7_2q{VqStmZhlH>PO6SVc}8Y(23J8*epzNp
zYOz9ceo?AIT4`Q#NoIatVoqjBC5V@j2y#_ojzUSk0?20dVvs0U4a7a}sd=eIi8(oy
zItp+b%JWNeQWTO>LEg$QDoIUINGwq(D$Og&%mukK1>~p{h0HvKl8nR>g|x)tjLiHz
z1zoPp5{1O%l46C#VueJ7ynNmK0(6Zj`KiSUdHE#@8Hr^eqbfnh>VnP9FH0@TNKH&p
zNUG#YNiEJy&(q`Lax7NJEKw*aEy^oa$S*BHa$_dMoU+usl>DN^q#RIKWtM<kR;*B*
zT98<jSdywxoL^d$oLa1qmS4mbP+5|ZpQm7?4`mqZDTHK{7V9XKWMqOuFC{f8u{c#B
zIWZ6Hz|@L@)Z`Md?fIafC@4xTPR%RP;|j@FD9<m-R!A($FU?B<>(&7WtwLf>PJTHg
zvLJB<4L?xWC#5PRrDkO2r6?pSxFzNkr|MR6<rhGr3M5}plv<XW2evP*C_fhzEP0^R
zgBI{5l?AD~$@#gUNG%4tH3^(hQn*U;6^c@G^UG4fi6t*JH3j5rFbAXwl&nDBNK8&n
zEiTRkg;z>uQED<M@urj(fvkc?upSpz2q;7#$xH#BzCh^}>T-qj(!?Tg0!UQI%S=wq
zsZ_{I%mvv9O$x>Nkff2wm0VhsnO|D0keis9SCW{Sms$jNbx~?!a)v@iYEdf4^F^R&
z2StM(7ndhecF_R^DKwMlLW8s@H7602A~SOf@{3A}6^b)pi52W9P+A4WH#jP+xVRJ)
z6coS#T98?w7Y|7-dWifO4>c8HnnFlqfNQ+7hpV%<r=L4Sb7mT<s1?{qxUs1E_4M?(
zxPnsCtQ0azN(zdt^!3v-OEOB6^pf*)^$WlWP#=^F^)ri$OH+&Wjg1V=xNh;HSbK{l
zIkC9J?IozJ(qt?G6;sI|0>lSl5Sx*Kfx#J6cCj!pFw`&xGiWmUtz^(-y2T2L>-bx&
zWr;bZsYM`JF!8I=*(xTqIJKxaCN(D|vna+tFV&?evka7JLj63$T!Vr=LmYz@JpEk!
z{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|MQgtCgnOYoE
zkXfJ)4PSkTU}j#rJ~Vvw3M#=K(FeI1<N*doKTXzK?D6p_`N{F|AVy+NPJDb3$YZzI
nAb|?j0d_tT!Op<IaErqRk~r-^%8Nn8Jc|qmI|~~N6CX1G)8pp^

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/markers.cpython-39.pyc
deleted file mode 100644
index 0480d34e188df2c3536d4830f9aeb47d6a187009..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9299
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
NW)2<>84gYkX#f-5H&Flp

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/requirements.cpython-39.pyc
deleted file mode 100644
index d42056248ced5aafe8868c86c2fe5e45cb488297..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4172
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
J;$h}u1^}4?I~xE1

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/specifiers.cpython-39.pyc
deleted file mode 100644
index 86b3f711973562313491c819d34b7fbd22dfd96e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/tags.cpython-39.pyc
deleted file mode 100644
index 0bfdb1a79a6c8ce95d6d2cb22df79fa9a1c8a885..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 18571
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
D5$Bw}

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/utils.cpython-39.pyc
deleted file mode 100644
index 09d01046c240055f8b96ebd19e5a7fb6041595b6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3639
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
O#l*$T!Oo$@p$q_h*Ppfk

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/packaging/__pycache__/version.cpython-39.pyc
deleted file mode 100644
index f4437ce827b023287d76e6ede6dfebe88eb07b47..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 12703
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
A9smFU

diff --git a/env/Lib/site-packages/pip/_vendor/packaging/_compat.py b/env/Lib/site-packages/pip/_vendor/packaging/_compat.py
deleted file mode 100644
index e54bd4ed..00000000
--- a/env/Lib/site-packages/pip/_vendor/packaging/_compat.py
+++ /dev/null
@@ -1,38 +0,0 @@
-# This file is dual licensed under the terms of the Apache License, Version
-# 2.0, and the BSD License. See the LICENSE file in the root of this repository
-# for complete details.
-from __future__ import absolute_import, division, print_function
-
-import sys
-
-from ._typing import TYPE_CHECKING
-
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import Any, Dict, Tuple, Type
-
-
-PY2 = sys.version_info[0] == 2
-PY3 = sys.version_info[0] == 3
-
-# flake8: noqa
-
-if PY3:
-    string_types = (str,)
-else:
-    string_types = (basestring,)
-
-
-def with_metaclass(meta, *bases):
-    # type: (Type[Any], Tuple[Type[Any], ...]) -> Any
-    """
-    Create a base class with a metaclass.
-    """
-    # This requires a bit of explanation: the basic idea is to make a dummy
-    # metaclass for one level of class instantiation that replaces itself with
-    # the actual metaclass.
-    class metaclass(meta):  # type: ignore
-        def __new__(cls, name, this_bases, d):
-            # type: (Type[Any], str, Tuple[Any], Dict[Any, Any]) -> Any
-            return meta(name, bases, d)
-
-    return type.__new__(metaclass, "temporary_class", (), {})
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/_structures.py b/env/Lib/site-packages/pip/_vendor/packaging/_structures.py
index 800d5c55..90a6465f 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/_structures.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/_structures.py
@@ -1,85 +1,60 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 
-class InfinityType(object):
-    def __repr__(self):
-        # type: () -> str
+class InfinityType:
+    def __repr__(self) -> str:
         return "Infinity"
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(repr(self))
 
-    def __lt__(self, other):
-        # type: (object) -> bool
+    def __lt__(self, other: object) -> bool:
         return False
 
-    def __le__(self, other):
-        # type: (object) -> bool
+    def __le__(self, other: object) -> bool:
         return False
 
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         return isinstance(other, self.__class__)
 
-    def __ne__(self, other):
-        # type: (object) -> bool
-        return not isinstance(other, self.__class__)
-
-    def __gt__(self, other):
-        # type: (object) -> bool
+    def __gt__(self, other: object) -> bool:
         return True
 
-    def __ge__(self, other):
-        # type: (object) -> bool
+    def __ge__(self, other: object) -> bool:
         return True
 
-    def __neg__(self):
-        # type: (object) -> NegativeInfinityType
+    def __neg__(self: object) -> "NegativeInfinityType":
         return NegativeInfinity
 
 
 Infinity = InfinityType()
 
 
-class NegativeInfinityType(object):
-    def __repr__(self):
-        # type: () -> str
+class NegativeInfinityType:
+    def __repr__(self) -> str:
         return "-Infinity"
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(repr(self))
 
-    def __lt__(self, other):
-        # type: (object) -> bool
+    def __lt__(self, other: object) -> bool:
         return True
 
-    def __le__(self, other):
-        # type: (object) -> bool
+    def __le__(self, other: object) -> bool:
         return True
 
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         return isinstance(other, self.__class__)
 
-    def __ne__(self, other):
-        # type: (object) -> bool
-        return not isinstance(other, self.__class__)
-
-    def __gt__(self, other):
-        # type: (object) -> bool
+    def __gt__(self, other: object) -> bool:
         return False
 
-    def __ge__(self, other):
-        # type: (object) -> bool
+    def __ge__(self, other: object) -> bool:
         return False
 
-    def __neg__(self):
-        # type: (object) -> InfinityType
+    def __neg__(self: object) -> InfinityType:
         return Infinity
 
 
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/_typing.py b/env/Lib/site-packages/pip/_vendor/packaging/_typing.py
deleted file mode 100644
index 2846133b..00000000
--- a/env/Lib/site-packages/pip/_vendor/packaging/_typing.py
+++ /dev/null
@@ -1,48 +0,0 @@
-"""For neatly implementing static typing in packaging.
-
-`mypy` - the static type analysis tool we use - uses the `typing` module, which
-provides core functionality fundamental to mypy's functioning.
-
-Generally, `typing` would be imported at runtime and used in that fashion -
-it acts as a no-op at runtime and does not have any run-time overhead by
-design.
-
-As it turns out, `typing` is not vendorable - it uses separate sources for
-Python 2/Python 3. Thus, this codebase can not expect it to be present.
-To work around this, mypy allows the typing import to be behind a False-y
-optional to prevent it from running at runtime and type-comments can be used
-to remove the need for the types to be accessible directly during runtime.
-
-This module provides the False-y guard in a nicely named fashion so that a
-curious maintainer can reach here to read this.
-
-In packaging, all static-typing related imports should be guarded as follows:
-
-    from pip._vendor.packaging._typing import TYPE_CHECKING
-
-    if TYPE_CHECKING:
-        from typing import ...
-
-Ref: https://github.com/python/mypy/issues/3216
-"""
-
-__all__ = ["TYPE_CHECKING", "cast"]
-
-# The TYPE_CHECKING constant defined by the typing module is False at runtime
-# but True while type checking.
-if False:  # pragma: no cover
-    from typing import TYPE_CHECKING
-else:
-    TYPE_CHECKING = False
-
-# typing's cast syntax requires calling typing.cast at runtime, but we don't
-# want to import typing at runtime. Here, we inform the type checkers that
-# we're importing `typing.cast` as `cast` and re-implement typing.cast's
-# runtime behavior in a block that is ignored by type checkers.
-if TYPE_CHECKING:  # pragma: no cover
-    # not executed at runtime
-    from typing import cast
-else:
-    # executed at runtime
-    def cast(type_, value):  # noqa
-        return value
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/markers.py b/env/Lib/site-packages/pip/_vendor/packaging/markers.py
index 69a60cf1..540e7a4d 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/markers.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/markers.py
@@ -1,12 +1,12 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 import operator
 import os
 import platform
 import sys
+from typing import Any, Callable, Dict, List, Optional, Tuple, Union
 
 from pip._vendor.pyparsing import (  # noqa: N817
     Forward,
@@ -20,16 +20,8 @@ from pip._vendor.pyparsing import (  # noqa: N817
     stringStart,
 )
 
-from ._compat import string_types
-from ._typing import TYPE_CHECKING
 from .specifiers import InvalidSpecifier, Specifier
 
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import Any, Callable, Dict, List, Optional, Tuple, Union
-
-    Operator = Callable[[str, str], bool]
-
-
 __all__ = [
     "InvalidMarker",
     "UndefinedComparison",
@@ -38,6 +30,8 @@ __all__ = [
     "default_environment",
 ]
 
+Operator = Callable[[str, str], bool]
+
 
 class InvalidMarker(ValueError):
     """
@@ -58,39 +52,32 @@ class UndefinedEnvironmentName(ValueError):
     """
 
 
-class Node(object):
-    def __init__(self, value):
-        # type: (Any) -> None
+class Node:
+    def __init__(self, value: Any) -> None:
         self.value = value
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return str(self.value)
 
-    def __repr__(self):
-        # type: () -> str
-        return "<{0}({1!r})>".format(self.__class__.__name__, str(self))
+    def __repr__(self) -> str:
+        return f"<{self.__class__.__name__}('{self}')>"
 
-    def serialize(self):
-        # type: () -> str
+    def serialize(self) -> str:
         raise NotImplementedError
 
 
 class Variable(Node):
-    def serialize(self):
-        # type: () -> str
+    def serialize(self) -> str:
         return str(self)
 
 
 class Value(Node):
-    def serialize(self):
-        # type: () -> str
-        return '"{0}"'.format(self)
+    def serialize(self) -> str:
+        return f'"{self}"'
 
 
 class Op(Node):
-    def serialize(self):
-        # type: () -> str
+    def serialize(self) -> str:
         return str(self)
 
 
@@ -151,18 +138,18 @@ MARKER_EXPR << MARKER_ATOM + ZeroOrMore(BOOLOP + MARKER_EXPR)
 MARKER = stringStart + MARKER_EXPR + stringEnd
 
 
-def _coerce_parse_result(results):
-    # type: (Union[ParseResults, List[Any]]) -> List[Any]
+def _coerce_parse_result(results: Union[ParseResults, List[Any]]) -> List[Any]:
     if isinstance(results, ParseResults):
         return [_coerce_parse_result(i) for i in results]
     else:
         return results
 
 
-def _format_marker(marker, first=True):
-    # type: (Union[List[str], Tuple[Node, ...], str], Optional[bool]) -> str
+def _format_marker(
+    marker: Union[List[str], Tuple[Node, ...], str], first: Optional[bool] = True
+) -> str:
 
-    assert isinstance(marker, (list, tuple, string_types))
+    assert isinstance(marker, (list, tuple, str))
 
     # Sometimes we have a structure like [[...]] which is a single item list
     # where the single item is itself it's own list. In that case we want skip
@@ -187,7 +174,7 @@ def _format_marker(marker, first=True):
         return marker
 
 
-_operators = {
+_operators: Dict[str, Operator] = {
     "in": lambda lhs, rhs: lhs in rhs,
     "not in": lambda lhs, rhs: lhs not in rhs,
     "<": operator.lt,
@@ -196,11 +183,10 @@ _operators = {
     "!=": operator.ne,
     ">=": operator.ge,
     ">": operator.gt,
-}  # type: Dict[str, Operator]
+}
 
 
-def _eval_op(lhs, op, rhs):
-    # type: (str, Op, str) -> bool
+def _eval_op(lhs: str, op: Op, rhs: str) -> bool:
     try:
         spec = Specifier("".join([op.serialize(), rhs]))
     except InvalidSpecifier:
@@ -208,40 +194,36 @@ def _eval_op(lhs, op, rhs):
     else:
         return spec.contains(lhs)
 
-    oper = _operators.get(op.serialize())  # type: Optional[Operator]
+    oper: Optional[Operator] = _operators.get(op.serialize())
     if oper is None:
-        raise UndefinedComparison(
-            "Undefined {0!r} on {1!r} and {2!r}.".format(op, lhs, rhs)
-        )
+        raise UndefinedComparison(f"Undefined {op!r} on {lhs!r} and {rhs!r}.")
 
     return oper(lhs, rhs)
 
 
-class Undefined(object):
+class Undefined:
     pass
 
 
 _undefined = Undefined()
 
 
-def _get_env(environment, name):
-    # type: (Dict[str, str], str) -> str
-    value = environment.get(name, _undefined)  # type: Union[str, Undefined]
+def _get_env(environment: Dict[str, str], name: str) -> str:
+    value: Union[str, Undefined] = environment.get(name, _undefined)
 
     if isinstance(value, Undefined):
         raise UndefinedEnvironmentName(
-            "{0!r} does not exist in evaluation environment.".format(name)
+            f"{name!r} does not exist in evaluation environment."
         )
 
     return value
 
 
-def _evaluate_markers(markers, environment):
-    # type: (List[Any], Dict[str, str]) -> bool
-    groups = [[]]  # type: List[List[bool]]
+def _evaluate_markers(markers: List[Any], environment: Dict[str, str]) -> bool:
+    groups: List[List[bool]] = [[]]
 
     for marker in markers:
-        assert isinstance(marker, (list, tuple, string_types))
+        assert isinstance(marker, (list, tuple, str))
 
         if isinstance(marker, list):
             groups[-1].append(_evaluate_markers(marker, environment))
@@ -264,8 +246,7 @@ def _evaluate_markers(markers, environment):
     return any(all(item) for item in groups)
 
 
-def format_full_version(info):
-    # type: (sys._version_info) -> str
+def format_full_version(info: "sys._version_info") -> str:
     version = "{0.major}.{0.minor}.{0.micro}".format(info)
     kind = info.releaselevel
     if kind != "final":
@@ -273,18 +254,9 @@ def format_full_version(info):
     return version
 
 
-def default_environment():
-    # type: () -> Dict[str, str]
-    if hasattr(sys, "implementation"):
-        # Ignoring the `sys.implementation` reference for type checking due to
-        # mypy not liking that the attribute doesn't exist in Python 2.7 when
-        # run with the `--py27` flag.
-        iver = format_full_version(sys.implementation.version)  # type: ignore
-        implementation_name = sys.implementation.name  # type: ignore
-    else:
-        iver = "0"
-        implementation_name = ""
-
+def default_environment() -> Dict[str, str]:
+    iver = format_full_version(sys.implementation.version)
+    implementation_name = sys.implementation.name
     return {
         "implementation_name": implementation_name,
         "implementation_version": iver,
@@ -300,27 +272,23 @@ def default_environment():
     }
 
 
-class Marker(object):
-    def __init__(self, marker):
-        # type: (str) -> None
+class Marker:
+    def __init__(self, marker: str) -> None:
         try:
             self._markers = _coerce_parse_result(MARKER.parseString(marker))
         except ParseException as e:
-            err_str = "Invalid marker: {0!r}, parse error at {1!r}".format(
-                marker, marker[e.loc : e.loc + 8]
+            raise InvalidMarker(
+                f"Invalid marker: {marker!r}, parse error at "
+                f"{marker[e.loc : e.loc + 8]!r}"
             )
-            raise InvalidMarker(err_str)
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return _format_marker(self._markers)
 
-    def __repr__(self):
-        # type: () -> str
-        return "<Marker({0!r})>".format(str(self))
+    def __repr__(self) -> str:
+        return f"<Marker('{self}')>"
 
-    def evaluate(self, environment=None):
-        # type: (Optional[Dict[str, str]]) -> bool
+    def evaluate(self, environment: Optional[Dict[str, str]] = None) -> bool:
         """Evaluate a marker.
 
         Return the boolean from evaluating the given marker against the
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/requirements.py b/env/Lib/site-packages/pip/_vendor/packaging/requirements.py
index c2a7fdac..1eab7dd6 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/requirements.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/requirements.py
@@ -1,13 +1,13 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 import re
 import string
-import sys
+import urllib.parse
+from typing import List, Optional as TOptional, Set
 
-from pip._vendor.pyparsing import (  # noqa: N817
+from pip._vendor.pyparsing import (  # noqa
     Combine,
     Literal as L,
     Optional,
@@ -20,19 +20,9 @@ from pip._vendor.pyparsing import (  # noqa: N817
     stringStart,
 )
 
-from ._typing import TYPE_CHECKING
 from .markers import MARKER_EXPR, Marker
 from .specifiers import LegacySpecifier, Specifier, SpecifierSet
 
-if sys.version_info[0] >= 3:
-    from urllib import parse as urlparse  # pragma: no cover
-else:  # pragma: no cover
-    import urlparse
-
-
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import List, Optional as TOptional, Set
-
 
 class InvalidRequirement(ValueError):
     """
@@ -70,7 +60,7 @@ VERSION_ONE = VERSION_PEP440 ^ VERSION_LEGACY
 VERSION_MANY = Combine(
     VERSION_ONE + ZeroOrMore(COMMA + VERSION_ONE), joinString=",", adjacent=False
 )("_raw_spec")
-_VERSION_SPEC = Optional(((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY))
+_VERSION_SPEC = Optional((LPAREN + VERSION_MANY + RPAREN) | VERSION_MANY)
 _VERSION_SPEC.setParseAction(lambda s, l, t: t._raw_spec or "")
 
 VERSION_SPEC = originalTextFor(_VERSION_SPEC)("specifier")
@@ -94,7 +84,7 @@ REQUIREMENT = stringStart + NAMED_REQUIREMENT + stringEnd
 REQUIREMENT.parseString("x[]")
 
 
-class Requirement(object):
+class Requirement:
     """Parse a requirement.
 
     Parse a given requirement string into its parts, such as name, specifier,
@@ -107,54 +97,50 @@ class Requirement(object):
     #       the thing as well as the version? What about the markers?
     # TODO: Can we normalize the name and extra name?
 
-    def __init__(self, requirement_string):
-        # type: (str) -> None
+    def __init__(self, requirement_string: str) -> None:
         try:
             req = REQUIREMENT.parseString(requirement_string)
         except ParseException as e:
             raise InvalidRequirement(
-                'Parse error at "{0!r}": {1}'.format(
-                    requirement_string[e.loc : e.loc + 8], e.msg
-                )
+                f'Parse error at "{ requirement_string[e.loc : e.loc + 8]!r}": {e.msg}'
             )
 
-        self.name = req.name  # type: str
+        self.name: str = req.name
         if req.url:
-            parsed_url = urlparse.urlparse(req.url)
+            parsed_url = urllib.parse.urlparse(req.url)
             if parsed_url.scheme == "file":
-                if urlparse.urlunparse(parsed_url) != req.url:
+                if urllib.parse.urlunparse(parsed_url) != req.url:
                     raise InvalidRequirement("Invalid URL given")
             elif not (parsed_url.scheme and parsed_url.netloc) or (
                 not parsed_url.scheme and not parsed_url.netloc
             ):
-                raise InvalidRequirement("Invalid URL: {0}".format(req.url))
-            self.url = req.url  # type: TOptional[str]
+                raise InvalidRequirement(f"Invalid URL: {req.url}")
+            self.url: TOptional[str] = req.url
         else:
             self.url = None
-        self.extras = set(req.extras.asList() if req.extras else [])  # type: Set[str]
-        self.specifier = SpecifierSet(req.specifier)  # type: SpecifierSet
-        self.marker = req.marker if req.marker else None  # type: TOptional[Marker]
+        self.extras: Set[str] = set(req.extras.asList() if req.extras else [])
+        self.specifier: SpecifierSet = SpecifierSet(req.specifier)
+        self.marker: TOptional[Marker] = req.marker if req.marker else None
 
-    def __str__(self):
-        # type: () -> str
-        parts = [self.name]  # type: List[str]
+    def __str__(self) -> str:
+        parts: List[str] = [self.name]
 
         if self.extras:
-            parts.append("[{0}]".format(",".join(sorted(self.extras))))
+            formatted_extras = ",".join(sorted(self.extras))
+            parts.append(f"[{formatted_extras}]")
 
         if self.specifier:
             parts.append(str(self.specifier))
 
         if self.url:
-            parts.append("@ {0}".format(self.url))
+            parts.append(f"@ {self.url}")
             if self.marker:
                 parts.append(" ")
 
         if self.marker:
-            parts.append("; {0}".format(self.marker))
+            parts.append(f"; {self.marker}")
 
         return "".join(parts)
 
-    def __repr__(self):
-        # type: () -> str
-        return "<Requirement({0!r})>".format(str(self))
+    def __repr__(self) -> str:
+        return f"<Requirement('{self}')>"
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py b/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py
index a6a83c1f..0e218a6f 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/specifiers.py
@@ -1,25 +1,33 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 import abc
 import functools
 import itertools
 import re
 import warnings
+from typing import (
+    Callable,
+    Dict,
+    Iterable,
+    Iterator,
+    List,
+    Optional,
+    Pattern,
+    Set,
+    Tuple,
+    TypeVar,
+    Union,
+)
 
-from ._compat import string_types, with_metaclass
-from ._typing import TYPE_CHECKING
 from .utils import canonicalize_version
 from .version import LegacyVersion, Version, parse
 
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import Callable, Dict, Iterable, Iterator, List, Optional, Tuple, Union
-
-    ParsedVersion = Union[Version, LegacyVersion]
-    UnparsedVersion = Union[Version, LegacyVersion, str]
-    CallableOperator = Callable[[ParsedVersion, str], bool]
+ParsedVersion = Union[Version, LegacyVersion]
+UnparsedVersion = Union[Version, LegacyVersion, str]
+VersionTypeVar = TypeVar("VersionTypeVar", bound=UnparsedVersion)
+CallableOperator = Callable[[ParsedVersion, str], bool]
 
 
 class InvalidSpecifier(ValueError):
@@ -28,64 +36,51 @@ class InvalidSpecifier(ValueError):
     """
 
 
-class BaseSpecifier(with_metaclass(abc.ABCMeta, object)):  # type: ignore
+class BaseSpecifier(metaclass=abc.ABCMeta):
     @abc.abstractmethod
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         """
         Returns the str representation of this Specifier like object. This
         should be representative of the Specifier itself.
         """
 
     @abc.abstractmethod
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         """
         Returns a hash value for this Specifier like object.
         """
 
     @abc.abstractmethod
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         """
         Returns a boolean representing whether or not the two Specifier like
         objects are equal.
         """
 
-    @abc.abstractmethod
-    def __ne__(self, other):
-        # type: (object) -> bool
-        """
-        Returns a boolean representing whether or not the two Specifier like
-        objects are not equal.
-        """
-
     @abc.abstractproperty
-    def prereleases(self):
-        # type: () -> Optional[bool]
+    def prereleases(self) -> Optional[bool]:
         """
         Returns whether or not pre-releases as a whole are allowed by this
         specifier.
         """
 
     @prereleases.setter
-    def prereleases(self, value):
-        # type: (bool) -> None
+    def prereleases(self, value: bool) -> None:
         """
         Sets whether or not pre-releases as a whole are allowed by this
         specifier.
         """
 
     @abc.abstractmethod
-    def contains(self, item, prereleases=None):
-        # type: (str, Optional[bool]) -> bool
+    def contains(self, item: str, prereleases: Optional[bool] = None) -> bool:
         """
         Determines if the given item is contained within this specifier.
         """
 
     @abc.abstractmethod
-    def filter(self, iterable, prereleases=None):
-        # type: (Iterable[UnparsedVersion], Optional[bool]) -> Iterable[UnparsedVersion]
+    def filter(
+        self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None
+    ) -> Iterable[VersionTypeVar]:
         """
         Takes an iterable of items and filters them so that only items which
         are contained within this specifier are allowed in it.
@@ -94,48 +89,43 @@ class BaseSpecifier(with_metaclass(abc.ABCMeta, object)):  # type: ignore
 
 class _IndividualSpecifier(BaseSpecifier):
 
-    _operators = {}  # type: Dict[str, str]
+    _operators: Dict[str, str] = {}
+    _regex: Pattern[str]
 
-    def __init__(self, spec="", prereleases=None):
-        # type: (str, Optional[bool]) -> None
+    def __init__(self, spec: str = "", prereleases: Optional[bool] = None) -> None:
         match = self._regex.search(spec)
         if not match:
-            raise InvalidSpecifier("Invalid specifier: '{0}'".format(spec))
+            raise InvalidSpecifier(f"Invalid specifier: '{spec}'")
 
-        self._spec = (
+        self._spec: Tuple[str, str] = (
             match.group("operator").strip(),
             match.group("version").strip(),
-        )  # type: Tuple[str, str]
+        )
 
         # Store whether or not this Specifier should accept prereleases
         self._prereleases = prereleases
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         pre = (
-            ", prereleases={0!r}".format(self.prereleases)
+            f", prereleases={self.prereleases!r}"
             if self._prereleases is not None
             else ""
         )
 
-        return "<{0}({1!r}{2})>".format(self.__class__.__name__, str(self), pre)
+        return f"<{self.__class__.__name__}({str(self)!r}{pre})>"
 
-    def __str__(self):
-        # type: () -> str
-        return "{0}{1}".format(*self._spec)
+    def __str__(self) -> str:
+        return "{}{}".format(*self._spec)
 
     @property
-    def _canonical_spec(self):
-        # type: () -> Tuple[str, Union[Version, str]]
+    def _canonical_spec(self) -> Tuple[str, str]:
         return self._spec[0], canonicalize_version(self._spec[1])
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(self._canonical_spec)
 
-    def __eq__(self, other):
-        # type: (object) -> bool
-        if isinstance(other, string_types):
+    def __eq__(self, other: object) -> bool:
+        if isinstance(other, str):
             try:
                 other = self.__class__(str(other))
             except InvalidSpecifier:
@@ -145,57 +135,39 @@ class _IndividualSpecifier(BaseSpecifier):
 
         return self._canonical_spec == other._canonical_spec
 
-    def __ne__(self, other):
-        # type: (object) -> bool
-        if isinstance(other, string_types):
-            try:
-                other = self.__class__(str(other))
-            except InvalidSpecifier:
-                return NotImplemented
-        elif not isinstance(other, self.__class__):
-            return NotImplemented
-
-        return self._spec != other._spec
-
-    def _get_operator(self, op):
-        # type: (str) -> CallableOperator
-        operator_callable = getattr(
-            self, "_compare_{0}".format(self._operators[op])
-        )  # type: CallableOperator
+    def _get_operator(self, op: str) -> CallableOperator:
+        operator_callable: CallableOperator = getattr(
+            self, f"_compare_{self._operators[op]}"
+        )
         return operator_callable
 
-    def _coerce_version(self, version):
-        # type: (UnparsedVersion) -> ParsedVersion
+    def _coerce_version(self, version: UnparsedVersion) -> ParsedVersion:
         if not isinstance(version, (LegacyVersion, Version)):
             version = parse(version)
         return version
 
     @property
-    def operator(self):
-        # type: () -> str
+    def operator(self) -> str:
         return self._spec[0]
 
     @property
-    def version(self):
-        # type: () -> str
+    def version(self) -> str:
         return self._spec[1]
 
     @property
-    def prereleases(self):
-        # type: () -> Optional[bool]
+    def prereleases(self) -> Optional[bool]:
         return self._prereleases
 
     @prereleases.setter
-    def prereleases(self, value):
-        # type: (bool) -> None
+    def prereleases(self, value: bool) -> None:
         self._prereleases = value
 
-    def __contains__(self, item):
-        # type: (str) -> bool
+    def __contains__(self, item: str) -> bool:
         return self.contains(item)
 
-    def contains(self, item, prereleases=None):
-        # type: (UnparsedVersion, Optional[bool]) -> bool
+    def contains(
+        self, item: UnparsedVersion, prereleases: Optional[bool] = None
+    ) -> bool:
 
         # Determine if prereleases are to be allowed or not.
         if prereleases is None:
@@ -213,11 +185,12 @@ class _IndividualSpecifier(BaseSpecifier):
 
         # Actually do the comparison to determine if this item is contained
         # within this Specifier or not.
-        operator_callable = self._get_operator(self.operator)  # type: CallableOperator
+        operator_callable: CallableOperator = self._get_operator(self.operator)
         return operator_callable(normalized_item, self.version)
 
-    def filter(self, iterable, prereleases=None):
-        # type: (Iterable[UnparsedVersion], Optional[bool]) -> Iterable[UnparsedVersion]
+    def filter(
+        self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None
+    ) -> Iterable[VersionTypeVar]:
 
         yielded = False
         found_prereleases = []
@@ -231,7 +204,7 @@ class _IndividualSpecifier(BaseSpecifier):
 
             if self.contains(parsed_version, **kw):
                 # If our version is a prerelease, and we were not set to allow
-                # prereleases, then we'll store it for later incase nothing
+                # prereleases, then we'll store it for later in case nothing
                 # else matches this specifier.
                 if parsed_version.is_prerelease and not (
                     prereleases or self.prereleases
@@ -276,9 +249,8 @@ class LegacySpecifier(_IndividualSpecifier):
         ">": "greater_than",
     }
 
-    def __init__(self, spec="", prereleases=None):
-        # type: (str, Optional[bool]) -> None
-        super(LegacySpecifier, self).__init__(spec, prereleases)
+    def __init__(self, spec: str = "", prereleases: Optional[bool] = None) -> None:
+        super().__init__(spec, prereleases)
 
         warnings.warn(
             "Creating a LegacyVersion has been deprecated and will be "
@@ -286,44 +258,37 @@ class LegacySpecifier(_IndividualSpecifier):
             DeprecationWarning,
         )
 
-    def _coerce_version(self, version):
-        # type: (Union[ParsedVersion, str]) -> LegacyVersion
+    def _coerce_version(self, version: UnparsedVersion) -> LegacyVersion:
         if not isinstance(version, LegacyVersion):
             version = LegacyVersion(str(version))
         return version
 
-    def _compare_equal(self, prospective, spec):
-        # type: (LegacyVersion, str) -> bool
+    def _compare_equal(self, prospective: LegacyVersion, spec: str) -> bool:
         return prospective == self._coerce_version(spec)
 
-    def _compare_not_equal(self, prospective, spec):
-        # type: (LegacyVersion, str) -> bool
+    def _compare_not_equal(self, prospective: LegacyVersion, spec: str) -> bool:
         return prospective != self._coerce_version(spec)
 
-    def _compare_less_than_equal(self, prospective, spec):
-        # type: (LegacyVersion, str) -> bool
+    def _compare_less_than_equal(self, prospective: LegacyVersion, spec: str) -> bool:
         return prospective <= self._coerce_version(spec)
 
-    def _compare_greater_than_equal(self, prospective, spec):
-        # type: (LegacyVersion, str) -> bool
+    def _compare_greater_than_equal(
+        self, prospective: LegacyVersion, spec: str
+    ) -> bool:
         return prospective >= self._coerce_version(spec)
 
-    def _compare_less_than(self, prospective, spec):
-        # type: (LegacyVersion, str) -> bool
+    def _compare_less_than(self, prospective: LegacyVersion, spec: str) -> bool:
         return prospective < self._coerce_version(spec)
 
-    def _compare_greater_than(self, prospective, spec):
-        # type: (LegacyVersion, str) -> bool
+    def _compare_greater_than(self, prospective: LegacyVersion, spec: str) -> bool:
         return prospective > self._coerce_version(spec)
 
 
 def _require_version_compare(
-    fn,  # type: (Callable[[Specifier, ParsedVersion, str], bool])
-):
-    # type: (...) -> Callable[[Specifier, ParsedVersion, str], bool]
+    fn: Callable[["Specifier", ParsedVersion, str], bool]
+) -> Callable[["Specifier", ParsedVersion, str], bool]:
     @functools.wraps(fn)
-    def wrapped(self, prospective, spec):
-        # type: (Specifier, ParsedVersion, str) -> bool
+    def wrapped(self: "Specifier", prospective: ParsedVersion, spec: str) -> bool:
         if not isinstance(prospective, Version):
             return False
         return fn(self, prospective, spec)
@@ -440,8 +405,7 @@ class Specifier(_IndividualSpecifier):
     }
 
     @_require_version_compare
-    def _compare_compatible(self, prospective, spec):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_compatible(self, prospective: ParsedVersion, spec: str) -> bool:
 
         # Compatible releases have an equivalent combination of >= and ==. That
         # is that ~=2.2 is equivalent to >=2.2,==2.*. This allows us to
@@ -450,15 +414,9 @@ class Specifier(_IndividualSpecifier):
         # the other specifiers.
 
         # We want everything but the last item in the version, but we want to
-        # ignore post and dev releases and we want to treat the pre-release as
-        # it's own separate segment.
+        # ignore suffix segments.
         prefix = ".".join(
-            list(
-                itertools.takewhile(
-                    lambda x: (not x.startswith("post") and not x.startswith("dev")),
-                    _version_split(spec),
-                )
-            )[:-1]
+            list(itertools.takewhile(_is_not_suffix, _version_split(spec)))[:-1]
         )
 
         # Add the prefix notation to the end of our string
@@ -469,8 +427,7 @@ class Specifier(_IndividualSpecifier):
         )
 
     @_require_version_compare
-    def _compare_equal(self, prospective, spec):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_equal(self, prospective: ParsedVersion, spec: str) -> bool:
 
         # We need special logic to handle prefix matching
         if spec.endswith(".*"):
@@ -510,13 +467,11 @@ class Specifier(_IndividualSpecifier):
             return prospective == spec_version
 
     @_require_version_compare
-    def _compare_not_equal(self, prospective, spec):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_not_equal(self, prospective: ParsedVersion, spec: str) -> bool:
         return not self._compare_equal(prospective, spec)
 
     @_require_version_compare
-    def _compare_less_than_equal(self, prospective, spec):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_less_than_equal(self, prospective: ParsedVersion, spec: str) -> bool:
 
         # NB: Local version identifiers are NOT permitted in the version
         # specifier, so local version labels can be universally removed from
@@ -524,8 +479,9 @@ class Specifier(_IndividualSpecifier):
         return Version(prospective.public) <= Version(spec)
 
     @_require_version_compare
-    def _compare_greater_than_equal(self, prospective, spec):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_greater_than_equal(
+        self, prospective: ParsedVersion, spec: str
+    ) -> bool:
 
         # NB: Local version identifiers are NOT permitted in the version
         # specifier, so local version labels can be universally removed from
@@ -533,8 +489,7 @@ class Specifier(_IndividualSpecifier):
         return Version(prospective.public) >= Version(spec)
 
     @_require_version_compare
-    def _compare_less_than(self, prospective, spec_str):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_less_than(self, prospective: ParsedVersion, spec_str: str) -> bool:
 
         # Convert our spec to a Version instance, since we'll want to work with
         # it as a version.
@@ -560,8 +515,7 @@ class Specifier(_IndividualSpecifier):
         return True
 
     @_require_version_compare
-    def _compare_greater_than(self, prospective, spec_str):
-        # type: (ParsedVersion, str) -> bool
+    def _compare_greater_than(self, prospective: ParsedVersion, spec_str: str) -> bool:
 
         # Convert our spec to a Version instance, since we'll want to work with
         # it as a version.
@@ -592,13 +546,11 @@ class Specifier(_IndividualSpecifier):
         # same version in the spec.
         return True
 
-    def _compare_arbitrary(self, prospective, spec):
-        # type: (Version, str) -> bool
+    def _compare_arbitrary(self, prospective: Version, spec: str) -> bool:
         return str(prospective).lower() == str(spec).lower()
 
     @property
-    def prereleases(self):
-        # type: () -> bool
+    def prereleases(self) -> bool:
 
         # If there is an explicit prereleases set for this, then we'll just
         # blindly use that.
@@ -623,17 +575,15 @@ class Specifier(_IndividualSpecifier):
         return False
 
     @prereleases.setter
-    def prereleases(self, value):
-        # type: (bool) -> None
+    def prereleases(self, value: bool) -> None:
         self._prereleases = value
 
 
 _prefix_regex = re.compile(r"^([0-9]+)((?:a|b|c|rc)[0-9]+)$")
 
 
-def _version_split(version):
-    # type: (str) -> List[str]
-    result = []  # type: List[str]
+def _version_split(version: str) -> List[str]:
+    result: List[str] = []
     for item in version.split("."):
         match = _prefix_regex.search(item)
         if match:
@@ -643,8 +593,13 @@ def _version_split(version):
     return result
 
 
-def _pad_version(left, right):
-    # type: (List[str], List[str]) -> Tuple[List[str], List[str]]
+def _is_not_suffix(segment: str) -> bool:
+    return not any(
+        segment.startswith(prefix) for prefix in ("dev", "a", "b", "rc", "post")
+    )
+
+
+def _pad_version(left: List[str], right: List[str]) -> Tuple[List[str], List[str]]:
     left_split, right_split = [], []
 
     # Get the release segment of our versions
@@ -663,8 +618,9 @@ def _pad_version(left, right):
 
 
 class SpecifierSet(BaseSpecifier):
-    def __init__(self, specifiers="", prereleases=None):
-        # type: (str, Optional[bool]) -> None
+    def __init__(
+        self, specifiers: str = "", prereleases: Optional[bool] = None
+    ) -> None:
 
         # Split on , to break each individual specifier into it's own item, and
         # strip each item to remove leading/trailing whitespace.
@@ -672,7 +628,7 @@ class SpecifierSet(BaseSpecifier):
 
         # Parsed each individual specifier, attempting first to make it a
         # Specifier and falling back to a LegacySpecifier.
-        parsed = set()
+        parsed: Set[_IndividualSpecifier] = set()
         for specifier in split_specifiers:
             try:
                 parsed.add(Specifier(specifier))
@@ -686,27 +642,23 @@ class SpecifierSet(BaseSpecifier):
         # we accept prereleases or not.
         self._prereleases = prereleases
 
-    def __repr__(self):
-        # type: () -> str
+    def __repr__(self) -> str:
         pre = (
-            ", prereleases={0!r}".format(self.prereleases)
+            f", prereleases={self.prereleases!r}"
             if self._prereleases is not None
             else ""
         )
 
-        return "<SpecifierSet({0!r}{1})>".format(str(self), pre)
+        return f"<SpecifierSet({str(self)!r}{pre})>"
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return ",".join(sorted(str(s) for s in self._specs))
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(self._specs)
 
-    def __and__(self, other):
-        # type: (Union[SpecifierSet, str]) -> SpecifierSet
-        if isinstance(other, string_types):
+    def __and__(self, other: Union["SpecifierSet", str]) -> "SpecifierSet":
+        if isinstance(other, str):
             other = SpecifierSet(other)
         elif not isinstance(other, SpecifierSet):
             return NotImplemented
@@ -728,35 +680,22 @@ class SpecifierSet(BaseSpecifier):
 
         return specifier
 
-    def __eq__(self, other):
-        # type: (object) -> bool
-        if isinstance(other, (string_types, _IndividualSpecifier)):
+    def __eq__(self, other: object) -> bool:
+        if isinstance(other, (str, _IndividualSpecifier)):
             other = SpecifierSet(str(other))
         elif not isinstance(other, SpecifierSet):
             return NotImplemented
 
         return self._specs == other._specs
 
-    def __ne__(self, other):
-        # type: (object) -> bool
-        if isinstance(other, (string_types, _IndividualSpecifier)):
-            other = SpecifierSet(str(other))
-        elif not isinstance(other, SpecifierSet):
-            return NotImplemented
-
-        return self._specs != other._specs
-
-    def __len__(self):
-        # type: () -> int
+    def __len__(self) -> int:
         return len(self._specs)
 
-    def __iter__(self):
-        # type: () -> Iterator[_IndividualSpecifier]
+    def __iter__(self) -> Iterator[_IndividualSpecifier]:
         return iter(self._specs)
 
     @property
-    def prereleases(self):
-        # type: () -> Optional[bool]
+    def prereleases(self) -> Optional[bool]:
 
         # If we have been given an explicit prerelease modifier, then we'll
         # pass that through here.
@@ -774,16 +713,15 @@ class SpecifierSet(BaseSpecifier):
         return any(s.prereleases for s in self._specs)
 
     @prereleases.setter
-    def prereleases(self, value):
-        # type: (bool) -> None
+    def prereleases(self, value: bool) -> None:
         self._prereleases = value
 
-    def __contains__(self, item):
-        # type: (Union[ParsedVersion, str]) -> bool
+    def __contains__(self, item: UnparsedVersion) -> bool:
         return self.contains(item)
 
-    def contains(self, item, prereleases=None):
-        # type: (Union[ParsedVersion, str], Optional[bool]) -> bool
+    def contains(
+        self, item: UnparsedVersion, prereleases: Optional[bool] = None
+    ) -> bool:
 
         # Ensure that our item is a Version or LegacyVersion instance.
         if not isinstance(item, (LegacyVersion, Version)):
@@ -811,11 +749,8 @@ class SpecifierSet(BaseSpecifier):
         return all(s.contains(item, prereleases=prereleases) for s in self._specs)
 
     def filter(
-        self,
-        iterable,  # type: Iterable[Union[ParsedVersion, str]]
-        prereleases=None,  # type: Optional[bool]
-    ):
-        # type: (...) -> Iterable[Union[ParsedVersion, str]]
+        self, iterable: Iterable[VersionTypeVar], prereleases: Optional[bool] = None
+    ) -> Iterable[VersionTypeVar]:
 
         # Determine if we're forcing a prerelease or not, if we're not forcing
         # one for this particular filter call, then we'll use whatever the
@@ -834,8 +769,11 @@ class SpecifierSet(BaseSpecifier):
         # which will filter out any pre-releases, unless there are no final
         # releases, and which will filter out LegacyVersion in general.
         else:
-            filtered = []  # type: List[Union[ParsedVersion, str]]
-            found_prereleases = []  # type: List[Union[ParsedVersion, str]]
+            filtered: List[VersionTypeVar] = []
+            found_prereleases: List[VersionTypeVar] = []
+
+            item: UnparsedVersion
+            parsed_version: Union[Version, LegacyVersion]
 
             for item in iterable:
                 # Ensure that we some kind of Version class for this item.
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/tags.py b/env/Lib/site-packages/pip/_vendor/packaging/tags.py
index d637f1b6..9a3d25a7 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/tags.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/tags.py
@@ -2,81 +2,44 @@
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
 
-from __future__ import absolute_import
-
-import distutils.util
-
-try:
-    from importlib.machinery import EXTENSION_SUFFIXES
-except ImportError:  # pragma: no cover
-    import imp
-
-    EXTENSION_SUFFIXES = [x[0] for x in imp.get_suffixes()]
-    del imp
-import collections
 import logging
-import os
 import platform
-import re
-import struct
 import sys
 import sysconfig
-import warnings
-
-from ._typing import TYPE_CHECKING, cast
-
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import (
-        IO,
-        Dict,
-        FrozenSet,
-        Iterable,
-        Iterator,
-        List,
-        Optional,
-        Sequence,
-        Tuple,
-        Union,
-    )
-
-    PythonVersion = Sequence[int]
-    MacVersion = Tuple[int, int]
-    GlibcVersion = Tuple[int, int]
-
+from importlib.machinery import EXTENSION_SUFFIXES
+from typing import (
+    Dict,
+    FrozenSet,
+    Iterable,
+    Iterator,
+    List,
+    Optional,
+    Sequence,
+    Tuple,
+    Union,
+    cast,
+)
+
+from . import _manylinux, _musllinux
 
 logger = logging.getLogger(__name__)
 
-INTERPRETER_SHORT_NAMES = {
+PythonVersion = Sequence[int]
+MacVersion = Tuple[int, int]
+
+INTERPRETER_SHORT_NAMES: Dict[str, str] = {
     "python": "py",  # Generic.
     "cpython": "cp",
     "pypy": "pp",
     "ironpython": "ip",
     "jython": "jy",
-}  # type: Dict[str, str]
+}
 
 
 _32_BIT_INTERPRETER = sys.maxsize <= 2 ** 32
 
 
-_LEGACY_MANYLINUX_MAP = {
-    # CentOS 7 w/ glibc 2.17 (PEP 599)
-    (2, 17): "manylinux2014",
-    # CentOS 6 w/ glibc 2.12 (PEP 571)
-    (2, 12): "manylinux2010",
-    # CentOS 5 w/ glibc 2.5 (PEP 513)
-    (2, 5): "manylinux1",
-}
-
-# If glibc ever changes its major version, we need to know what the last
-# minor version was, so we can build the complete list of all versions.
-# For now, guess what the highest minor version might be, assume it will
-# be 50 for testing. Once this actually happens, update the dictionary
-# with the actual value.
-_LAST_GLIBC_MINOR = collections.defaultdict(lambda: 50)  # type: Dict[int, int]
-glibcVersion = collections.namedtuple("Version", ["major", "minor"])
-
-
-class Tag(object):
+class Tag:
     """
     A representation of the tag triple for a wheel.
 
@@ -86,8 +49,7 @@ class Tag(object):
 
     __slots__ = ["_interpreter", "_abi", "_platform", "_hash"]
 
-    def __init__(self, interpreter, abi, platform):
-        # type: (str, str, str) -> None
+    def __init__(self, interpreter: str, abi: str, platform: str) -> None:
         self._interpreter = interpreter.lower()
         self._abi = abi.lower()
         self._platform = platform.lower()
@@ -99,46 +61,39 @@ class Tag(object):
         self._hash = hash((self._interpreter, self._abi, self._platform))
 
     @property
-    def interpreter(self):
-        # type: () -> str
+    def interpreter(self) -> str:
         return self._interpreter
 
     @property
-    def abi(self):
-        # type: () -> str
+    def abi(self) -> str:
         return self._abi
 
     @property
-    def platform(self):
-        # type: () -> str
+    def platform(self) -> str:
         return self._platform
 
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         if not isinstance(other, Tag):
             return NotImplemented
 
         return (
-            (self.platform == other.platform)
-            and (self.abi == other.abi)
-            and (self.interpreter == other.interpreter)
+            (self._hash == other._hash)  # Short-circuit ASAP for perf reasons.
+            and (self._platform == other._platform)
+            and (self._abi == other._abi)
+            and (self._interpreter == other._interpreter)
         )
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return self._hash
 
-    def __str__(self):
-        # type: () -> str
-        return "{}-{}-{}".format(self._interpreter, self._abi, self._platform)
+    def __str__(self) -> str:
+        return f"{self._interpreter}-{self._abi}-{self._platform}"
 
-    def __repr__(self):
-        # type: () -> str
-        return "<{self} @ {self_id}>".format(self=self, self_id=id(self))
+    def __repr__(self) -> str:
+        return f"<{self} @ {id(self)}>"
 
 
-def parse_tag(tag):
-    # type: (str) -> FrozenSet[Tag]
+def parse_tag(tag: str) -> FrozenSet[Tag]:
     """
     Parses the provided tag (e.g. `py3-none-any`) into a frozenset of Tag instances.
 
@@ -154,24 +109,7 @@ def parse_tag(tag):
     return frozenset(tags)
 
 
-def _warn_keyword_parameter(func_name, kwargs):
-    # type: (str, Dict[str, bool]) -> bool
-    """
-    Backwards-compatibility with Python 2.7 to allow treating 'warn' as keyword-only.
-    """
-    if not kwargs:
-        return False
-    elif len(kwargs) > 1 or "warn" not in kwargs:
-        kwargs.pop("warn", None)
-        arg = next(iter(kwargs.keys()))
-        raise TypeError(
-            "{}() got an unexpected keyword argument {!r}".format(func_name, arg)
-        )
-    return kwargs["warn"]
-
-
-def _get_config_var(name, warn=False):
-    # type: (str, bool) -> Union[int, str, None]
+def _get_config_var(name: str, warn: bool = False) -> Union[int, str, None]:
     value = sysconfig.get_config_var(name)
     if value is None and warn:
         logger.debug(
@@ -180,13 +118,11 @@ def _get_config_var(name, warn=False):
     return value
 
 
-def _normalize_string(string):
-    # type: (str) -> str
+def _normalize_string(string: str) -> str:
     return string.replace(".", "_").replace("-", "_")
 
 
-def _abi3_applies(python_version):
-    # type: (PythonVersion) -> bool
+def _abi3_applies(python_version: PythonVersion) -> bool:
     """
     Determine if the Python version supports abi3.
 
@@ -195,8 +131,7 @@ def _abi3_applies(python_version):
     return len(python_version) > 1 and tuple(python_version) >= (3, 2)
 
 
-def _cpython_abis(py_version, warn=False):
-    # type: (PythonVersion, bool) -> List[str]
+def _cpython_abis(py_version: PythonVersion, warn: bool = False) -> List[str]:
     py_version = tuple(py_version)  # To allow for version comparison.
     abis = []
     version = _version_nodot(py_version[:2])
@@ -222,7 +157,7 @@ def _cpython_abis(py_version, warn=False):
     elif debug:
         # Debug builds can also load "normal" extension modules.
         # We can also assume no UCS-4 or pymalloc requirement.
-        abis.append("cp{version}".format(version=version))
+        abis.append(f"cp{version}")
     abis.insert(
         0,
         "cp{version}{debug}{pymalloc}{ucs4}".format(
@@ -233,12 +168,12 @@ def _cpython_abis(py_version, warn=False):
 
 
 def cpython_tags(
-    python_version=None,  # type: Optional[PythonVersion]
-    abis=None,  # type: Optional[Iterable[str]]
-    platforms=None,  # type: Optional[Iterable[str]]
-    **kwargs  # type: bool
-):
-    # type: (...) -> Iterator[Tag]
+    python_version: Optional[PythonVersion] = None,
+    abis: Optional[Iterable[str]] = None,
+    platforms: Optional[Iterable[str]] = None,
+    *,
+    warn: bool = False,
+) -> Iterator[Tag]:
     """
     Yields the tags for a CPython interpreter.
 
@@ -254,11 +189,10 @@ def cpython_tags(
     If 'abi3' or 'none' are specified in 'abis' then they will be yielded at
     their normal position and not at the beginning.
     """
-    warn = _warn_keyword_parameter("cpython_tags", kwargs)
     if not python_version:
         python_version = sys.version_info[:2]
 
-    interpreter = "cp{}".format(_version_nodot(python_version[:2]))
+    interpreter = f"cp{_version_nodot(python_version[:2])}"
 
     if abis is None:
         if len(python_version) > 1:
@@ -273,15 +207,13 @@ def cpython_tags(
         except ValueError:
             pass
 
-    platforms = list(platforms or _platform_tags())
+    platforms = list(platforms or platform_tags())
     for abi in abis:
         for platform_ in platforms:
             yield Tag(interpreter, abi, platform_)
     if _abi3_applies(python_version):
-        for tag in (Tag(interpreter, "abi3", platform_) for platform_ in platforms):
-            yield tag
-    for tag in (Tag(interpreter, "none", platform_) for platform_ in platforms):
-        yield tag
+        yield from (Tag(interpreter, "abi3", platform_) for platform_ in platforms)
+    yield from (Tag(interpreter, "none", platform_) for platform_ in platforms)
 
     if _abi3_applies(python_version):
         for minor_version in range(python_version[1] - 1, 1, -1):
@@ -292,20 +224,19 @@ def cpython_tags(
                 yield Tag(interpreter, "abi3", platform_)
 
 
-def _generic_abi():
-    # type: () -> Iterator[str]
+def _generic_abi() -> Iterator[str]:
     abi = sysconfig.get_config_var("SOABI")
     if abi:
         yield _normalize_string(abi)
 
 
 def generic_tags(
-    interpreter=None,  # type: Optional[str]
-    abis=None,  # type: Optional[Iterable[str]]
-    platforms=None,  # type: Optional[Iterable[str]]
-    **kwargs  # type: bool
-):
-    # type: (...) -> Iterator[Tag]
+    interpreter: Optional[str] = None,
+    abis: Optional[Iterable[str]] = None,
+    platforms: Optional[Iterable[str]] = None,
+    *,
+    warn: bool = False,
+) -> Iterator[Tag]:
     """
     Yields the tags for a generic interpreter.
 
@@ -314,14 +245,13 @@ def generic_tags(
 
     The "none" ABI will be added if it was not explicitly provided.
     """
-    warn = _warn_keyword_parameter("generic_tags", kwargs)
     if not interpreter:
         interp_name = interpreter_name()
         interp_version = interpreter_version(warn=warn)
         interpreter = "".join([interp_name, interp_version])
     if abis is None:
         abis = _generic_abi()
-    platforms = list(platforms or _platform_tags())
+    platforms = list(platforms or platform_tags())
     abis = list(abis)
     if "none" not in abis:
         abis.append("none")
@@ -330,8 +260,7 @@ def generic_tags(
             yield Tag(interpreter, abi, platform_)
 
 
-def _py_interpreter_range(py_version):
-    # type: (PythonVersion) -> Iterator[str]
+def _py_interpreter_range(py_version: PythonVersion) -> Iterator[str]:
     """
     Yields Python versions in descending order.
 
@@ -339,19 +268,18 @@ def _py_interpreter_range(py_version):
     all previous versions of that major version.
     """
     if len(py_version) > 1:
-        yield "py{version}".format(version=_version_nodot(py_version[:2]))
-    yield "py{major}".format(major=py_version[0])
+        yield f"py{_version_nodot(py_version[:2])}"
+    yield f"py{py_version[0]}"
     if len(py_version) > 1:
         for minor in range(py_version[1] - 1, -1, -1):
-            yield "py{version}".format(version=_version_nodot((py_version[0], minor)))
+            yield f"py{_version_nodot((py_version[0], minor))}"
 
 
 def compatible_tags(
-    python_version=None,  # type: Optional[PythonVersion]
-    interpreter=None,  # type: Optional[str]
-    platforms=None,  # type: Optional[Iterable[str]]
-):
-    # type: (...) -> Iterator[Tag]
+    python_version: Optional[PythonVersion] = None,
+    interpreter: Optional[str] = None,
+    platforms: Optional[Iterable[str]] = None,
+) -> Iterator[Tag]:
     """
     Yields the sequence of tags that are compatible with a specific version of Python.
 
@@ -362,7 +290,7 @@ def compatible_tags(
     """
     if not python_version:
         python_version = sys.version_info[:2]
-    platforms = list(platforms or _platform_tags())
+    platforms = list(platforms or platform_tags())
     for version in _py_interpreter_range(python_version):
         for platform_ in platforms:
             yield Tag(version, "none", platform_)
@@ -372,8 +300,7 @@ def compatible_tags(
         yield Tag(version, "none", "any")
 
 
-def _mac_arch(arch, is_32bit=_32_BIT_INTERPRETER):
-    # type: (str, bool) -> str
+def _mac_arch(arch: str, is_32bit: bool = _32_BIT_INTERPRETER) -> str:
     if not is_32bit:
         return arch
 
@@ -383,8 +310,7 @@ def _mac_arch(arch, is_32bit=_32_BIT_INTERPRETER):
     return "i386"
 
 
-def _mac_binary_formats(version, cpu_arch):
-    # type: (MacVersion, str) -> List[str]
+def _mac_binary_formats(version: MacVersion, cpu_arch: str) -> List[str]:
     formats = [cpu_arch]
     if cpu_arch == "x86_64":
         if version < (10, 4):
@@ -416,8 +342,9 @@ def _mac_binary_formats(version, cpu_arch):
     return formats
 
 
-def mac_platforms(version=None, arch=None):
-    # type: (Optional[MacVersion], Optional[str]) -> Iterator[str]
+def mac_platforms(
+    version: Optional[MacVersion] = None, arch: Optional[str] = None
+) -> Iterator[str]:
     """
     Yields the platform tags for a macOS system.
 
@@ -426,7 +353,7 @@ def mac_platforms(version=None, arch=None):
     generate platform tags for. Both parameters default to the appropriate value
     for the current system.
     """
-    version_str, _, cpu_arch = platform.mac_ver()  # type: ignore
+    version_str, _, cpu_arch = platform.mac_ver()
     if version is None:
         version = cast("MacVersion", tuple(map(int, version_str.split(".")[:2])))
     else:
@@ -487,320 +414,24 @@ def mac_platforms(version=None, arch=None):
                 )
 
 
-# From PEP 513, PEP 600
-def _is_manylinux_compatible(name, arch, glibc_version):
-    # type: (str, str, GlibcVersion) -> bool
-    sys_glibc = _get_glibc_version()
-    if sys_glibc < glibc_version:
-        return False
-    # Check for presence of _manylinux module.
-    try:
-        import _manylinux  # noqa
-    except ImportError:
-        pass
-    else:
-        if hasattr(_manylinux, "manylinux_compatible"):
-            result = _manylinux.manylinux_compatible(
-                glibc_version[0], glibc_version[1], arch
-            )
-            if result is not None:
-                return bool(result)
-        else:
-            if glibc_version == (2, 5):
-                if hasattr(_manylinux, "manylinux1_compatible"):
-                    return bool(_manylinux.manylinux1_compatible)
-            if glibc_version == (2, 12):
-                if hasattr(_manylinux, "manylinux2010_compatible"):
-                    return bool(_manylinux.manylinux2010_compatible)
-            if glibc_version == (2, 17):
-                if hasattr(_manylinux, "manylinux2014_compatible"):
-                    return bool(_manylinux.manylinux2014_compatible)
-    return True
-
-
-def _glibc_version_string():
-    # type: () -> Optional[str]
-    # Returns glibc version string, or None if not using glibc.
-    return _glibc_version_string_confstr() or _glibc_version_string_ctypes()
-
-
-def _glibc_version_string_confstr():
-    # type: () -> Optional[str]
-    """
-    Primary implementation of glibc_version_string using os.confstr.
-    """
-    # os.confstr is quite a bit faster than ctypes.DLL. It's also less likely
-    # to be broken or missing. This strategy is used in the standard library
-    # platform module.
-    # https://github.com/python/cpython/blob/fcf1d003bf4f0100c9d0921ff3d70e1127ca1b71/Lib/platform.py#L175-L183
-    try:
-        # os.confstr("CS_GNU_LIBC_VERSION") returns a string like "glibc 2.17".
-        version_string = os.confstr(  # type: ignore[attr-defined] # noqa: F821
-            "CS_GNU_LIBC_VERSION"
-        )
-        assert version_string is not None
-        _, version = version_string.split()  # type: Tuple[str, str]
-    except (AssertionError, AttributeError, OSError, ValueError):
-        # os.confstr() or CS_GNU_LIBC_VERSION not available (or a bad value)...
-        return None
-    return version
-
-
-def _glibc_version_string_ctypes():
-    # type: () -> Optional[str]
-    """
-    Fallback implementation of glibc_version_string using ctypes.
-    """
-    try:
-        import ctypes
-    except ImportError:
-        return None
-
-    # ctypes.CDLL(None) internally calls dlopen(NULL), and as the dlopen
-    # manpage says, "If filename is NULL, then the returned handle is for the
-    # main program". This way we can let the linker do the work to figure out
-    # which libc our process is actually using.
-    #
-    # We must also handle the special case where the executable is not a
-    # dynamically linked executable. This can occur when using musl libc,
-    # for example. In this situation, dlopen() will error, leading to an
-    # OSError. Interestingly, at least in the case of musl, there is no
-    # errno set on the OSError. The single string argument used to construct
-    # OSError comes from libc itself and is therefore not portable to
-    # hard code here. In any case, failure to call dlopen() means we
-    # can proceed, so we bail on our attempt.
-    try:
-        # Note: typeshed is wrong here so we are ignoring this line.
-        process_namespace = ctypes.CDLL(None)  # type: ignore
-    except OSError:
-        return None
-
-    try:
-        gnu_get_libc_version = process_namespace.gnu_get_libc_version
-    except AttributeError:
-        # Symbol doesn't exist -> therefore, we are not linked to
-        # glibc.
-        return None
-
-    # Call gnu_get_libc_version, which returns a string like "2.5"
-    gnu_get_libc_version.restype = ctypes.c_char_p
-    version_str = gnu_get_libc_version()  # type: str
-    # py2 / py3 compatibility:
-    if not isinstance(version_str, str):
-        version_str = version_str.decode("ascii")
-
-    return version_str
-
-
-def _parse_glibc_version(version_str):
-    # type: (str) -> Tuple[int, int]
-    # Parse glibc version.
-    #
-    # We use a regexp instead of str.split because we want to discard any
-    # random junk that might come after the minor version -- this might happen
-    # in patched/forked versions of glibc (e.g. Linaro's version of glibc
-    # uses version strings like "2.20-2014.11"). See gh-3588.
-    m = re.match(r"(?P<major>[0-9]+)\.(?P<minor>[0-9]+)", version_str)
-    if not m:
-        warnings.warn(
-            "Expected glibc version with 2 components major.minor,"
-            " got: %s" % version_str,
-            RuntimeWarning,
-        )
-        return -1, -1
-    return (int(m.group("major")), int(m.group("minor")))
-
-
-_glibc_version = []  #  type: List[Tuple[int, int]]
-
-
-def _get_glibc_version():
-    # type: () -> Tuple[int, int]
-    if _glibc_version:
-        return _glibc_version[0]
-    version_str = _glibc_version_string()
-    if version_str is None:
-        _glibc_version.append((-1, -1))
-    else:
-        _glibc_version.append(_parse_glibc_version(version_str))
-    return _glibc_version[0]
-
-
-# Python does not provide platform information at sufficient granularity to
-# identify the architecture of the running executable in some cases, so we
-# determine it dynamically by reading the information from the running
-# process. This only applies on Linux, which uses the ELF format.
-class _ELFFileHeader(object):
-    # https://en.wikipedia.org/wiki/Executable_and_Linkable_Format#File_header
-    class _InvalidELFFileHeader(ValueError):
-        """
-        An invalid ELF file header was found.
-        """
-
-    ELF_MAGIC_NUMBER = 0x7F454C46
-    ELFCLASS32 = 1
-    ELFCLASS64 = 2
-    ELFDATA2LSB = 1
-    ELFDATA2MSB = 2
-    EM_386 = 3
-    EM_S390 = 22
-    EM_ARM = 40
-    EM_X86_64 = 62
-    EF_ARM_ABIMASK = 0xFF000000
-    EF_ARM_ABI_VER5 = 0x05000000
-    EF_ARM_ABI_FLOAT_HARD = 0x00000400
-
-    def __init__(self, file):
-        # type: (IO[bytes]) -> None
-        def unpack(fmt):
-            # type: (str) -> int
-            try:
-                (result,) = struct.unpack(
-                    fmt, file.read(struct.calcsize(fmt))
-                )  # type: (int, )
-            except struct.error:
-                raise _ELFFileHeader._InvalidELFFileHeader()
-            return result
-
-        self.e_ident_magic = unpack(">I")
-        if self.e_ident_magic != self.ELF_MAGIC_NUMBER:
-            raise _ELFFileHeader._InvalidELFFileHeader()
-        self.e_ident_class = unpack("B")
-        if self.e_ident_class not in {self.ELFCLASS32, self.ELFCLASS64}:
-            raise _ELFFileHeader._InvalidELFFileHeader()
-        self.e_ident_data = unpack("B")
-        if self.e_ident_data not in {self.ELFDATA2LSB, self.ELFDATA2MSB}:
-            raise _ELFFileHeader._InvalidELFFileHeader()
-        self.e_ident_version = unpack("B")
-        self.e_ident_osabi = unpack("B")
-        self.e_ident_abiversion = unpack("B")
-        self.e_ident_pad = file.read(7)
-        format_h = "<H" if self.e_ident_data == self.ELFDATA2LSB else ">H"
-        format_i = "<I" if self.e_ident_data == self.ELFDATA2LSB else ">I"
-        format_q = "<Q" if self.e_ident_data == self.ELFDATA2LSB else ">Q"
-        format_p = format_i if self.e_ident_class == self.ELFCLASS32 else format_q
-        self.e_type = unpack(format_h)
-        self.e_machine = unpack(format_h)
-        self.e_version = unpack(format_i)
-        self.e_entry = unpack(format_p)
-        self.e_phoff = unpack(format_p)
-        self.e_shoff = unpack(format_p)
-        self.e_flags = unpack(format_i)
-        self.e_ehsize = unpack(format_h)
-        self.e_phentsize = unpack(format_h)
-        self.e_phnum = unpack(format_h)
-        self.e_shentsize = unpack(format_h)
-        self.e_shnum = unpack(format_h)
-        self.e_shstrndx = unpack(format_h)
-
-
-def _get_elf_header():
-    # type: () -> Optional[_ELFFileHeader]
-    try:
-        with open(sys.executable, "rb") as f:
-            elf_header = _ELFFileHeader(f)
-    except (IOError, OSError, TypeError, _ELFFileHeader._InvalidELFFileHeader):
-        return None
-    return elf_header
-
-
-def _is_linux_armhf():
-    # type: () -> bool
-    # hard-float ABI can be detected from the ELF header of the running
-    # process
-    # https://static.docs.arm.com/ihi0044/g/aaelf32.pdf
-    elf_header = _get_elf_header()
-    if elf_header is None:
-        return False
-    result = elf_header.e_ident_class == elf_header.ELFCLASS32
-    result &= elf_header.e_ident_data == elf_header.ELFDATA2LSB
-    result &= elf_header.e_machine == elf_header.EM_ARM
-    result &= (
-        elf_header.e_flags & elf_header.EF_ARM_ABIMASK
-    ) == elf_header.EF_ARM_ABI_VER5
-    result &= (
-        elf_header.e_flags & elf_header.EF_ARM_ABI_FLOAT_HARD
-    ) == elf_header.EF_ARM_ABI_FLOAT_HARD
-    return result
-
-
-def _is_linux_i686():
-    # type: () -> bool
-    elf_header = _get_elf_header()
-    if elf_header is None:
-        return False
-    result = elf_header.e_ident_class == elf_header.ELFCLASS32
-    result &= elf_header.e_ident_data == elf_header.ELFDATA2LSB
-    result &= elf_header.e_machine == elf_header.EM_386
-    return result
-
-
-def _have_compatible_manylinux_abi(arch):
-    # type: (str) -> bool
-    if arch == "armv7l":
-        return _is_linux_armhf()
-    if arch == "i686":
-        return _is_linux_i686()
-    return arch in {"x86_64", "aarch64", "ppc64", "ppc64le", "s390x"}
-
-
-def _manylinux_tags(linux, arch):
-    # type: (str, str) -> Iterator[str]
-    # Oldest glibc to be supported regardless of architecture is (2, 17).
-    too_old_glibc2 = glibcVersion(2, 16)
-    if arch in {"x86_64", "i686"}:
-        # On x86/i686 also oldest glibc to be supported is (2, 5).
-        too_old_glibc2 = glibcVersion(2, 4)
-    current_glibc = glibcVersion(*_get_glibc_version())
-    glibc_max_list = [current_glibc]
-    # We can assume compatibility across glibc major versions.
-    # https://sourceware.org/bugzilla/show_bug.cgi?id=24636
-    #
-    # Build a list of maximum glibc versions so that we can
-    # output the canonical list of all glibc from current_glibc
-    # down to too_old_glibc2, including all intermediary versions.
-    for glibc_major in range(current_glibc.major - 1, 1, -1):
-        glibc_max_list.append(glibcVersion(glibc_major, _LAST_GLIBC_MINOR[glibc_major]))
-    for glibc_max in glibc_max_list:
-        if glibc_max.major == too_old_glibc2.major:
-            min_minor = too_old_glibc2.minor
-        else:
-            # For other glibc major versions oldest supported is (x, 0).
-            min_minor = -1
-        for glibc_minor in range(glibc_max.minor, min_minor, -1):
-            glibc_version = (glibc_max.major, glibc_minor)
-            tag = "manylinux_{}_{}".format(*glibc_version)
-            if _is_manylinux_compatible(tag, arch, glibc_version):
-                yield linux.replace("linux", tag)
-            # Handle the legacy manylinux1, manylinux2010, manylinux2014 tags.
-            if glibc_version in _LEGACY_MANYLINUX_MAP:
-                legacy_tag = _LEGACY_MANYLINUX_MAP[glibc_version]
-                if _is_manylinux_compatible(legacy_tag, arch, glibc_version):
-                    yield linux.replace("linux", legacy_tag)
-
-
-def _linux_platforms(is_32bit=_32_BIT_INTERPRETER):
-    # type: (bool) -> Iterator[str]
-    linux = _normalize_string(distutils.util.get_platform())
+def _linux_platforms(is_32bit: bool = _32_BIT_INTERPRETER) -> Iterator[str]:
+    linux = _normalize_string(sysconfig.get_platform())
     if is_32bit:
         if linux == "linux_x86_64":
             linux = "linux_i686"
         elif linux == "linux_aarch64":
             linux = "linux_armv7l"
     _, arch = linux.split("_", 1)
-    if _have_compatible_manylinux_abi(arch):
-        for tag in _manylinux_tags(linux, arch):
-            yield tag
+    yield from _manylinux.platform_tags(linux, arch)
+    yield from _musllinux.platform_tags(arch)
     yield linux
 
 
-def _generic_platforms():
-    # type: () -> Iterator[str]
-    yield _normalize_string(distutils.util.get_platform())
+def _generic_platforms() -> Iterator[str]:
+    yield _normalize_string(sysconfig.get_platform())
 
 
-def _platform_tags():
-    # type: () -> Iterator[str]
+def platform_tags() -> Iterator[str]:
     """
     Provides the platform tags for this installation.
     """
@@ -812,25 +443,18 @@ def _platform_tags():
         return _generic_platforms()
 
 
-def interpreter_name():
-    # type: () -> str
+def interpreter_name() -> str:
     """
     Returns the name of the running interpreter.
     """
-    try:
-        name = sys.implementation.name  # type: ignore
-    except AttributeError:  # pragma: no cover
-        # Python 2.7 compatibility.
-        name = platform.python_implementation().lower()
+    name = sys.implementation.name
     return INTERPRETER_SHORT_NAMES.get(name) or name
 
 
-def interpreter_version(**kwargs):
-    # type: (bool) -> str
+def interpreter_version(*, warn: bool = False) -> str:
     """
     Returns the version of the running interpreter.
     """
-    warn = _warn_keyword_parameter("interpreter_version", kwargs)
     version = _get_config_var("py_version_nodot", warn=warn)
     if version:
         version = str(version)
@@ -839,28 +463,25 @@ def interpreter_version(**kwargs):
     return version
 
 
-def _version_nodot(version):
-    # type: (PythonVersion) -> str
+def _version_nodot(version: PythonVersion) -> str:
     return "".join(map(str, version))
 
 
-def sys_tags(**kwargs):
-    # type: (bool) -> Iterator[Tag]
+def sys_tags(*, warn: bool = False) -> Iterator[Tag]:
     """
     Returns the sequence of tag triples for the running interpreter.
 
     The order of the sequence corresponds to priority order for the
     interpreter, from most to least important.
     """
-    warn = _warn_keyword_parameter("sys_tags", kwargs)
 
     interp_name = interpreter_name()
     if interp_name == "cp":
-        for tag in cpython_tags(warn=warn):
-            yield tag
+        yield from cpython_tags(warn=warn)
     else:
-        for tag in generic_tags():
-            yield tag
+        yield from generic_tags()
 
-    for tag in compatible_tags():
-        yield tag
+    if interp_name == "pp":
+        yield from compatible_tags(interpreter="pp3")
+    else:
+        yield from compatible_tags()
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/utils.py b/env/Lib/site-packages/pip/_vendor/packaging/utils.py
index 6e8c2a3e..bab11b80 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/utils.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/utils.py
@@ -1,22 +1,15 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 import re
+from typing import FrozenSet, NewType, Tuple, Union, cast
 
-from ._typing import TYPE_CHECKING, cast
 from .tags import Tag, parse_tag
 from .version import InvalidVersion, Version
 
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import FrozenSet, NewType, Tuple, Union
-
-    BuildTag = Union[Tuple[()], Tuple[int, str]]
-    NormalizedName = NewType("NormalizedName", str)
-else:
-    BuildTag = tuple
-    NormalizedName = str
+BuildTag = Union[Tuple[()], Tuple[int, str]]
+NormalizedName = NewType("NormalizedName", str)
 
 
 class InvalidWheelFilename(ValueError):
@@ -36,74 +29,75 @@ _canonicalize_regex = re.compile(r"[-_.]+")
 _build_tag_regex = re.compile(r"(\d+)(.*)")
 
 
-def canonicalize_name(name):
-    # type: (str) -> NormalizedName
+def canonicalize_name(name: str) -> NormalizedName:
     # This is taken from PEP 503.
     value = _canonicalize_regex.sub("-", name).lower()
     return cast(NormalizedName, value)
 
 
-def canonicalize_version(version):
-    # type: (Union[Version, str]) -> Union[Version, str]
+def canonicalize_version(version: Union[Version, str]) -> str:
     """
     This is very similar to Version.__str__, but has one subtle difference
     with the way it handles the release segment.
     """
-    if not isinstance(version, Version):
+    if isinstance(version, str):
         try:
-            version = Version(version)
+            parsed = Version(version)
         except InvalidVersion:
             # Legacy versions cannot be normalized
             return version
+    else:
+        parsed = version
 
     parts = []
 
     # Epoch
-    if version.epoch != 0:
-        parts.append("{0}!".format(version.epoch))
+    if parsed.epoch != 0:
+        parts.append(f"{parsed.epoch}!")
 
     # Release segment
     # NB: This strips trailing '.0's to normalize
-    parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in version.release)))
+    parts.append(re.sub(r"(\.0)+$", "", ".".join(str(x) for x in parsed.release)))
 
     # Pre-release
-    if version.pre is not None:
-        parts.append("".join(str(x) for x in version.pre))
+    if parsed.pre is not None:
+        parts.append("".join(str(x) for x in parsed.pre))
 
     # Post-release
-    if version.post is not None:
-        parts.append(".post{0}".format(version.post))
+    if parsed.post is not None:
+        parts.append(f".post{parsed.post}")
 
     # Development release
-    if version.dev is not None:
-        parts.append(".dev{0}".format(version.dev))
+    if parsed.dev is not None:
+        parts.append(f".dev{parsed.dev}")
 
     # Local version segment
-    if version.local is not None:
-        parts.append("+{0}".format(version.local))
+    if parsed.local is not None:
+        parts.append(f"+{parsed.local}")
 
     return "".join(parts)
 
 
-def parse_wheel_filename(filename):
-    # type: (str) -> Tuple[NormalizedName, Version, BuildTag, FrozenSet[Tag]]
+def parse_wheel_filename(
+    filename: str,
+) -> Tuple[NormalizedName, Version, BuildTag, FrozenSet[Tag]]:
     if not filename.endswith(".whl"):
         raise InvalidWheelFilename(
-            "Invalid wheel filename (extension must be '.whl'): {0}".format(filename)
+            f"Invalid wheel filename (extension must be '.whl'): {filename}"
         )
 
     filename = filename[:-4]
     dashes = filename.count("-")
     if dashes not in (4, 5):
         raise InvalidWheelFilename(
-            "Invalid wheel filename (wrong number of parts): {0}".format(filename)
+            f"Invalid wheel filename (wrong number of parts): {filename}"
         )
 
     parts = filename.split("-", dashes - 2)
     name_part = parts[0]
     # See PEP 427 for the rules on escaping the project name
     if "__" in name_part or re.match(r"^[\w\d._]*$", name_part, re.UNICODE) is None:
-        raise InvalidWheelFilename("Invalid project name: {0}".format(filename))
+        raise InvalidWheelFilename(f"Invalid project name: {filename}")
     name = canonicalize_name(name_part)
     version = Version(parts[1])
     if dashes == 5:
@@ -111,7 +105,7 @@ def parse_wheel_filename(filename):
         build_match = _build_tag_regex.match(build_part)
         if build_match is None:
             raise InvalidWheelFilename(
-                "Invalid build number: {0} in '{1}'".format(build_part, filename)
+                f"Invalid build number: {build_part} in '{filename}'"
             )
         build = cast(BuildTag, (int(build_match.group(1)), build_match.group(2)))
     else:
@@ -120,18 +114,22 @@ def parse_wheel_filename(filename):
     return (name, version, build, tags)
 
 
-def parse_sdist_filename(filename):
-    # type: (str) -> Tuple[NormalizedName, Version]
-    if not filename.endswith(".tar.gz"):
+def parse_sdist_filename(filename: str) -> Tuple[NormalizedName, Version]:
+    if filename.endswith(".tar.gz"):
+        file_stem = filename[: -len(".tar.gz")]
+    elif filename.endswith(".zip"):
+        file_stem = filename[: -len(".zip")]
+    else:
         raise InvalidSdistFilename(
-            "Invalid sdist filename (extension must be '.tar.gz'): {0}".format(filename)
+            f"Invalid sdist filename (extension must be '.tar.gz' or '.zip'):"
+            f" {filename}"
         )
 
     # We are requiring a PEP 440 version, which cannot contain dashes,
     # so we split on the last dash.
-    name_part, sep, version_part = filename[:-7].rpartition("-")
+    name_part, sep, version_part = file_stem.rpartition("-")
     if not sep:
-        raise InvalidSdistFilename("Invalid sdist filename: {0}".format(filename))
+        raise InvalidSdistFilename(f"Invalid sdist filename: {filename}")
 
     name = canonicalize_name(name_part)
     version = Version(version_part)
diff --git a/env/Lib/site-packages/pip/_vendor/packaging/version.py b/env/Lib/site-packages/pip/_vendor/packaging/version.py
index 517d91f2..de9a09a4 100644
--- a/env/Lib/site-packages/pip/_vendor/packaging/version.py
+++ b/env/Lib/site-packages/pip/_vendor/packaging/version.py
@@ -1,53 +1,45 @@
 # This file is dual licensed under the terms of the Apache License, Version
 # 2.0, and the BSD License. See the LICENSE file in the root of this repository
 # for complete details.
-from __future__ import absolute_import, division, print_function
 
 import collections
 import itertools
 import re
 import warnings
+from typing import Callable, Iterator, List, Optional, SupportsInt, Tuple, Union
 
-from ._structures import Infinity, NegativeInfinity
-from ._typing import TYPE_CHECKING
-
-if TYPE_CHECKING:  # pragma: no cover
-    from typing import Callable, Iterator, List, Optional, SupportsInt, Tuple, Union
-
-    from ._structures import InfinityType, NegativeInfinityType
-
-    InfiniteTypes = Union[InfinityType, NegativeInfinityType]
-    PrePostDevType = Union[InfiniteTypes, Tuple[str, int]]
-    SubLocalType = Union[InfiniteTypes, int, str]
-    LocalType = Union[
-        NegativeInfinityType,
-        Tuple[
-            Union[
-                SubLocalType,
-                Tuple[SubLocalType, str],
-                Tuple[NegativeInfinityType, SubLocalType],
-            ],
-            ...,
-        ],
-    ]
-    CmpKey = Tuple[
-        int, Tuple[int, ...], PrePostDevType, PrePostDevType, PrePostDevType, LocalType
-    ]
-    LegacyCmpKey = Tuple[int, Tuple[str, ...]]
-    VersionComparisonMethod = Callable[
-        [Union[CmpKey, LegacyCmpKey], Union[CmpKey, LegacyCmpKey]], bool
-    ]
+from ._structures import Infinity, InfinityType, NegativeInfinity, NegativeInfinityType
 
 __all__ = ["parse", "Version", "LegacyVersion", "InvalidVersion", "VERSION_PATTERN"]
 
+InfiniteTypes = Union[InfinityType, NegativeInfinityType]
+PrePostDevType = Union[InfiniteTypes, Tuple[str, int]]
+SubLocalType = Union[InfiniteTypes, int, str]
+LocalType = Union[
+    NegativeInfinityType,
+    Tuple[
+        Union[
+            SubLocalType,
+            Tuple[SubLocalType, str],
+            Tuple[NegativeInfinityType, SubLocalType],
+        ],
+        ...,
+    ],
+]
+CmpKey = Tuple[
+    int, Tuple[int, ...], PrePostDevType, PrePostDevType, PrePostDevType, LocalType
+]
+LegacyCmpKey = Tuple[int, Tuple[str, ...]]
+VersionComparisonMethod = Callable[
+    [Union[CmpKey, LegacyCmpKey], Union[CmpKey, LegacyCmpKey]], bool
+]
 
 _Version = collections.namedtuple(
     "_Version", ["epoch", "release", "dev", "pre", "post", "local"]
 )
 
 
-def parse(version):
-    # type: (str) -> Union[LegacyVersion, Version]
+def parse(version: str) -> Union["LegacyVersion", "Version"]:
     """
     Parse the given version string and return either a :class:`Version` object
     or a :class:`LegacyVersion` object depending on if the given version is
@@ -65,53 +57,46 @@ class InvalidVersion(ValueError):
     """
 
 
-class _BaseVersion(object):
-    _key = None  # type: Union[CmpKey, LegacyCmpKey]
+class _BaseVersion:
+    _key: Union[CmpKey, LegacyCmpKey]
 
-    def __hash__(self):
-        # type: () -> int
+    def __hash__(self) -> int:
         return hash(self._key)
 
     # Please keep the duplicated `isinstance` check
     # in the six comparisons hereunder
     # unless you find a way to avoid adding overhead function calls.
-    def __lt__(self, other):
-        # type: (_BaseVersion) -> bool
+    def __lt__(self, other: "_BaseVersion") -> bool:
         if not isinstance(other, _BaseVersion):
             return NotImplemented
 
         return self._key < other._key
 
-    def __le__(self, other):
-        # type: (_BaseVersion) -> bool
+    def __le__(self, other: "_BaseVersion") -> bool:
         if not isinstance(other, _BaseVersion):
             return NotImplemented
 
         return self._key <= other._key
 
-    def __eq__(self, other):
-        # type: (object) -> bool
+    def __eq__(self, other: object) -> bool:
         if not isinstance(other, _BaseVersion):
             return NotImplemented
 
         return self._key == other._key
 
-    def __ge__(self, other):
-        # type: (_BaseVersion) -> bool
+    def __ge__(self, other: "_BaseVersion") -> bool:
         if not isinstance(other, _BaseVersion):
             return NotImplemented
 
         return self._key >= other._key
 
-    def __gt__(self, other):
-        # type: (_BaseVersion) -> bool
+    def __gt__(self, other: "_BaseVersion") -> bool:
         if not isinstance(other, _BaseVersion):
             return NotImplemented
 
         return self._key > other._key
 
-    def __ne__(self, other):
-        # type: (object) -> bool
+    def __ne__(self, other: object) -> bool:
         if not isinstance(other, _BaseVersion):
             return NotImplemented
 
@@ -119,8 +104,7 @@ class _BaseVersion(object):
 
 
 class LegacyVersion(_BaseVersion):
-    def __init__(self, version):
-        # type: (str) -> None
+    def __init__(self, version: str) -> None:
         self._version = str(version)
         self._key = _legacy_cmpkey(self._version)
 
@@ -130,67 +114,54 @@ class LegacyVersion(_BaseVersion):
             DeprecationWarning,
         )
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         return self._version
 
-    def __repr__(self):
-        # type: () -> str
-        return "<LegacyVersion({0})>".format(repr(str(self)))
+    def __repr__(self) -> str:
+        return f"<LegacyVersion('{self}')>"
 
     @property
-    def public(self):
-        # type: () -> str
+    def public(self) -> str:
         return self._version
 
     @property
-    def base_version(self):
-        # type: () -> str
+    def base_version(self) -> str:
         return self._version
 
     @property
-    def epoch(self):
-        # type: () -> int
+    def epoch(self) -> int:
         return -1
 
     @property
-    def release(self):
-        # type: () -> None
+    def release(self) -> None:
         return None
 
     @property
-    def pre(self):
-        # type: () -> None
+    def pre(self) -> None:
         return None
 
     @property
-    def post(self):
-        # type: () -> None
+    def post(self) -> None:
         return None
 
     @property
-    def dev(self):
-        # type: () -> None
+    def dev(self) -> None:
         return None
 
     @property
-    def local(self):
-        # type: () -> None
+    def local(self) -> None:
         return None
 
     @property
-    def is_prerelease(self):
-        # type: () -> bool
+    def is_prerelease(self) -> bool:
         return False
 
     @property
-    def is_postrelease(self):
-        # type: () -> bool
+    def is_postrelease(self) -> bool:
         return False
 
     @property
-    def is_devrelease(self):
-        # type: () -> bool
+    def is_devrelease(self) -> bool:
         return False
 
 
@@ -205,8 +176,7 @@ _legacy_version_replacement_map = {
 }
 
 
-def _parse_version_parts(s):
-    # type: (str) -> Iterator[str]
+def _parse_version_parts(s: str) -> Iterator[str]:
     for part in _legacy_version_component_re.split(s):
         part = _legacy_version_replacement_map.get(part, part)
 
@@ -223,8 +193,7 @@ def _parse_version_parts(s):
     yield "*final"
 
 
-def _legacy_cmpkey(version):
-    # type: (str) -> LegacyCmpKey
+def _legacy_cmpkey(version: str) -> LegacyCmpKey:
 
     # We hardcode an epoch of -1 here. A PEP 440 version can only have a epoch
     # greater than or equal to 0. This will effectively put the LegacyVersion,
@@ -234,7 +203,7 @@ def _legacy_cmpkey(version):
 
     # This scheme is taken from pkg_resources.parse_version setuptools prior to
     # it's adoption of the packaging library.
-    parts = []  # type: List[str]
+    parts: List[str] = []
     for part in _parse_version_parts(version.lower()):
         if part.startswith("*"):
             # remove "-" before a prerelease tag
@@ -289,13 +258,12 @@ class Version(_BaseVersion):
 
     _regex = re.compile(r"^\s*" + VERSION_PATTERN + r"\s*$", re.VERBOSE | re.IGNORECASE)
 
-    def __init__(self, version):
-        # type: (str) -> None
+    def __init__(self, version: str) -> None:
 
         # Validate the version and parse it into pieces
         match = self._regex.search(version)
         if not match:
-            raise InvalidVersion("Invalid version: '{0}'".format(version))
+            raise InvalidVersion(f"Invalid version: '{version}'")
 
         # Store the parsed out pieces of the version
         self._version = _Version(
@@ -319,17 +287,15 @@ class Version(_BaseVersion):
             self._version.local,
         )
 
-    def __repr__(self):
-        # type: () -> str
-        return "<Version({0})>".format(repr(str(self)))
+    def __repr__(self) -> str:
+        return f"<Version('{self}')>"
 
-    def __str__(self):
-        # type: () -> str
+    def __str__(self) -> str:
         parts = []
 
         # Epoch
         if self.epoch != 0:
-            parts.append("{0}!".format(self.epoch))
+            parts.append(f"{self.epoch}!")
 
         # Release segment
         parts.append(".".join(str(x) for x in self.release))
@@ -340,67 +306,59 @@ class Version(_BaseVersion):
 
         # Post-release
         if self.post is not None:
-            parts.append(".post{0}".format(self.post))
+            parts.append(f".post{self.post}")
 
         # Development release
         if self.dev is not None:
-            parts.append(".dev{0}".format(self.dev))
+            parts.append(f".dev{self.dev}")
 
         # Local version segment
         if self.local is not None:
-            parts.append("+{0}".format(self.local))
+            parts.append(f"+{self.local}")
 
         return "".join(parts)
 
     @property
-    def epoch(self):
-        # type: () -> int
-        _epoch = self._version.epoch  # type: int
+    def epoch(self) -> int:
+        _epoch: int = self._version.epoch
         return _epoch
 
     @property
-    def release(self):
-        # type: () -> Tuple[int, ...]
-        _release = self._version.release  # type: Tuple[int, ...]
+    def release(self) -> Tuple[int, ...]:
+        _release: Tuple[int, ...] = self._version.release
         return _release
 
     @property
-    def pre(self):
-        # type: () -> Optional[Tuple[str, int]]
-        _pre = self._version.pre  # type: Optional[Tuple[str, int]]
+    def pre(self) -> Optional[Tuple[str, int]]:
+        _pre: Optional[Tuple[str, int]] = self._version.pre
         return _pre
 
     @property
-    def post(self):
-        # type: () -> Optional[Tuple[str, int]]
+    def post(self) -> Optional[int]:
         return self._version.post[1] if self._version.post else None
 
     @property
-    def dev(self):
-        # type: () -> Optional[Tuple[str, int]]
+    def dev(self) -> Optional[int]:
         return self._version.dev[1] if self._version.dev else None
 
     @property
-    def local(self):
-        # type: () -> Optional[str]
+    def local(self) -> Optional[str]:
         if self._version.local:
             return ".".join(str(x) for x in self._version.local)
         else:
             return None
 
     @property
-    def public(self):
-        # type: () -> str
+    def public(self) -> str:
         return str(self).split("+", 1)[0]
 
     @property
-    def base_version(self):
-        # type: () -> str
+    def base_version(self) -> str:
         parts = []
 
         # Epoch
         if self.epoch != 0:
-            parts.append("{0}!".format(self.epoch))
+            parts.append(f"{self.epoch}!")
 
         # Release segment
         parts.append(".".join(str(x) for x in self.release))
@@ -408,41 +366,33 @@ class Version(_BaseVersion):
         return "".join(parts)
 
     @property
-    def is_prerelease(self):
-        # type: () -> bool
+    def is_prerelease(self) -> bool:
         return self.dev is not None or self.pre is not None
 
     @property
-    def is_postrelease(self):
-        # type: () -> bool
+    def is_postrelease(self) -> bool:
         return self.post is not None
 
     @property
-    def is_devrelease(self):
-        # type: () -> bool
+    def is_devrelease(self) -> bool:
         return self.dev is not None
 
     @property
-    def major(self):
-        # type: () -> int
+    def major(self) -> int:
         return self.release[0] if len(self.release) >= 1 else 0
 
     @property
-    def minor(self):
-        # type: () -> int
+    def minor(self) -> int:
         return self.release[1] if len(self.release) >= 2 else 0
 
     @property
-    def micro(self):
-        # type: () -> int
+    def micro(self) -> int:
         return self.release[2] if len(self.release) >= 3 else 0
 
 
 def _parse_letter_version(
-    letter,  # type: str
-    number,  # type: Union[str, bytes, SupportsInt]
-):
-    # type: (...) -> Optional[Tuple[str, int]]
+    letter: str, number: Union[str, bytes, SupportsInt]
+) -> Optional[Tuple[str, int]]:
 
     if letter:
         # We consider there to be an implicit 0 in a pre-release if there is
@@ -479,8 +429,7 @@ def _parse_letter_version(
 _local_version_separators = re.compile(r"[\._-]")
 
 
-def _parse_local_version(local):
-    # type: (str) -> Optional[LocalType]
+def _parse_local_version(local: str) -> Optional[LocalType]:
     """
     Takes a string like abc.1.twelve and turns it into ("abc", 1, "twelve").
     """
@@ -493,14 +442,13 @@ def _parse_local_version(local):
 
 
 def _cmpkey(
-    epoch,  # type: int
-    release,  # type: Tuple[int, ...]
-    pre,  # type: Optional[Tuple[str, int]]
-    post,  # type: Optional[Tuple[str, int]]
-    dev,  # type: Optional[Tuple[str, int]]
-    local,  # type: Optional[Tuple[SubLocalType]]
-):
-    # type: (...) -> CmpKey
+    epoch: int,
+    release: Tuple[int, ...],
+    pre: Optional[Tuple[str, int]],
+    post: Optional[Tuple[str, int]],
+    dev: Optional[Tuple[str, int]],
+    local: Optional[Tuple[SubLocalType]],
+) -> CmpKey:
 
     # When we compare a release version, we want to compare it with all of the
     # trailing zeros removed. So we'll use a reverse the list, drop all the now
@@ -516,7 +464,7 @@ def _cmpkey(
     # if there is not a pre or a post segment. If we have one of those then
     # the normal sorting rules will handle this case correctly.
     if pre is None and post is None and dev is not None:
-        _pre = NegativeInfinity  # type: PrePostDevType
+        _pre: PrePostDevType = NegativeInfinity
     # Versions without a pre-release (except as noted above) should sort after
     # those with one.
     elif pre is None:
@@ -526,21 +474,21 @@ def _cmpkey(
 
     # Versions without a post segment should sort before those with one.
     if post is None:
-        _post = NegativeInfinity  # type: PrePostDevType
+        _post: PrePostDevType = NegativeInfinity
 
     else:
         _post = post
 
     # Versions without a development segment should sort after those with one.
     if dev is None:
-        _dev = Infinity  # type: PrePostDevType
+        _dev: PrePostDevType = Infinity
 
     else:
         _dev = dev
 
     if local is None:
         # Versions without a local segment should sort before those with one.
-        _local = NegativeInfinity  # type: LocalType
+        _local: LocalType = NegativeInfinity
     else:
         # Versions with a local segment need that segment parsed to implement
         # the sorting rules in PEP440.
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__init__.py b/env/Lib/site-packages/pip/_vendor/pep517/__init__.py
deleted file mode 100644
index 3b07c639..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/__init__.py
+++ /dev/null
@@ -1,6 +0,0 @@
-"""Wrappers to build Python packages using PEP 517 hooks
-"""
-
-__version__ = '0.10.0'
-
-from .wrappers import *  # noqa: F401, F403
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 589f580d2e21cc8fce9bd99ae00c77a5604a9f06..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 341
zcmYe~<>g{vU|^UdaWJ)sfq~&Mh=Yuo7#J8F7#J9eMHm<uQW&BbQW&EcQ<zeibC^OH
zQdoi+G+C?6!iy3M3Q~)T6-x3Il1ejkQWOFzOEU8F6bcfPvlG)(ixo<XGxO3F0$c+W
zObyKyGV=4Yi@B=U4D<{Q^bB4yGB7Y`GTvg;^3!C##U3A@lAjzOe~UXlzAUw<I5R&l
zKK>R*In;`k3`J}V3=ra1y|YzJXmM&$aZGAXN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+
zW3Ym!pNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ab`)X
zF3jCA1(^l<@nxxbDfvbE1*rw5hUWV5@tJv<CGqik1(mlrY;yBcN^?@}Kwc<jVPIfj
IVP;_h0KtP{ApigX

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/build.cpython-39.pyc
deleted file mode 100644
index 47792844f358eac82058d404fcabf681b685d821..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3590
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
N8tWe$8wVd3BLF4^vF-o>

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/check.cpython-39.pyc
deleted file mode 100644
index 2b8bf48c8712b2a76b7d0cdf337614e9d9df0c53..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5125
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
SN?c-0j9~bOje~=ogAoA4wI6Q)

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/colorlog.cpython-39.pyc
deleted file mode 100644
index 1eabf2c0aa8cf34f5bc55418a9cc8a6424b94c4e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2966
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
DFnS8U

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index dd65d1d5cf54e43bedf76232d6b23291b7750c3a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1143
zcmYe~<>g{vU|^UdaWIvKnStRkh=Ytd7#J8F7#J9eGZ+{cQW&BbQW#U1au}l+!8B78
zQz}yya|)v*Lke>?YmrF`OA2cXLljF2TMBy%LlkSCKne#`gcBlC#gWPu#TL$xC&t2%
z%3hho$N++=98qkM40%ij3@J>(44Pb35&@MZ8Tok%M*7AI$@#eji6xmynK_vyl`lcA
z^Lxq6z`&5q1Y$!m3j+fK$g$oa$GR~vFqAOVfE}5_+{@grQp;Szn8j4XP{W+Yl*v%T
zw1lybk&z*sA%%g3frX)&nUNt+z>uNX!T{_XMutcRMurrIU<OSVzgvvuzgSC4(sV6W
zGT!1y%}dTt$;?Y%$$X0?zaTa57E4xfe%>vXl+xUSl`OZI^OLe}u@oehWZYuQE>A2<
zFTTZ?wvwSpfPsPGSFN*EOlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vV
zr=N?zpKGwEV@$BCuWN9KYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AI
za&}^RYH>_KW`TZuS!!NNevy7bYJsVtxjrQH^a?6(ag`TkmZZjm+zX2IVo;DVFbXgh
z34sEW5gL#n3KX!Qz;p%$rVS)8!7&dGOsQJN62=8gHH-@x!x@;6f-soDkfB%)YY-L{
zfov;cWnf@f$y@|7yNHv4f#DWQPJUv_N~R)S1_p*Aeh>i)DR6KV34#=G7NsVpfZfao
zatz26u$#p}ZU(s%<X#X4$$-p7O90JG{Tj%TpTd;FoXJR90$?gnDq;h<4P-|VJBY;%
zB2b+Q4n`4#BY7B;afYb{JWQLJ`tgUS7Djk7`Q2hFN-6?bRV0SR9iX6*Kz4^F=Pma5
z_>}zQ_;^UDGZ$AD-{L7tEh^5;&x_B@OUnm4z6hlAmY`c^PO4viiCcbYUW#i`QGU@a
zPQS$5R0xyZ(;v)$L=kET+~Tmw%}*)KNwoucycpy*7Df(64pu%U4i+vp4i*k}CPofM
G9!3DN+~qw0

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/dirtools.cpython-39.pyc
deleted file mode 100644
index 73b1646d7f274b7dcbf0798ac825a436804d8b46..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1375
zcmYe~<>g{vU|^UdaWFNLg@NHQh=Yuo85kHG7#J9eqZk+%QW#Pga~Pr^G-DJan9mf&
z1g4pzn87ql6bqPUjba7UY*B2fOj+zHOexGQ49$#D94Ra*tSt;toGEN6>@5sYTq%sf
z44ND-LALrOgGd-=WME+6WME(b2^Q-yFff!bEMQ#7P|HvyQo|6&z{n8JP{Oo;xrSjO
zBO^l|4}xvL05+4U%E-AWHL)aBAyJ_uHMbzYD6yzgAtkdYHMu0es8S&_Pa#nuIX|x?
zwW35JH!&|UJ+(;BPm|>q2S{~VW=`rY_T20g5a$+KaYkuLX3j0PqTG_A)KpEzTTCS>
zD;bK|85kIT)jM0ogche3700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~
zxdwYW#ss_ix(0{11}T`u1O)iRB%0{v<fmsAmt<zgq~?{y_+%!<6la#C>J}s>XD6no
z7RMB17U;*9rRJsN7wH$I7ML2E>!)NEmE`B=6zdgK-eL#2F(tDI6qm&upzvenU}R$C
zU@C%zA4m+0K@kd4<`0TgF9rsNDxngFEXEp!Ookf9C5(NH;S9kHEDR+~l`f17wM>i*
zRZ=xfS<EHOSuEMiMFvd_;S7-sDU7vDbxe6&5ZZtN9^m0Vnc1ld3Ax!RnMDaY3Q46U
z3Mu)i#R_@(B??7}nZ>CJiFpdC70IauC7Jno3YlpNB^jw)3JMBH(UO=`l$w}QsgPQc
zSzJ=A2bT5IWWB|dUwn%dZ1OF3|6tdmqWq#;tf@ssdHJ{4TwNnPgF`f#Z?Pm6r5E2~
z%Pt4g%&8U0;3$F+ppXGaX=YJ;fe0u7Kq0}v!o(=V$j8XTSR@2WZJ=Za4k`u)29ORm
z1_lOakm6~GB*+L(Y>X+43z=$}N>~=Kf)b$%Lu^qDb1g$Hb1h2^vkOD4K`m<uOBUM#
z_8Nv7)`d*9Y+xQo4O<PvLZ({w8m0xDHS8%&;tVOw3z--h3Uz8&To__?2<qahVXI*W
z>qsh;t6>Ue&}6AHaL&&wE-5NaE&&B`W}a?tYAz^|S7jC`fReI8T7Hp2A|jaeZZVes
zV${FIpvirUDKq~TyHjOJYO$yPE%vI+0+5DV>`|EoZkai$;8b;sr93ew`xZ+<VoAm=
zmaP2Dyj$!=sX1USM|n|ZNosLP(JfXmOOxXkOHqD)$t|{|(zLYHqFWqQnFaA+Gg(qH
zi;8ctg4o4H(hLj?QS52O@eosrQggs8NL+z3RuL%pZ}FvM7R8t3$3xvE4~hy2Py{h?
zF!C^pFmf>RG4e4AL1_WTA~gmE22F0Tvx~$S7#MDGK{I(yW>OIo0|P@53y9za5g>zZ
v@j>OGWdJzSfYSolC?xkF9K~Uio1apelWGS_EybX;#KDLJnOPXQI61fh=nY@N

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/envbuild.cpython-39.pyc
deleted file mode 100644
index 1744d09a53c384ece5d60fe31713465a07fdfbf1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 4508
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
Y%q+|tj2w(SaLmIb0IGJl1roW$06yuoXaE2J

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/meta.cpython-39.pyc
deleted file mode 100644
index 3e2ed2c3a3ab0fc6ebb48e6e14542442571237d6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2948
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
P78Vfe9~&D7D;FaG5;^V*

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/__pycache__/wrappers.cpython-39.pyc
deleted file mode 100644
index 9257929d62f2b2ea70c917bcd7872f56792a791d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/build.py b/env/Lib/site-packages/pip/_vendor/pep517/build.py
deleted file mode 100644
index f884bcf1..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/build.py
+++ /dev/null
@@ -1,127 +0,0 @@
-"""Build a project using PEP 517 hooks.
-"""
-import argparse
-import logging
-import os
-from pip._vendor import toml
-import shutil
-
-from .envbuild import BuildEnvironment
-from .wrappers import Pep517HookCaller
-from .dirtools import tempdir, mkdir_p
-from .compat import FileNotFoundError
-
-log = logging.getLogger(__name__)
-
-
-def validate_system(system):
-    """
-    Ensure build system has the requisite fields.
-    """
-    required = {'requires', 'build-backend'}
-    if not (required <= set(system)):
-        message = "Missing required fields: {missing}".format(
-            missing=required-set(system),
-        )
-        raise ValueError(message)
-
-
-def load_system(source_dir):
-    """
-    Load the build system from a source dir (pyproject.toml).
-    """
-    pyproject = os.path.join(source_dir, 'pyproject.toml')
-    with open(pyproject) as f:
-        pyproject_data = toml.load(f)
-    return pyproject_data['build-system']
-
-
-def compat_system(source_dir):
-    """
-    Given a source dir, attempt to get a build system backend
-    and requirements from pyproject.toml. Fallback to
-    setuptools but only if the file was not found or a build
-    system was not indicated.
-    """
-    try:
-        system = load_system(source_dir)
-    except (FileNotFoundError, KeyError):
-        system = {}
-    system.setdefault(
-        'build-backend',
-        'setuptools.build_meta:__legacy__',
-    )
-    system.setdefault('requires', ['setuptools', 'wheel'])
-    return system
-
-
-def _do_build(hooks, env, dist, dest):
-    get_requires_name = 'get_requires_for_build_{dist}'.format(**locals())
-    get_requires = getattr(hooks, get_requires_name)
-    reqs = get_requires({})
-    log.info('Got build requires: %s', reqs)
-
-    env.pip_install(reqs)
-    log.info('Installed dynamic build dependencies')
-
-    with tempdir() as td:
-        log.info('Trying to build %s in %s', dist, td)
-        build_name = 'build_{dist}'.format(**locals())
-        build = getattr(hooks, build_name)
-        filename = build(td, {})
-        source = os.path.join(td, filename)
-        shutil.move(source, os.path.join(dest, os.path.basename(filename)))
-
-
-def build(source_dir, dist, dest=None, system=None):
-    system = system or load_system(source_dir)
-    dest = os.path.join(source_dir, dest or 'dist')
-    mkdir_p(dest)
-
-    validate_system(system)
-    hooks = Pep517HookCaller(
-        source_dir, system['build-backend'], system.get('backend-path')
-    )
-
-    with BuildEnvironment() as env:
-        env.pip_install(system['requires'])
-        _do_build(hooks, env, dist, dest)
-
-
-parser = argparse.ArgumentParser()
-parser.add_argument(
-    'source_dir',
-    help="A directory containing pyproject.toml",
-)
-parser.add_argument(
-    '--binary', '-b',
-    action='store_true',
-    default=False,
-)
-parser.add_argument(
-    '--source', '-s',
-    action='store_true',
-    default=False,
-)
-parser.add_argument(
-    '--out-dir', '-o',
-    help="Destination in which to save the builds relative to source dir",
-)
-
-
-def main(args):
-    log.warning('pep517.build is deprecated. '
-                'Consider switching to https://pypi.org/project/build/')
-
-    # determine which dists to build
-    dists = list(filter(None, (
-        'sdist' if args.source or not args.binary else None,
-        'wheel' if args.binary or not args.source else None,
-    )))
-
-    for dist in dists:
-        build(args.source_dir, dist, args.out_dir)
-
-
-if __name__ == '__main__':
-    main(parser.parse_args())
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/check.py b/env/Lib/site-packages/pip/_vendor/pep517/check.py
deleted file mode 100644
index decab8a3..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/check.py
+++ /dev/null
@@ -1,206 +0,0 @@
-"""Check a project and backend by attempting to build using PEP 517 hooks.
-"""
-import argparse
-import logging
-import os
-from os.path import isfile, join as pjoin
-from pip._vendor.toml import TomlDecodeError, load as toml_load
-import shutil
-from subprocess import CalledProcessError
-import sys
-import tarfile
-from tempfile import mkdtemp
-import zipfile
-
-from .colorlog import enable_colourful_output
-from .envbuild import BuildEnvironment
-from .wrappers import Pep517HookCaller
-
-log = logging.getLogger(__name__)
-
-
-def check_build_sdist(hooks, build_sys_requires):
-    with BuildEnvironment() as env:
-        try:
-            env.pip_install(build_sys_requires)
-            log.info('Installed static build dependencies')
-        except CalledProcessError:
-            log.error('Failed to install static build dependencies')
-            return False
-
-        try:
-            reqs = hooks.get_requires_for_build_sdist({})
-            log.info('Got build requires: %s', reqs)
-        except Exception:
-            log.error('Failure in get_requires_for_build_sdist', exc_info=True)
-            return False
-
-        try:
-            env.pip_install(reqs)
-            log.info('Installed dynamic build dependencies')
-        except CalledProcessError:
-            log.error('Failed to install dynamic build dependencies')
-            return False
-
-        td = mkdtemp()
-        log.info('Trying to build sdist in %s', td)
-        try:
-            try:
-                filename = hooks.build_sdist(td, {})
-                log.info('build_sdist returned %r', filename)
-            except Exception:
-                log.info('Failure in build_sdist', exc_info=True)
-                return False
-
-            if not filename.endswith('.tar.gz'):
-                log.error(
-                    "Filename %s doesn't have .tar.gz extension", filename)
-                return False
-
-            path = pjoin(td, filename)
-            if isfile(path):
-                log.info("Output file %s exists", path)
-            else:
-                log.error("Output file %s does not exist", path)
-                return False
-
-            if tarfile.is_tarfile(path):
-                log.info("Output file is a tar file")
-            else:
-                log.error("Output file is not a tar file")
-                return False
-
-        finally:
-            shutil.rmtree(td)
-
-        return True
-
-
-def check_build_wheel(hooks, build_sys_requires):
-    with BuildEnvironment() as env:
-        try:
-            env.pip_install(build_sys_requires)
-            log.info('Installed static build dependencies')
-        except CalledProcessError:
-            log.error('Failed to install static build dependencies')
-            return False
-
-        try:
-            reqs = hooks.get_requires_for_build_wheel({})
-            log.info('Got build requires: %s', reqs)
-        except Exception:
-            log.error('Failure in get_requires_for_build_sdist', exc_info=True)
-            return False
-
-        try:
-            env.pip_install(reqs)
-            log.info('Installed dynamic build dependencies')
-        except CalledProcessError:
-            log.error('Failed to install dynamic build dependencies')
-            return False
-
-        td = mkdtemp()
-        log.info('Trying to build wheel in %s', td)
-        try:
-            try:
-                filename = hooks.build_wheel(td, {})
-                log.info('build_wheel returned %r', filename)
-            except Exception:
-                log.info('Failure in build_wheel', exc_info=True)
-                return False
-
-            if not filename.endswith('.whl'):
-                log.error("Filename %s doesn't have .whl extension", filename)
-                return False
-
-            path = pjoin(td, filename)
-            if isfile(path):
-                log.info("Output file %s exists", path)
-            else:
-                log.error("Output file %s does not exist", path)
-                return False
-
-            if zipfile.is_zipfile(path):
-                log.info("Output file is a zip file")
-            else:
-                log.error("Output file is not a zip file")
-                return False
-
-        finally:
-            shutil.rmtree(td)
-
-        return True
-
-
-def check(source_dir):
-    pyproject = pjoin(source_dir, 'pyproject.toml')
-    if isfile(pyproject):
-        log.info('Found pyproject.toml')
-    else:
-        log.error('Missing pyproject.toml')
-        return False
-
-    try:
-        with open(pyproject) as f:
-            pyproject_data = toml_load(f)
-        # Ensure the mandatory data can be loaded
-        buildsys = pyproject_data['build-system']
-        requires = buildsys['requires']
-        backend = buildsys['build-backend']
-        backend_path = buildsys.get('backend-path')
-        log.info('Loaded pyproject.toml')
-    except (TomlDecodeError, KeyError):
-        log.error("Invalid pyproject.toml", exc_info=True)
-        return False
-
-    hooks = Pep517HookCaller(source_dir, backend, backend_path)
-
-    sdist_ok = check_build_sdist(hooks, requires)
-    wheel_ok = check_build_wheel(hooks, requires)
-
-    if not sdist_ok:
-        log.warning('Sdist checks failed; scroll up to see')
-    if not wheel_ok:
-        log.warning('Wheel checks failed')
-
-    return sdist_ok
-
-
-def main(argv=None):
-    log.warning('pep517.check is deprecated. '
-                'Consider switching to https://pypi.org/project/build/')
-
-    ap = argparse.ArgumentParser()
-    ap.add_argument(
-        'source_dir',
-        help="A directory containing pyproject.toml")
-    args = ap.parse_args(argv)
-
-    enable_colourful_output()
-
-    ok = check(args.source_dir)
-
-    if ok:
-        print(ansi('Checks passed', 'green'))
-    else:
-        print(ansi('Checks failed', 'red'))
-        sys.exit(1)
-
-
-ansi_codes = {
-    'reset': '\x1b[0m',
-    'bold': '\x1b[1m',
-    'red': '\x1b[31m',
-    'green': '\x1b[32m',
-}
-
-
-def ansi(s, attr):
-    if os.name != 'nt' and sys.stdout.isatty():
-        return ansi_codes[attr] + str(s) + ansi_codes['reset']
-    else:
-        return str(s)
-
-
-if __name__ == '__main__':
-    main()
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/colorlog.py b/env/Lib/site-packages/pip/_vendor/pep517/colorlog.py
deleted file mode 100644
index 69c8a59d..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/colorlog.py
+++ /dev/null
@@ -1,115 +0,0 @@
-"""Nicer log formatting with colours.
-
-Code copied from Tornado, Apache licensed.
-"""
-# Copyright 2012 Facebook
-#
-# Licensed under the Apache License, Version 2.0 (the "License"); you may
-# not use this file except in compliance with the License. You may obtain
-# a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
-# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
-# License for the specific language governing permissions and limitations
-# under the License.
-
-import logging
-import sys
-
-try:
-    import curses
-except ImportError:
-    curses = None
-
-
-def _stderr_supports_color():
-    color = False
-    if curses and hasattr(sys.stderr, 'isatty') and sys.stderr.isatty():
-        try:
-            curses.setupterm()
-            if curses.tigetnum("colors") > 0:
-                color = True
-        except Exception:
-            pass
-    return color
-
-
-class LogFormatter(logging.Formatter):
-    """Log formatter with colour support
-    """
-    DEFAULT_COLORS = {
-        logging.INFO: 2,  # Green
-        logging.WARNING: 3,  # Yellow
-        logging.ERROR: 1,  # Red
-        logging.CRITICAL: 1,
-    }
-
-    def __init__(self, color=True, datefmt=None):
-        r"""
-        :arg bool color: Enables color support.
-        :arg string fmt: Log message format.
-        It will be applied to the attributes dict of log records. The
-        text between ``%(color)s`` and ``%(end_color)s`` will be colored
-        depending on the level if color support is on.
-        :arg dict colors: color mappings from logging level to terminal color
-        code
-        :arg string datefmt: Datetime format.
-        Used for formatting ``(asctime)`` placeholder in ``prefix_fmt``.
-        .. versionchanged:: 3.2
-        Added ``fmt`` and ``datefmt`` arguments.
-        """
-        logging.Formatter.__init__(self, datefmt=datefmt)
-        self._colors = {}
-        if color and _stderr_supports_color():
-            # The curses module has some str/bytes confusion in
-            # python3. Until version 3.2.3, most methods return
-            # bytes, but only accept strings. In addition, we want to
-            # output these strings with the logging module, which
-            # works with unicode strings. The explicit calls to
-            # unicode() below are harmless in python2 but will do the
-            # right conversion in python 3.
-            fg_color = (curses.tigetstr("setaf") or
-                        curses.tigetstr("setf") or "")
-            if (3, 0) < sys.version_info < (3, 2, 3):
-                fg_color = str(fg_color, "ascii")
-
-            for levelno, code in self.DEFAULT_COLORS.items():
-                self._colors[levelno] = str(
-                    curses.tparm(fg_color, code), "ascii")
-            self._normal = str(curses.tigetstr("sgr0"), "ascii")
-
-            scr = curses.initscr()
-            self.termwidth = scr.getmaxyx()[1]
-            curses.endwin()
-        else:
-            self._normal = ''
-            # Default width is usually 80, but too wide is
-            # worse than too narrow
-            self.termwidth = 70
-
-    def formatMessage(self, record):
-        mlen = len(record.message)
-        right_text = '{initial}-{name}'.format(initial=record.levelname[0],
-                                               name=record.name)
-        if mlen + len(right_text) < self.termwidth:
-            space = ' ' * (self.termwidth - (mlen + len(right_text)))
-        else:
-            space = '  '
-
-        if record.levelno in self._colors:
-            start_color = self._colors[record.levelno]
-            end_color = self._normal
-        else:
-            start_color = end_color = ''
-
-        return record.message + space + start_color + right_text + end_color
-
-
-def enable_colourful_output(level=logging.INFO):
-    handler = logging.StreamHandler()
-    handler.setFormatter(LogFormatter())
-    logging.root.addHandler(handler)
-    logging.root.setLevel(level)
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/compat.py b/env/Lib/site-packages/pip/_vendor/pep517/compat.py
deleted file mode 100644
index 8432acb7..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/compat.py
+++ /dev/null
@@ -1,34 +0,0 @@
-"""Python 2/3 compatibility"""
-import json
-import sys
-
-
-# Handle reading and writing JSON in UTF-8, on Python 3 and 2.
-
-if sys.version_info[0] >= 3:
-    # Python 3
-    def write_json(obj, path, **kwargs):
-        with open(path, 'w', encoding='utf-8') as f:
-            json.dump(obj, f, **kwargs)
-
-    def read_json(path):
-        with open(path, 'r', encoding='utf-8') as f:
-            return json.load(f)
-
-else:
-    # Python 2
-    def write_json(obj, path, **kwargs):
-        with open(path, 'wb') as f:
-            json.dump(obj, f, encoding='utf-8', **kwargs)
-
-    def read_json(path):
-        with open(path, 'rb') as f:
-            return json.load(f)
-
-
-# FileNotFoundError
-
-try:
-    FileNotFoundError = FileNotFoundError
-except NameError:
-    FileNotFoundError = IOError
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/dirtools.py b/env/Lib/site-packages/pip/_vendor/pep517/dirtools.py
deleted file mode 100644
index 58c6ca0c..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/dirtools.py
+++ /dev/null
@@ -1,44 +0,0 @@
-import os
-import io
-import contextlib
-import tempfile
-import shutil
-import errno
-import zipfile
-
-
-@contextlib.contextmanager
-def tempdir():
-    """Create a temporary directory in a context manager."""
-    td = tempfile.mkdtemp()
-    try:
-        yield td
-    finally:
-        shutil.rmtree(td)
-
-
-def mkdir_p(*args, **kwargs):
-    """Like `mkdir`, but does not raise an exception if the
-    directory already exists.
-    """
-    try:
-        return os.mkdir(*args, **kwargs)
-    except OSError as exc:
-        if exc.errno != errno.EEXIST:
-            raise
-
-
-def dir_to_zipfile(root):
-    """Construct an in-memory zip file for a directory."""
-    buffer = io.BytesIO()
-    zip_file = zipfile.ZipFile(buffer, 'w')
-    for root, dirs, files in os.walk(root):
-        for path in dirs:
-            fs_path = os.path.join(root, path)
-            rel_path = os.path.relpath(fs_path, root)
-            zip_file.writestr(rel_path + '/', '')
-        for path in files:
-            fs_path = os.path.join(root, path)
-            rel_path = os.path.relpath(fs_path, root)
-            zip_file.write(fs_path, rel_path)
-    return zip_file
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/envbuild.py b/env/Lib/site-packages/pip/_vendor/pep517/envbuild.py
deleted file mode 100644
index 4088dcdb..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/envbuild.py
+++ /dev/null
@@ -1,167 +0,0 @@
-"""Build wheels/sdists by installing build deps to a temporary environment.
-"""
-
-import os
-import logging
-from pip._vendor import toml
-import shutil
-from subprocess import check_call
-import sys
-from sysconfig import get_paths
-from tempfile import mkdtemp
-
-from .wrappers import Pep517HookCaller, LoggerWrapper
-
-log = logging.getLogger(__name__)
-
-
-def _load_pyproject(source_dir):
-    with open(os.path.join(source_dir, 'pyproject.toml')) as f:
-        pyproject_data = toml.load(f)
-    buildsys = pyproject_data['build-system']
-    return (
-        buildsys['requires'],
-        buildsys['build-backend'],
-        buildsys.get('backend-path'),
-    )
-
-
-class BuildEnvironment(object):
-    """Context manager to install build deps in a simple temporary environment
-
-    Based on code I wrote for pip, which is MIT licensed.
-    """
-    # Copyright (c) 2008-2016 The pip developers (see AUTHORS.txt file)
-    #
-    # Permission is hereby granted, free of charge, to any person obtaining
-    # a copy of this software and associated documentation files (the
-    # "Software"), to deal in the Software without restriction, including
-    # without limitation the rights to use, copy, modify, merge, publish,
-    # distribute, sublicense, and/or sell copies of the Software, and to
-    # permit persons to whom the Software is furnished to do so, subject to
-    # the following conditions:
-    #
-    # The above copyright notice and this permission notice shall be
-    # included in all copies or substantial portions of the Software.
-    #
-    # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-    # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-    # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-    # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
-    # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
-    # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
-    # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-
-    path = None
-
-    def __init__(self, cleanup=True):
-        self._cleanup = cleanup
-
-    def __enter__(self):
-        self.path = mkdtemp(prefix='pep517-build-env-')
-        log.info('Temporary build environment: %s', self.path)
-
-        self.save_path = os.environ.get('PATH', None)
-        self.save_pythonpath = os.environ.get('PYTHONPATH', None)
-
-        install_scheme = 'nt' if (os.name == 'nt') else 'posix_prefix'
-        install_dirs = get_paths(install_scheme, vars={
-            'base': self.path,
-            'platbase': self.path,
-        })
-
-        scripts = install_dirs['scripts']
-        if self.save_path:
-            os.environ['PATH'] = scripts + os.pathsep + self.save_path
-        else:
-            os.environ['PATH'] = scripts + os.pathsep + os.defpath
-
-        if install_dirs['purelib'] == install_dirs['platlib']:
-            lib_dirs = install_dirs['purelib']
-        else:
-            lib_dirs = install_dirs['purelib'] + os.pathsep + \
-                install_dirs['platlib']
-        if self.save_pythonpath:
-            os.environ['PYTHONPATH'] = lib_dirs + os.pathsep + \
-                self.save_pythonpath
-        else:
-            os.environ['PYTHONPATH'] = lib_dirs
-
-        return self
-
-    def pip_install(self, reqs):
-        """Install dependencies into this env by calling pip in a subprocess"""
-        if not reqs:
-            return
-        log.info('Calling pip to install %s', reqs)
-        cmd = [
-            sys.executable, '-m', 'pip', 'install', '--ignore-installed',
-            '--prefix', self.path] + list(reqs)
-        check_call(
-            cmd,
-            stdout=LoggerWrapper(log, logging.INFO),
-            stderr=LoggerWrapper(log, logging.ERROR),
-        )
-
-    def __exit__(self, exc_type, exc_val, exc_tb):
-        needs_cleanup = (
-            self._cleanup and
-            self.path is not None and
-            os.path.isdir(self.path)
-        )
-        if needs_cleanup:
-            shutil.rmtree(self.path)
-
-        if self.save_path is None:
-            os.environ.pop('PATH', None)
-        else:
-            os.environ['PATH'] = self.save_path
-
-        if self.save_pythonpath is None:
-            os.environ.pop('PYTHONPATH', None)
-        else:
-            os.environ['PYTHONPATH'] = self.save_pythonpath
-
-
-def build_wheel(source_dir, wheel_dir, config_settings=None):
-    """Build a wheel from a source directory using PEP 517 hooks.
-
-    :param str source_dir: Source directory containing pyproject.toml
-    :param str wheel_dir: Target directory to create wheel in
-    :param dict config_settings: Options to pass to build backend
-
-    This is a blocking function which will run pip in a subprocess to install
-    build requirements.
-    """
-    if config_settings is None:
-        config_settings = {}
-    requires, backend, backend_path = _load_pyproject(source_dir)
-    hooks = Pep517HookCaller(source_dir, backend, backend_path)
-
-    with BuildEnvironment() as env:
-        env.pip_install(requires)
-        reqs = hooks.get_requires_for_build_wheel(config_settings)
-        env.pip_install(reqs)
-        return hooks.build_wheel(wheel_dir, config_settings)
-
-
-def build_sdist(source_dir, sdist_dir, config_settings=None):
-    """Build an sdist from a source directory using PEP 517 hooks.
-
-    :param str source_dir: Source directory containing pyproject.toml
-    :param str sdist_dir: Target directory to place sdist in
-    :param dict config_settings: Options to pass to build backend
-
-    This is a blocking function which will run pip in a subprocess to install
-    build requirements.
-    """
-    if config_settings is None:
-        config_settings = {}
-    requires, backend, backend_path = _load_pyproject(source_dir)
-    hooks = Pep517HookCaller(source_dir, backend, backend_path)
-
-    with BuildEnvironment() as env:
-        env.pip_install(requires)
-        reqs = hooks.get_requires_for_build_sdist(config_settings)
-        env.pip_install(reqs)
-        return hooks.build_sdist(sdist_dir, config_settings)
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py b/env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py
deleted file mode 100644
index c932313b..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__init__.py
+++ /dev/null
@@ -1,17 +0,0 @@
-"""This is a subpackage because the directory is on sys.path for _in_process.py
-
-The subpackage should stay as empty as possible to avoid shadowing modules that
-the backend might import.
-"""
-from os.path import dirname, abspath, join as pjoin
-from contextlib import contextmanager
-
-try:
-    import importlib.resources as resources
-
-    def _in_proc_script_path():
-        return resources.path(__package__, '_in_process.py')
-except ImportError:
-    @contextmanager
-    def _in_proc_script_path():
-        yield pjoin(dirname(abspath(__file__)), '_in_process.py')
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index e2722f2ea3c2184a72df767f0512df0257b1aacd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 943
zcmYe~<>g{vU|^UdaWK`GiGkrUh=Ytd7#J8F7#J9e6Brm6QW&BbQW#U1au{=&qL^}-
zqnLA9qF5P0V$3;gx$IHwj0{y0DU2yBIUKp1QJjnnDXb}MEeugy;S70lEDWjKl~Ifg
zAehRY!VZ#YW{l#BWXNMOU`SyJX3*rQ+7XhGS*(y*tdOWsT$)snn4F!Mo~n?Pnw(f#
zoT^Zgk*biAS(KVwl3!E_Qk9>lP+VE8SCCkep^%neq!6E(7hh16pPX7;tXELU#TAl~
zifm4CMt*5dib8QoVx>Z2u|jHYK?#^qkY8M!nUs^NP?E2ZSeBoeqEMWXn37+fnU}7R
zo1apelUl4$l95=#1#&=AVsdtBUW!6)W_m`6LS}A3eo=`Y*Go{SX)@npPsuFGOUzBZ
z#h#c{406{kmaP2DJWa-1e98HFC8-r9xrup+>8VA2$sirbn1z9X!5I|RJPZsBB@7D~
zOPEp^7cvDitYq@5;zRYCCi5-MqSWI2(xT+l;#(|Wi@4+Cp#c^jzmlN{6tQ69SC_L@
zOlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BCuWN9K
zYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOsxH*J;+TTW0{!^1)V!4ZBK?BY
z0#ieCeMC&?$H!;pWtPOp>lIYq5`p<6zBsukv!Em%<aCgSi<v-S!B_-hV+|URV6g-^
zXi6AMm`a$N8JihX7@L{G7#JB+7=js!*cccXG+A!37Jx#$2xMLnGXn#|Esps3w9K5;
z_;_$|AQ9XQ3=Cik`9Z-B(!ju^$#aW6K0YNsIX?atdp;y>A<QZQMN$zj$W$(9eCA{(
z6|sT@gdu4mCo@S89yLYmFe`3xdxDdSYf({t5t19g(FAhHEe;z<TC-yWxkiA2fq{ip
Sgpr4diIInihlz)gi4g$Z4fziM

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pep517/in_process/__pycache__/_in_process.cpython-39.pyc
deleted file mode 100644
index 3872c9f3274e7d6f9553553705736291542f8262..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8305
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
I$Z|0P06sI>2LJ#7

diff --git a/env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py b/env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py
deleted file mode 100644
index a536b03e..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/in_process/_in_process.py
+++ /dev/null
@@ -1,280 +0,0 @@
-"""This is invoked in a subprocess to call the build backend hooks.
-
-It expects:
-- Command line args: hook_name, control_dir
-- Environment variables:
-      PEP517_BUILD_BACKEND=entry.point:spec
-      PEP517_BACKEND_PATH=paths (separated with os.pathsep)
-- control_dir/input.json:
-  - {"kwargs": {...}}
-
-Results:
-- control_dir/output.json
-  - {"return_val": ...}
-"""
-from glob import glob
-from importlib import import_module
-import json
-import os
-import os.path
-from os.path import join as pjoin
-import re
-import shutil
-import sys
-import traceback
-
-# This file is run as a script, and `import compat` is not zip-safe, so we
-# include write_json() and read_json() from compat.py.
-#
-# Handle reading and writing JSON in UTF-8, on Python 3 and 2.
-
-if sys.version_info[0] >= 3:
-    # Python 3
-    def write_json(obj, path, **kwargs):
-        with open(path, 'w', encoding='utf-8') as f:
-            json.dump(obj, f, **kwargs)
-
-    def read_json(path):
-        with open(path, 'r', encoding='utf-8') as f:
-            return json.load(f)
-
-else:
-    # Python 2
-    def write_json(obj, path, **kwargs):
-        with open(path, 'wb') as f:
-            json.dump(obj, f, encoding='utf-8', **kwargs)
-
-    def read_json(path):
-        with open(path, 'rb') as f:
-            return json.load(f)
-
-
-class BackendUnavailable(Exception):
-    """Raised if we cannot import the backend"""
-    def __init__(self, traceback):
-        self.traceback = traceback
-
-
-class BackendInvalid(Exception):
-    """Raised if the backend is invalid"""
-    def __init__(self, message):
-        self.message = message
-
-
-class HookMissing(Exception):
-    """Raised if a hook is missing and we are not executing the fallback"""
-
-
-def contained_in(filename, directory):
-    """Test if a file is located within the given directory."""
-    filename = os.path.normcase(os.path.abspath(filename))
-    directory = os.path.normcase(os.path.abspath(directory))
-    return os.path.commonprefix([filename, directory]) == directory
-
-
-def _build_backend():
-    """Find and load the build backend"""
-    # Add in-tree backend directories to the front of sys.path.
-    backend_path = os.environ.get('PEP517_BACKEND_PATH')
-    if backend_path:
-        extra_pathitems = backend_path.split(os.pathsep)
-        sys.path[:0] = extra_pathitems
-
-    ep = os.environ['PEP517_BUILD_BACKEND']
-    mod_path, _, obj_path = ep.partition(':')
-    try:
-        obj = import_module(mod_path)
-    except ImportError:
-        raise BackendUnavailable(traceback.format_exc())
-
-    if backend_path:
-        if not any(
-            contained_in(obj.__file__, path)
-            for path in extra_pathitems
-        ):
-            raise BackendInvalid("Backend was not loaded from backend-path")
-
-    if obj_path:
-        for path_part in obj_path.split('.'):
-            obj = getattr(obj, path_part)
-    return obj
-
-
-def get_requires_for_build_wheel(config_settings):
-    """Invoke the optional get_requires_for_build_wheel hook
-
-    Returns [] if the hook is not defined.
-    """
-    backend = _build_backend()
-    try:
-        hook = backend.get_requires_for_build_wheel
-    except AttributeError:
-        return []
-    else:
-        return hook(config_settings)
-
-
-def prepare_metadata_for_build_wheel(
-        metadata_directory, config_settings, _allow_fallback):
-    """Invoke optional prepare_metadata_for_build_wheel
-
-    Implements a fallback by building a wheel if the hook isn't defined,
-    unless _allow_fallback is False in which case HookMissing is raised.
-    """
-    backend = _build_backend()
-    try:
-        hook = backend.prepare_metadata_for_build_wheel
-    except AttributeError:
-        if not _allow_fallback:
-            raise HookMissing()
-        return _get_wheel_metadata_from_wheel(backend, metadata_directory,
-                                              config_settings)
-    else:
-        return hook(metadata_directory, config_settings)
-
-
-WHEEL_BUILT_MARKER = 'PEP517_ALREADY_BUILT_WHEEL'
-
-
-def _dist_info_files(whl_zip):
-    """Identify the .dist-info folder inside a wheel ZipFile."""
-    res = []
-    for path in whl_zip.namelist():
-        m = re.match(r'[^/\\]+-[^/\\]+\.dist-info/', path)
-        if m:
-            res.append(path)
-    if res:
-        return res
-    raise Exception("No .dist-info folder found in wheel")
-
-
-def _get_wheel_metadata_from_wheel(
-        backend, metadata_directory, config_settings):
-    """Build a wheel and extract the metadata from it.
-
-    Fallback for when the build backend does not
-    define the 'get_wheel_metadata' hook.
-    """
-    from zipfile import ZipFile
-    whl_basename = backend.build_wheel(metadata_directory, config_settings)
-    with open(os.path.join(metadata_directory, WHEEL_BUILT_MARKER), 'wb'):
-        pass  # Touch marker file
-
-    whl_file = os.path.join(metadata_directory, whl_basename)
-    with ZipFile(whl_file) as zipf:
-        dist_info = _dist_info_files(zipf)
-        zipf.extractall(path=metadata_directory, members=dist_info)
-    return dist_info[0].split('/')[0]
-
-
-def _find_already_built_wheel(metadata_directory):
-    """Check for a wheel already built during the get_wheel_metadata hook.
-    """
-    if not metadata_directory:
-        return None
-    metadata_parent = os.path.dirname(metadata_directory)
-    if not os.path.isfile(pjoin(metadata_parent, WHEEL_BUILT_MARKER)):
-        return None
-
-    whl_files = glob(os.path.join(metadata_parent, '*.whl'))
-    if not whl_files:
-        print('Found wheel built marker, but no .whl files')
-        return None
-    if len(whl_files) > 1:
-        print('Found multiple .whl files; unspecified behaviour. '
-              'Will call build_wheel.')
-        return None
-
-    # Exactly one .whl file
-    return whl_files[0]
-
-
-def build_wheel(wheel_directory, config_settings, metadata_directory=None):
-    """Invoke the mandatory build_wheel hook.
-
-    If a wheel was already built in the
-    prepare_metadata_for_build_wheel fallback, this
-    will copy it rather than rebuilding the wheel.
-    """
-    prebuilt_whl = _find_already_built_wheel(metadata_directory)
-    if prebuilt_whl:
-        shutil.copy2(prebuilt_whl, wheel_directory)
-        return os.path.basename(prebuilt_whl)
-
-    return _build_backend().build_wheel(wheel_directory, config_settings,
-                                        metadata_directory)
-
-
-def get_requires_for_build_sdist(config_settings):
-    """Invoke the optional get_requires_for_build_wheel hook
-
-    Returns [] if the hook is not defined.
-    """
-    backend = _build_backend()
-    try:
-        hook = backend.get_requires_for_build_sdist
-    except AttributeError:
-        return []
-    else:
-        return hook(config_settings)
-
-
-class _DummyException(Exception):
-    """Nothing should ever raise this exception"""
-
-
-class GotUnsupportedOperation(Exception):
-    """For internal use when backend raises UnsupportedOperation"""
-    def __init__(self, traceback):
-        self.traceback = traceback
-
-
-def build_sdist(sdist_directory, config_settings):
-    """Invoke the mandatory build_sdist hook."""
-    backend = _build_backend()
-    try:
-        return backend.build_sdist(sdist_directory, config_settings)
-    except getattr(backend, 'UnsupportedOperation', _DummyException):
-        raise GotUnsupportedOperation(traceback.format_exc())
-
-
-HOOK_NAMES = {
-    'get_requires_for_build_wheel',
-    'prepare_metadata_for_build_wheel',
-    'build_wheel',
-    'get_requires_for_build_sdist',
-    'build_sdist',
-}
-
-
-def main():
-    if len(sys.argv) < 3:
-        sys.exit("Needs args: hook_name, control_dir")
-    hook_name = sys.argv[1]
-    control_dir = sys.argv[2]
-    if hook_name not in HOOK_NAMES:
-        sys.exit("Unknown hook: %s" % hook_name)
-    hook = globals()[hook_name]
-
-    hook_input = read_json(pjoin(control_dir, 'input.json'))
-
-    json_out = {'unsupported': False, 'return_val': None}
-    try:
-        json_out['return_val'] = hook(**hook_input['kwargs'])
-    except BackendUnavailable as e:
-        json_out['no_backend'] = True
-        json_out['traceback'] = e.traceback
-    except BackendInvalid as e:
-        json_out['backend_invalid'] = True
-        json_out['backend_error'] = e.message
-    except GotUnsupportedOperation as e:
-        json_out['unsupported'] = True
-        json_out['traceback'] = e.traceback
-    except HookMissing:
-        json_out['hook_missing'] = True
-
-    write_json(json_out, pjoin(control_dir, 'output.json'), indent=2)
-
-
-if __name__ == '__main__':
-    main()
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/meta.py b/env/Lib/site-packages/pip/_vendor/pep517/meta.py
deleted file mode 100644
index d525de5c..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/meta.py
+++ /dev/null
@@ -1,92 +0,0 @@
-"""Build metadata for a project using PEP 517 hooks.
-"""
-import argparse
-import logging
-import os
-import shutil
-import functools
-
-try:
-    import importlib.metadata as imp_meta
-except ImportError:
-    import importlib_metadata as imp_meta
-
-try:
-    from zipfile import Path
-except ImportError:
-    from zipp import Path
-
-from .envbuild import BuildEnvironment
-from .wrappers import Pep517HookCaller, quiet_subprocess_runner
-from .dirtools import tempdir, mkdir_p, dir_to_zipfile
-from .build import validate_system, load_system, compat_system
-
-log = logging.getLogger(__name__)
-
-
-def _prep_meta(hooks, env, dest):
-    reqs = hooks.get_requires_for_build_wheel({})
-    log.info('Got build requires: %s', reqs)
-
-    env.pip_install(reqs)
-    log.info('Installed dynamic build dependencies')
-
-    with tempdir() as td:
-        log.info('Trying to build metadata in %s', td)
-        filename = hooks.prepare_metadata_for_build_wheel(td, {})
-        source = os.path.join(td, filename)
-        shutil.move(source, os.path.join(dest, os.path.basename(filename)))
-
-
-def build(source_dir='.', dest=None, system=None):
-    system = system or load_system(source_dir)
-    dest = os.path.join(source_dir, dest or 'dist')
-    mkdir_p(dest)
-    validate_system(system)
-    hooks = Pep517HookCaller(
-        source_dir, system['build-backend'], system.get('backend-path')
-    )
-
-    with hooks.subprocess_runner(quiet_subprocess_runner):
-        with BuildEnvironment() as env:
-            env.pip_install(system['requires'])
-            _prep_meta(hooks, env, dest)
-
-
-def build_as_zip(builder=build):
-    with tempdir() as out_dir:
-        builder(dest=out_dir)
-        return dir_to_zipfile(out_dir)
-
-
-def load(root):
-    """
-    Given a source directory (root) of a package,
-    return an importlib.metadata.Distribution object
-    with metadata build from that package.
-    """
-    root = os.path.expanduser(root)
-    system = compat_system(root)
-    builder = functools.partial(build, source_dir=root, system=system)
-    path = Path(build_as_zip(builder))
-    return imp_meta.PathDistribution(path)
-
-
-parser = argparse.ArgumentParser()
-parser.add_argument(
-    'source_dir',
-    help="A directory containing pyproject.toml",
-)
-parser.add_argument(
-    '--out-dir', '-o',
-    help="Destination in which to save the builds relative to source dir",
-)
-
-
-def main():
-    args = parser.parse_args()
-    build(args.source_dir, args.out_dir)
-
-
-if __name__ == '__main__':
-    main()
diff --git a/env/Lib/site-packages/pip/_vendor/pep517/wrappers.py b/env/Lib/site-packages/pip/_vendor/pep517/wrappers.py
deleted file mode 100644
index 00974aa8..00000000
--- a/env/Lib/site-packages/pip/_vendor/pep517/wrappers.py
+++ /dev/null
@@ -1,318 +0,0 @@
-import threading
-from contextlib import contextmanager
-import os
-from os.path import abspath, join as pjoin
-import shutil
-from subprocess import check_call, check_output, STDOUT
-import sys
-from tempfile import mkdtemp
-
-from . import compat
-from .in_process import _in_proc_script_path
-
-__all__ = [
-    'BackendUnavailable',
-    'BackendInvalid',
-    'HookMissing',
-    'UnsupportedOperation',
-    'default_subprocess_runner',
-    'quiet_subprocess_runner',
-    'Pep517HookCaller',
-]
-
-
-@contextmanager
-def tempdir():
-    td = mkdtemp()
-    try:
-        yield td
-    finally:
-        shutil.rmtree(td)
-
-
-class BackendUnavailable(Exception):
-    """Will be raised if the backend cannot be imported in the hook process."""
-    def __init__(self, traceback):
-        self.traceback = traceback
-
-
-class BackendInvalid(Exception):
-    """Will be raised if the backend is invalid."""
-    def __init__(self, backend_name, backend_path, message):
-        self.backend_name = backend_name
-        self.backend_path = backend_path
-        self.message = message
-
-
-class HookMissing(Exception):
-    """Will be raised on missing hooks."""
-    def __init__(self, hook_name):
-        super(HookMissing, self).__init__(hook_name)
-        self.hook_name = hook_name
-
-
-class UnsupportedOperation(Exception):
-    """May be raised by build_sdist if the backend indicates that it can't."""
-    def __init__(self, traceback):
-        self.traceback = traceback
-
-
-def default_subprocess_runner(cmd, cwd=None, extra_environ=None):
-    """The default method of calling the wrapper subprocess."""
-    env = os.environ.copy()
-    if extra_environ:
-        env.update(extra_environ)
-
-    check_call(cmd, cwd=cwd, env=env)
-
-
-def quiet_subprocess_runner(cmd, cwd=None, extra_environ=None):
-    """A method of calling the wrapper subprocess while suppressing output."""
-    env = os.environ.copy()
-    if extra_environ:
-        env.update(extra_environ)
-
-    check_output(cmd, cwd=cwd, env=env, stderr=STDOUT)
-
-
-def norm_and_check(source_tree, requested):
-    """Normalise and check a backend path.
-
-    Ensure that the requested backend path is specified as a relative path,
-    and resolves to a location under the given source tree.
-
-    Return an absolute version of the requested path.
-    """
-    if os.path.isabs(requested):
-        raise ValueError("paths must be relative")
-
-    abs_source = os.path.abspath(source_tree)
-    abs_requested = os.path.normpath(os.path.join(abs_source, requested))
-    # We have to use commonprefix for Python 2.7 compatibility. So we
-    # normalise case to avoid problems because commonprefix is a character
-    # based comparison :-(
-    norm_source = os.path.normcase(abs_source)
-    norm_requested = os.path.normcase(abs_requested)
-    if os.path.commonprefix([norm_source, norm_requested]) != norm_source:
-        raise ValueError("paths must be inside source tree")
-
-    return abs_requested
-
-
-class Pep517HookCaller(object):
-    """A wrapper around a source directory to be built with a PEP 517 backend.
-
-    :param source_dir: The path to the source directory, containing
-        pyproject.toml.
-    :param build_backend: The build backend spec, as per PEP 517, from
-        pyproject.toml.
-    :param backend_path: The backend path, as per PEP 517, from pyproject.toml.
-    :param runner: A callable that invokes the wrapper subprocess.
-    :param python_executable: The Python executable used to invoke the backend
-
-    The 'runner', if provided, must expect the following:
-
-    - cmd: a list of strings representing the command and arguments to
-      execute, as would be passed to e.g. 'subprocess.check_call'.
-    - cwd: a string representing the working directory that must be
-      used for the subprocess. Corresponds to the provided source_dir.
-    - extra_environ: a dict mapping environment variable names to values
-      which must be set for the subprocess execution.
-    """
-    def __init__(
-            self,
-            source_dir,
-            build_backend,
-            backend_path=None,
-            runner=None,
-            python_executable=None,
-    ):
-        if runner is None:
-            runner = default_subprocess_runner
-
-        self.source_dir = abspath(source_dir)
-        self.build_backend = build_backend
-        if backend_path:
-            backend_path = [
-                norm_and_check(self.source_dir, p) for p in backend_path
-            ]
-        self.backend_path = backend_path
-        self._subprocess_runner = runner
-        if not python_executable:
-            python_executable = sys.executable
-        self.python_executable = python_executable
-
-    @contextmanager
-    def subprocess_runner(self, runner):
-        """A context manager for temporarily overriding the default subprocess
-        runner.
-        """
-        prev = self._subprocess_runner
-        self._subprocess_runner = runner
-        try:
-            yield
-        finally:
-            self._subprocess_runner = prev
-
-    def get_requires_for_build_wheel(self, config_settings=None):
-        """Identify packages required for building a wheel
-
-        Returns a list of dependency specifications, e.g.::
-
-            ["wheel >= 0.25", "setuptools"]
-
-        This does not include requirements specified in pyproject.toml.
-        It returns the result of calling the equivalently named hook in a
-        subprocess.
-        """
-        return self._call_hook('get_requires_for_build_wheel', {
-            'config_settings': config_settings
-        })
-
-    def prepare_metadata_for_build_wheel(
-            self, metadata_directory, config_settings=None,
-            _allow_fallback=True):
-        """Prepare a ``*.dist-info`` folder with metadata for this project.
-
-        Returns the name of the newly created folder.
-
-        If the build backend defines a hook with this name, it will be called
-        in a subprocess. If not, the backend will be asked to build a wheel,
-        and the dist-info extracted from that (unless _allow_fallback is
-        False).
-        """
-        return self._call_hook('prepare_metadata_for_build_wheel', {
-            'metadata_directory': abspath(metadata_directory),
-            'config_settings': config_settings,
-            '_allow_fallback': _allow_fallback,
-        })
-
-    def build_wheel(
-            self, wheel_directory, config_settings=None,
-            metadata_directory=None):
-        """Build a wheel from this project.
-
-        Returns the name of the newly created file.
-
-        In general, this will call the 'build_wheel' hook in the backend.
-        However, if that was previously called by
-        'prepare_metadata_for_build_wheel', and the same metadata_directory is
-        used, the previously built wheel will be copied to wheel_directory.
-        """
-        if metadata_directory is not None:
-            metadata_directory = abspath(metadata_directory)
-        return self._call_hook('build_wheel', {
-            'wheel_directory': abspath(wheel_directory),
-            'config_settings': config_settings,
-            'metadata_directory': metadata_directory,
-        })
-
-    def get_requires_for_build_sdist(self, config_settings=None):
-        """Identify packages required for building a wheel
-
-        Returns a list of dependency specifications, e.g.::
-
-            ["setuptools >= 26"]
-
-        This does not include requirements specified in pyproject.toml.
-        It returns the result of calling the equivalently named hook in a
-        subprocess.
-        """
-        return self._call_hook('get_requires_for_build_sdist', {
-            'config_settings': config_settings
-        })
-
-    def build_sdist(self, sdist_directory, config_settings=None):
-        """Build an sdist from this project.
-
-        Returns the name of the newly created file.
-
-        This calls the 'build_sdist' backend hook in a subprocess.
-        """
-        return self._call_hook('build_sdist', {
-            'sdist_directory': abspath(sdist_directory),
-            'config_settings': config_settings,
-        })
-
-    def _call_hook(self, hook_name, kwargs):
-        # On Python 2, pytoml returns Unicode values (which is correct) but the
-        # environment passed to check_call needs to contain string values. We
-        # convert here by encoding using ASCII (the backend can only contain
-        # letters, digits and _, . and : characters, and will be used as a
-        # Python identifier, so non-ASCII content is wrong on Python 2 in
-        # any case).
-        # For backend_path, we use sys.getfilesystemencoding.
-        if sys.version_info[0] == 2:
-            build_backend = self.build_backend.encode('ASCII')
-        else:
-            build_backend = self.build_backend
-        extra_environ = {'PEP517_BUILD_BACKEND': build_backend}
-
-        if self.backend_path:
-            backend_path = os.pathsep.join(self.backend_path)
-            if sys.version_info[0] == 2:
-                backend_path = backend_path.encode(sys.getfilesystemencoding())
-            extra_environ['PEP517_BACKEND_PATH'] = backend_path
-
-        with tempdir() as td:
-            hook_input = {'kwargs': kwargs}
-            compat.write_json(hook_input, pjoin(td, 'input.json'),
-                              indent=2)
-
-            # Run the hook in a subprocess
-            with _in_proc_script_path() as script:
-                python = self.python_executable
-                self._subprocess_runner(
-                    [python, abspath(str(script)), hook_name, td],
-                    cwd=self.source_dir,
-                    extra_environ=extra_environ
-                )
-
-            data = compat.read_json(pjoin(td, 'output.json'))
-            if data.get('unsupported'):
-                raise UnsupportedOperation(data.get('traceback', ''))
-            if data.get('no_backend'):
-                raise BackendUnavailable(data.get('traceback', ''))
-            if data.get('backend_invalid'):
-                raise BackendInvalid(
-                    backend_name=self.build_backend,
-                    backend_path=self.backend_path,
-                    message=data.get('backend_error', '')
-                )
-            if data.get('hook_missing'):
-                raise HookMissing(hook_name)
-            return data['return_val']
-
-
-class LoggerWrapper(threading.Thread):
-    """
-    Read messages from a pipe and redirect them
-    to a logger (see python's logging module).
-    """
-
-    def __init__(self, logger, level):
-        threading.Thread.__init__(self)
-        self.daemon = True
-
-        self.logger = logger
-        self.level = level
-
-        # create the pipe and reader
-        self.fd_read, self.fd_write = os.pipe()
-        self.reader = os.fdopen(self.fd_read)
-
-        self.start()
-
-    def fileno(self):
-        return self.fd_write
-
-    @staticmethod
-    def remove_newline(msg):
-        return msg[:-1] if msg.endswith(os.linesep) else msg
-
-    def run(self):
-        for line in self.reader:
-            self._write(self.remove_newline(line))
-
-    def _write(self, message):
-        self.logger.log(self.level, message)
diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py b/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
index a457ff27..ad279407 100644
--- a/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/pkg_resources/__init__.py
@@ -1,4 +1,3 @@
-# coding: utf-8
 """
 Package resource API
 --------------------
@@ -13,9 +12,10 @@ The package resource API is designed to work with normal filesystem packages,
 .egg files, and unpacked .egg files.  It can also work in a limited way with
 .zip files and with custom PEP 302 loaders that support the ``get_data()``
 method.
-"""
 
-from __future__ import absolute_import
+This module is deprecated. Users are directed to :mod:`importlib.resources`,
+:mod:`importlib.metadata` and :pypi:`packaging` instead.
+"""
 
 import sys
 import os
@@ -37,10 +37,10 @@ import email.parser
 import errno
 import tempfile
 import textwrap
-import itertools
 import inspect
 import ntpath
 import posixpath
+import importlib
 from pkgutil import get_importer
 
 try:
@@ -54,13 +54,12 @@ try:
 except NameError:
     FileExistsError = OSError
 
-from pip._vendor import six
-from pip._vendor.six.moves import urllib, map, filter
-
 # capture these to bypass sandboxing
 from os import utime
+
 try:
     from os import mkdir, rename, unlink
+
     WRITE_SUPPORT = True
 except ImportError:
     # no write support, probably under GAE
@@ -71,31 +70,30 @@ from os.path import isdir, split
 
 try:
     import importlib.machinery as importlib_machinery
+
     # access attribute to force import under delayed import mechanisms.
     importlib_machinery.__name__
 except ImportError:
     importlib_machinery = None
 
-from . import py31compat
-from pip._vendor import appdirs
+from pip._internal.utils._jaraco_text import (
+    yield_lines,
+    drop_comment,
+    join_continuation,
+)
+
+from pip._vendor import platformdirs
 from pip._vendor import packaging
+
 __import__('pip._vendor.packaging.version')
 __import__('pip._vendor.packaging.specifiers')
 __import__('pip._vendor.packaging.requirements')
 __import__('pip._vendor.packaging.markers')
+__import__('pip._vendor.packaging.utils')
 
-
-__metaclass__ = type
-
-
-if (3, 0) < sys.version_info < (3, 5):
+if sys.version_info < (3, 5):
     raise RuntimeError("Python 3.5 or later is required")
 
-if six.PY2:
-    # Those builtin exceptions are only defined in Python 3
-    PermissionError = None
-    NotADirectoryError = None
-
 # declare some globals that will be defined later to
 # satisfy the linters.
 require = None
@@ -117,6 +115,17 @@ _namespace_handlers = None
 _namespace_packages = None
 
 
+warnings.warn(
+    "pkg_resources is deprecated as an API. "
+    "See https://setuptools.pypa.io/en/latest/pkg_resources.html",
+    DeprecationWarning,
+    stacklevel=2
+)
+
+
+_PEP440_FALLBACK = re.compile(r"^v?(?P<safe>(?:[0-9]+!)?[0-9]+(?:\.[0-9]+)*)", re.I)
+
+
 class PEP440Warning(RuntimeWarning):
     """
     Used when there is an issue with a version or specifier not complying with
@@ -124,11 +133,7 @@ class PEP440Warning(RuntimeWarning):
     """
 
 
-def parse_version(v):
-    try:
-        return packaging.version.Version(v)
-    except packaging.version.InvalidVersion:
-        return packaging.version.LegacyVersion(v)
+parse_version = packaging.version.Version
 
 
 _state_vars = {}
@@ -178,10 +183,10 @@ def get_supported_platform():
     """Return this platform's maximum compatible version.
 
     distutils.util.get_platform() normally reports the minimum version
-    of Mac OS X that would be required to *use* extensions produced by
+    of macOS that would be required to *use* extensions produced by
     distutils.  But what we want when checking compatibility is to know the
-    version of Mac OS X that we are *running*.  To allow usage of packages that
-    explicitly require a newer version of Mac OS X, we must also know the
+    version of macOS that we are *running*.  To allow usage of packages that
+    explicitly require a newer version of macOS, we must also know the
     current version of the OS.
 
     If this condition occurs for any other platform with a version in its
@@ -191,60 +196,96 @@ def get_supported_platform():
     m = macosVersionString.match(plat)
     if m is not None and sys.platform == "darwin":
         try:
-            plat = 'macosx-%s-%s' % ('.'.join(_macosx_vers()[:2]), m.group(3))
+            plat = 'macosx-%s-%s' % ('.'.join(_macos_vers()[:2]), m.group(3))
         except ValueError:
-            # not Mac OS X
+            # not macOS
             pass
     return plat
 
 
 __all__ = [
     # Basic resource access and distribution/entry point discovery
-    'require', 'run_script', 'get_provider', 'get_distribution',
-    'load_entry_point', 'get_entry_map', 'get_entry_info',
+    'require',
+    'run_script',
+    'get_provider',
+    'get_distribution',
+    'load_entry_point',
+    'get_entry_map',
+    'get_entry_info',
     'iter_entry_points',
-    'resource_string', 'resource_stream', 'resource_filename',
-    'resource_listdir', 'resource_exists', 'resource_isdir',
-
+    'resource_string',
+    'resource_stream',
+    'resource_filename',
+    'resource_listdir',
+    'resource_exists',
+    'resource_isdir',
     # Environmental control
-    'declare_namespace', 'working_set', 'add_activation_listener',
-    'find_distributions', 'set_extraction_path', 'cleanup_resources',
+    'declare_namespace',
+    'working_set',
+    'add_activation_listener',
+    'find_distributions',
+    'set_extraction_path',
+    'cleanup_resources',
     'get_default_cache',
-
     # Primary implementation classes
-    'Environment', 'WorkingSet', 'ResourceManager',
-    'Distribution', 'Requirement', 'EntryPoint',
-
+    'Environment',
+    'WorkingSet',
+    'ResourceManager',
+    'Distribution',
+    'Requirement',
+    'EntryPoint',
     # Exceptions
-    'ResolutionError', 'VersionConflict', 'DistributionNotFound',
-    'UnknownExtra', 'ExtractionError',
-
+    'ResolutionError',
+    'VersionConflict',
+    'DistributionNotFound',
+    'UnknownExtra',
+    'ExtractionError',
     # Warnings
     'PEP440Warning',
-
     # Parsing functions and string utilities
-    'parse_requirements', 'parse_version', 'safe_name', 'safe_version',
-    'get_platform', 'compatible_platforms', 'yield_lines', 'split_sections',
-    'safe_extra', 'to_filename', 'invalid_marker', 'evaluate_marker',
-
+    'parse_requirements',
+    'parse_version',
+    'safe_name',
+    'safe_version',
+    'get_platform',
+    'compatible_platforms',
+    'yield_lines',
+    'split_sections',
+    'safe_extra',
+    'to_filename',
+    'invalid_marker',
+    'evaluate_marker',
     # filesystem utilities
-    'ensure_directory', 'normalize_path',
-
+    'ensure_directory',
+    'normalize_path',
     # Distribution "precedence" constants
-    'EGG_DIST', 'BINARY_DIST', 'SOURCE_DIST', 'CHECKOUT_DIST', 'DEVELOP_DIST',
-
+    'EGG_DIST',
+    'BINARY_DIST',
+    'SOURCE_DIST',
+    'CHECKOUT_DIST',
+    'DEVELOP_DIST',
     # "Provider" interfaces, implementations, and registration/lookup APIs
-    'IMetadataProvider', 'IResourceProvider', 'FileMetadata',
-    'PathMetadata', 'EggMetadata', 'EmptyProvider', 'empty_provider',
-    'NullProvider', 'EggProvider', 'DefaultProvider', 'ZipProvider',
-    'register_finder', 'register_namespace_handler', 'register_loader_type',
-    'fixup_namespace_packages', 'get_importer',
-
+    'IMetadataProvider',
+    'IResourceProvider',
+    'FileMetadata',
+    'PathMetadata',
+    'EggMetadata',
+    'EmptyProvider',
+    'empty_provider',
+    'NullProvider',
+    'EggProvider',
+    'DefaultProvider',
+    'ZipProvider',
+    'register_finder',
+    'register_namespace_handler',
+    'register_loader_type',
+    'fixup_namespace_packages',
+    'get_importer',
     # Warnings
     'PkgResourcesDeprecationWarning',
-
     # Deprecated/backward compatibility only
-    'run_main', 'AvailableDistributions',
+    'run_main',
+    'AvailableDistributions',
 ]
 
 
@@ -303,8 +344,10 @@ class ContextualVersionConflict(VersionConflict):
 class DistributionNotFound(ResolutionError):
     """A requested distribution was not found"""
 
-    _template = ("The '{self.req}' distribution was not found "
-                 "and is required by {self.requirers_str}")
+    _template = (
+        "The '{self.req}' distribution was not found "
+        "and is required by {self.requirers_str}"
+    )
 
     @property
     def req(self):
@@ -364,7 +407,7 @@ def get_provider(moduleOrReq):
     return _find_adapter(_provider_factories, loader)(module)
 
 
-def _macosx_vers(_cache=[]):
+def _macos_vers(_cache=[]):
     if not _cache:
         version = platform.mac_ver()[0]
         # fallback for MacPorts
@@ -380,7 +423,7 @@ def _macosx_vers(_cache=[]):
     return _cache[0]
 
 
-def _macosx_arch(machine):
+def _macos_arch(machine):
     return {'PowerPC': 'ppc', 'Power_Macintosh': 'ppc'}.get(machine, machine)
 
 
@@ -388,18 +431,19 @@ def get_build_platform():
     """Return this platform's string for platform-specific distributions
 
     XXX Currently this is the same as ``distutils.util.get_platform()``, but it
-    needs some hacks for Linux and Mac OS X.
+    needs some hacks for Linux and macOS.
     """
     from sysconfig import get_platform
 
     plat = get_platform()
     if sys.platform == "darwin" and not plat.startswith('macosx-'):
         try:
-            version = _macosx_vers()
+            version = _macos_vers()
             machine = os.uname()[4].replace(" ", "_")
             return "macosx-%d.%d-%s" % (
-                int(version[0]), int(version[1]),
-                _macosx_arch(machine),
+                int(version[0]),
+                int(version[1]),
+                _macos_arch(machine),
             )
         except ValueError:
             # if someone is running a non-Mac darwin system, this will fall
@@ -425,7 +469,7 @@ def compatible_platforms(provided, required):
         # easy case
         return True
 
-    # Mac OS X special cases
+    # macOS special cases
     reqMac = macosVersionString.match(required)
     if reqMac:
         provMac = macosVersionString.match(provided)
@@ -434,20 +478,23 @@ def compatible_platforms(provided, required):
         if not provMac:
             # this is backwards compatibility for packages built before
             # setuptools 0.6. All packages built after this point will
-            # use the new macosx designation.
+            # use the new macOS designation.
             provDarwin = darwinVersionString.match(provided)
             if provDarwin:
                 dversion = int(provDarwin.group(1))
                 macosversion = "%s.%s" % (reqMac.group(1), reqMac.group(2))
-                if dversion == 7 and macosversion >= "10.3" or \
-                        dversion == 8 and macosversion >= "10.4":
+                if (
+                    dversion == 7
+                    and macosversion >= "10.3"
+                    or dversion == 8
+                    and macosversion >= "10.4"
+                ):
                     return True
-            # egg isn't macosx or legacy darwin
+            # egg isn't macOS or legacy darwin
             return False
 
         # are they the same major version and machine type?
-        if provMac.group(1) != reqMac.group(1) or \
-                provMac.group(3) != reqMac.group(3):
+        if provMac.group(1) != reqMac.group(1) or provMac.group(3) != reqMac.group(3):
             return False
 
         # is the required OS major update >= the provided one?
@@ -475,7 +522,7 @@ run_main = run_script
 
 def get_distribution(dist):
     """Return a current distribution object for a Requirement or string"""
-    if isinstance(dist, six.string_types):
+    if isinstance(dist, str):
         dist = Requirement.parse(dist)
     if isinstance(dist, Requirement):
         dist = get_provider(dist)
@@ -509,8 +556,8 @@ class IMetadataProvider:
     def get_metadata_lines(name):
         """Yield named metadata resource as list of non-blank non-comment lines
 
-       Leading and trailing whitespace is stripped from each line, and lines
-       with ``#`` as the first non-blank character are omitted."""
+        Leading and trailing whitespace is stripped from each line, and lines
+        with ``#`` as the first non-blank character are omitted."""
 
     def metadata_isdir(name):
         """Is the named metadata a directory?  (like ``os.path.isdir()``)"""
@@ -558,6 +605,7 @@ class WorkingSet:
         self.entries = []
         self.entry_keys = {}
         self.by_key = {}
+        self.normalized_to_canonical_keys = {}
         self.callbacks = []
 
         if entries is None:
@@ -638,6 +686,14 @@ class WorkingSet:
         is returned.
         """
         dist = self.by_key.get(req.key)
+
+        if dist is None:
+            canonical_key = self.normalized_to_canonical_keys.get(req.key)
+
+            if canonical_key is not None:
+                req.key = canonical_key
+                dist = self.by_key.get(canonical_key)
+
         if dist is not None and dist not in req:
             # XXX add more info
             raise VersionConflict(dist, req)
@@ -706,14 +762,22 @@ class WorkingSet:
             return
 
         self.by_key[dist.key] = dist
+        normalized_name = packaging.utils.canonicalize_name(dist.key)
+        self.normalized_to_canonical_keys[normalized_name] = dist.key
         if dist.key not in keys:
             keys.append(dist.key)
         if dist.key not in keys2:
             keys2.append(dist.key)
         self._added_new(dist)
 
-    def resolve(self, requirements, env=None, installer=None,
-                replace_conflicting=False, extras=None):
+    def resolve(
+        self,
+        requirements,
+        env=None,
+        installer=None,
+        replace_conflicting=False,
+        extras=None,
+    ):
         """List all distributions needed to (recursively) meet `requirements`
 
         `requirements` must be a sequence of ``Requirement`` objects.  `env`,
@@ -762,33 +826,9 @@ class WorkingSet:
             if not req_extras.markers_pass(req, extras):
                 continue
 
-            dist = best.get(req.key)
-            if dist is None:
-                # Find the best distribution and add it to the map
-                dist = self.by_key.get(req.key)
-                if dist is None or (dist not in req and replace_conflicting):
-                    ws = self
-                    if env is None:
-                        if dist is None:
-                            env = Environment(self.entries)
-                        else:
-                            # Use an empty environment and workingset to avoid
-                            # any further conflicts with the conflicting
-                            # distribution
-                            env = Environment([])
-                            ws = WorkingSet([])
-                    dist = best[req.key] = env.best_match(
-                        req, ws, installer,
-                        replace_conflicting=replace_conflicting
-                    )
-                    if dist is None:
-                        requirers = required_by.get(req, None)
-                        raise DistributionNotFound(req, requirers)
-                to_activate.append(dist)
-            if dist not in req:
-                # Oops, the "best" so far conflicts with a dependency
-                dependent_req = required_by[req]
-                raise VersionConflict(dist, req).with_context(dependent_req)
+            dist = self._resolve_dist(
+                req, best, replace_conflicting, env, installer, required_by, to_activate
+            )
 
             # push the new requirements onto the stack
             new_requirements = dist.requires(req.extras)[::-1]
@@ -804,8 +844,38 @@ class WorkingSet:
         # return list of distros to activate
         return to_activate
 
-    def find_plugins(
-            self, plugin_env, full_env=None, installer=None, fallback=True):
+    def _resolve_dist(
+        self, req, best, replace_conflicting, env, installer, required_by, to_activate
+    ):
+        dist = best.get(req.key)
+        if dist is None:
+            # Find the best distribution and add it to the map
+            dist = self.by_key.get(req.key)
+            if dist is None or (dist not in req and replace_conflicting):
+                ws = self
+                if env is None:
+                    if dist is None:
+                        env = Environment(self.entries)
+                    else:
+                        # Use an empty environment and workingset to avoid
+                        # any further conflicts with the conflicting
+                        # distribution
+                        env = Environment([])
+                        ws = WorkingSet([])
+                dist = best[req.key] = env.best_match(
+                    req, ws, installer, replace_conflicting=replace_conflicting
+                )
+                if dist is None:
+                    requirers = required_by.get(req, None)
+                    raise DistributionNotFound(req, requirers)
+            to_activate.append(dist)
+        if dist not in req:
+            # Oops, the "best" so far conflicts with a dependency
+            dependent_req = required_by[req]
+            raise VersionConflict(dist, req).with_context(dependent_req)
+        return dist
+
+    def find_plugins(self, plugin_env, full_env=None, installer=None, fallback=True):
         """Find all activatable distributions in `plugin_env`
 
         Example usage::
@@ -858,9 +928,7 @@ class WorkingSet:
         list(map(shadow_set.add, self))
 
         for project_name in plugin_projects:
-
             for dist in plugin_env[project_name]:
-
                 req = [dist.as_requirement()]
 
                 try:
@@ -924,15 +992,19 @@ class WorkingSet:
 
     def __getstate__(self):
         return (
-            self.entries[:], self.entry_keys.copy(), self.by_key.copy(),
-            self.callbacks[:]
+            self.entries[:],
+            self.entry_keys.copy(),
+            self.by_key.copy(),
+            self.normalized_to_canonical_keys.copy(),
+            self.callbacks[:],
         )
 
-    def __setstate__(self, e_k_b_c):
-        entries, keys, by_key, callbacks = e_k_b_c
+    def __setstate__(self, e_k_b_n_c):
+        entries, keys, by_key, normalized_to_canonical_keys, callbacks = e_k_b_n_c
         self.entries = entries[:]
         self.entry_keys = keys.copy()
         self.by_key = by_key.copy()
+        self.normalized_to_canonical_keys = normalized_to_canonical_keys.copy()
         self.callbacks = callbacks[:]
 
 
@@ -960,8 +1032,8 @@ class Environment:
     """Searchable snapshot of distributions on a search path"""
 
     def __init__(
-            self, search_path=None, platform=get_supported_platform(),
-            python=PY_MAJOR):
+        self, search_path=None, platform=get_supported_platform(), python=PY_MAJOR
+    ):
         """Snapshot distributions available on a search path
 
         Any distributions found on `search_path` are added to the environment.
@@ -1028,16 +1100,14 @@ class Environment:
         return self._distmap.get(distribution_key, [])
 
     def add(self, dist):
-        """Add `dist` if we ``can_add()`` it and it has not already been added
-        """
+        """Add `dist` if we ``can_add()`` it and it has not already been added"""
         if self.can_add(dist) and dist.has_version():
             dists = self._distmap.setdefault(dist.key, [])
             if dist not in dists:
                 dists.append(dist)
                 dists.sort(key=operator.attrgetter('hashcmp'), reverse=True)
 
-    def best_match(
-            self, req, working_set, installer=None, replace_conflicting=False):
+    def best_match(self, req, working_set, installer=None, replace_conflicting=False):
         """Find distribution best matching `req` and usable on `working_set`
 
         This calls the ``find(req)`` method of the `working_set` to see if a
@@ -1124,6 +1194,7 @@ class ExtractionError(RuntimeError):
 
 class ResourceManager:
     """Manage resource extraction and packages"""
+
     extraction_path = None
 
     def __init__(self):
@@ -1135,9 +1206,7 @@ class ResourceManager:
 
     def resource_isdir(self, package_or_requirement, resource_name):
         """Is the named resource an existing directory?"""
-        return get_provider(package_or_requirement).resource_isdir(
-            resource_name
-        )
+        return get_provider(package_or_requirement).resource_isdir(resource_name)
 
     def resource_filename(self, package_or_requirement, resource_name):
         """Return a true filesystem path for specified resource"""
@@ -1159,9 +1228,7 @@ class ResourceManager:
 
     def resource_listdir(self, package_or_requirement, resource_name):
         """List the contents of the named resource directory"""
-        return get_provider(package_or_requirement).resource_listdir(
-            resource_name
-        )
+        return get_provider(package_or_requirement).resource_listdir(resource_name)
 
     def extraction_error(self):
         """Give an error message for problems extracting file(s)"""
@@ -1169,7 +1236,8 @@ class ResourceManager:
         old_exc = sys.exc_info()[1]
         cache_path = self.extraction_path or get_default_cache()
 
-        tmpl = textwrap.dedent("""
+        tmpl = textwrap.dedent(
+            """
             Can't extract file(s) to egg cache
 
             The following error occurred while trying to extract file(s)
@@ -1184,7 +1252,8 @@ class ResourceManager:
             Perhaps your account does not have write access to this directory?
             You can change the cache directory by setting the PYTHON_EGG_CACHE
             environment variable to point to an accessible directory.
-            """).lstrip()
+            """
+        ).lstrip()
         err = ExtractionError(tmpl.format(**locals()))
         err.manager = self
         err.cache_path = cache_path
@@ -1234,12 +1303,13 @@ class ResourceManager:
         mode = os.stat(path).st_mode
         if mode & stat.S_IWOTH or mode & stat.S_IWGRP:
             msg = (
-                "%s is writable by group/others and vulnerable to attack "
-                "when "
-                "used with get_resource_filename. Consider a more secure "
+                "Extraction path is writable by group/others "
+                "and vulnerable to attack when "
+                "used with get_resource_filename ({path}). "
+                "Consider a more secure "
                 "location (set with .set_extraction_path or the "
-                "PYTHON_EGG_CACHE environment variable)." % path
-            )
+                "PYTHON_EGG_CACHE environment variable)."
+            ).format(**locals())
             warnings.warn(msg, UserWarning)
 
     def postprocess(self, tempname, filename):
@@ -1282,9 +1352,7 @@ class ResourceManager:
         ``cleanup_resources()``.)
         """
         if self.cached_files:
-            raise ValueError(
-                "Can't change extraction path, files already extracted"
-            )
+            raise ValueError("Can't change extraction path, files already extracted")
 
         self.extraction_path = path
 
@@ -1308,9 +1376,8 @@ def get_default_cache():
     or a platform-relevant user cache dir for an app
     named "Python-Eggs".
     """
-    return (
-        os.environ.get('PYTHON_EGG_CACHE')
-        or appdirs.user_cache_dir(appname='Python-Eggs')
+    return os.environ.get('PYTHON_EGG_CACHE') or platformdirs.user_cache_dir(
+        appname='Python-Eggs'
     )
 
 
@@ -1334,6 +1401,38 @@ def safe_version(version):
         return re.sub('[^A-Za-z0-9.]+', '-', version)
 
 
+def _forgiving_version(version):
+    """Fallback when ``safe_version`` is not safe enough
+    >>> parse_version(_forgiving_version('0.23ubuntu1'))
+    <Version('0.23.dev0+sanitized.ubuntu1')>
+    >>> parse_version(_forgiving_version('0.23-'))
+    <Version('0.23.dev0+sanitized')>
+    >>> parse_version(_forgiving_version('0.-_'))
+    <Version('0.dev0+sanitized')>
+    >>> parse_version(_forgiving_version('42.+?1'))
+    <Version('42.dev0+sanitized.1')>
+    >>> parse_version(_forgiving_version('hello world'))
+    <Version('0.dev0+sanitized.hello.world')>
+    """
+    version = version.replace(' ', '.')
+    match = _PEP440_FALLBACK.search(version)
+    if match:
+        safe = match["safe"]
+        rest = version[len(safe):]
+    else:
+        safe = "0"
+        rest = version
+    local = f"sanitized.{_safe_segment(rest)}".strip(".")
+    return f"{safe}.dev0+{local}"
+
+
+def _safe_segment(segment):
+    """Convert an arbitrary string into a safe segment"""
+    segment = re.sub('[^A-Za-z0-9.]+', '-', segment)
+    segment = re.sub('-[^A-Za-z0-9]+', '-', segment)
+    return re.sub(r'\.[^A-Za-z0-9]+', '.', segment).strip(".-")
+
+
 def safe_extra(extra):
     """Convert an arbitrary string to a standard 'extra' name
 
@@ -1377,7 +1476,7 @@ def evaluate_marker(text, extra=None):
         marker = packaging.markers.Marker(text)
         return marker.evaluate()
     except packaging.markers.InvalidMarker as e:
-        raise SyntaxError(e)
+        raise SyntaxError(e) from e
 
 
 class NullProvider:
@@ -1418,8 +1517,6 @@ class NullProvider:
             return ""
         path = self._get_metadata_path(name)
         value = self._get(path)
-        if six.PY2:
-            return value
         try:
             return value.decode('utf-8')
         except UnicodeDecodeError as exc:
@@ -1449,21 +1546,27 @@ class NullProvider:
         script = 'scripts/' + script_name
         if not self.has_metadata(script):
             raise ResolutionError(
-                "Script {script!r} not found in metadata at {self.egg_info!r}"
-                .format(**locals()),
+                "Script {script!r} not found in metadata at {self.egg_info!r}".format(
+                    **locals()
+                ),
             )
         script_text = self.get_metadata(script).replace('\r\n', '\n')
         script_text = script_text.replace('\r', '\n')
         script_filename = self._fn(self.egg_info, script)
         namespace['__file__'] = script_filename
         if os.path.exists(script_filename):
-            source = open(script_filename).read()
+            with open(script_filename) as fid:
+                source = fid.read()
             code = compile(source, script_filename, 'exec')
             exec(code, namespace, namespace)
         else:
             from linecache import cache
+
             cache[script_filename] = (
-                len(script_text), 0, script_text.split('\n'), script_filename
+                len(script_text),
+                0,
+                script_text.split('\n'),
+                script_filename,
             )
             script_code = compile(script_text, script_filename, 'exec')
             exec(script_code, namespace, namespace)
@@ -1493,7 +1596,7 @@ class NullProvider:
     def _validate_resource_path(path):
         """
         Validate the resource paths according to the docs.
-        https://setuptools.readthedocs.io/en/latest/pkg_resources.html#basic-resource-access
+        https://setuptools.pypa.io/en/latest/pkg_resources.html#basic-resource-access
 
         >>> warned = getfixture('recwarn')
         >>> warnings.simplefilter('always')
@@ -1543,9 +1646,9 @@ is not allowed.
         AttributeError: ...
         """
         invalid = (
-            os.path.pardir in path.split(posixpath.sep) or
-            posixpath.isabs(path) or
-            ntpath.isabs(path)
+            os.path.pardir in path.split(posixpath.sep)
+            or posixpath.isabs(path)
+            or ntpath.isabs(path)
         )
         if not invalid:
             return
@@ -1558,10 +1661,9 @@ is not allowed.
 
         # for compatibility, warn; in future
         # raise ValueError(msg)
-        warnings.warn(
+        issue_warning(
             msg[:-1] + " and will raise exceptions in a future release.",
             DeprecationWarning,
-            stacklevel=4,
         )
 
     def _get(self, path):
@@ -1575,26 +1677,35 @@ is not allowed.
 register_loader_type(object, NullProvider)
 
 
+def _parents(path):
+    """
+    yield all parents of path including path
+    """
+    last = None
+    while path != last:
+        yield path
+        last = path
+        path, _ = os.path.split(path)
+
+
 class EggProvider(NullProvider):
     """Provider based on a virtual filesystem"""
 
     def __init__(self, module):
-        NullProvider.__init__(self, module)
+        super().__init__(module)
         self._setup_prefix()
 
     def _setup_prefix(self):
-        # we assume here that our metadata may be nested inside a "basket"
-        # of multiple eggs; that's why we use module_path instead of .archive
-        path = self.module_path
-        old = None
-        while path != old:
-            if _is_egg_path(path):
-                self.egg_name = os.path.basename(path)
-                self.egg_info = os.path.join(path, 'EGG-INFO')
-                self.egg_root = path
-                break
-            old = path
-            path, base = os.path.split(path)
+        # Assume that metadata may be nested inside a "basket"
+        # of multiple eggs and use module_path instead of .archive.
+        eggs = filter(_is_egg_path, _parents(self.module_path))
+        egg = next(eggs, None)
+        egg and self._set_egg(egg)
+
+    def _set_egg(self, path):
+        self.egg_name = os.path.basename(path)
+        self.egg_info = os.path.join(path, 'EGG-INFO')
+        self.egg_root = path
 
 
 class DefaultProvider(EggProvider):
@@ -1618,7 +1729,10 @@ class DefaultProvider(EggProvider):
 
     @classmethod
     def _register(cls):
-        loader_names = 'SourceFileLoader', 'SourcelessFileLoader',
+        loader_names = (
+            'SourceFileLoader',
+            'SourcelessFileLoader',
+        )
         for name in loader_names:
             loader_cls = getattr(importlib_machinery, name, type(None))
             register_loader_type(loader_cls, cls)
@@ -1678,6 +1792,7 @@ class MemoizedZipManifests(ZipManifests):
     """
     Memoized zipfile manifests.
     """
+
     manifest_mod = collections.namedtuple('manifest_mod', 'manifest mtime')
 
     def load(self, path):
@@ -1701,7 +1816,7 @@ class ZipProvider(EggProvider):
     _zip_manifests = MemoizedZipManifests()
 
     def __init__(self, module):
-        EggProvider.__init__(self, module)
+        super().__init__(module)
         self.zip_pre = self.loader.archive + os.sep
 
     def _zipinfo_name(self, fspath):
@@ -1711,20 +1826,16 @@ class ZipProvider(EggProvider):
         if fspath == self.loader.archive:
             return ''
         if fspath.startswith(self.zip_pre):
-            return fspath[len(self.zip_pre):]
-        raise AssertionError(
-            "%s is not a subpath of %s" % (fspath, self.zip_pre)
-        )
+            return fspath[len(self.zip_pre) :]
+        raise AssertionError("%s is not a subpath of %s" % (fspath, self.zip_pre))
 
     def _parts(self, zip_path):
         # Convert a zipfile subpath into an egg-relative path part list.
         # pseudo-fs path
         fspath = self.zip_pre + zip_path
         if fspath.startswith(self.egg_root + os.sep):
-            return fspath[len(self.egg_root) + 1:].split(os.sep)
-        raise AssertionError(
-            "%s is not a subpath of %s" % (fspath, self.egg_root)
-        )
+            return fspath[len(self.egg_root) + 1 :].split(os.sep)
+        raise AssertionError("%s is not a subpath of %s" % (fspath, self.egg_root))
 
     @property
     def zipinfo(self):
@@ -1752,26 +1863,22 @@ class ZipProvider(EggProvider):
         timestamp = time.mktime(date_time)
         return timestamp, size
 
-    def _extract_resource(self, manager, zip_path):
-
+    # FIXME: 'ZipProvider._extract_resource' is too complex (12)
+    def _extract_resource(self, manager, zip_path):  # noqa: C901
         if zip_path in self._index():
             for name in self._index()[zip_path]:
-                last = self._extract_resource(
-                    manager, os.path.join(zip_path, name)
-                )
+                last = self._extract_resource(manager, os.path.join(zip_path, name))
             # return the extracted directory name
             return os.path.dirname(last)
 
         timestamp, size = self._get_date_and_size(self.zipinfo[zip_path])
 
         if not WRITE_SUPPORT:
-            raise IOError('"os.rename" and "os.unlink" are not supported '
-                          'on this platform')
-        try:
-
-            real_path = manager.get_cache_path(
-                self.egg_name, self._parts(zip_path)
+            raise IOError(
+                '"os.rename" and "os.unlink" are not supported ' 'on this platform'
             )
+        try:
+            real_path = manager.get_cache_path(self.egg_name, self._parts(zip_path))
 
             if self._is_current(real_path, zip_path):
                 return real_path
@@ -1900,8 +2007,7 @@ class FileMetadata(EmptyProvider):
         return metadata
 
     def _warn_on_replacement(self, metadata):
-        # Python 2.7 compat for: replacement_char = '�'
-        replacement_char = b'\xef\xbf\xbd'.decode('utf-8')
+        replacement_char = '�'
         if replacement_char in metadata:
             tmpl = "{self.path} could not be properly decoded in UTF-8"
             msg = tmpl.format(**locals())
@@ -1991,7 +2097,7 @@ def find_eggs_in_zip(importer, path_item, only=False):
             dists = find_eggs_in_zip(zipimport.zipimporter(subpath), subpath)
             for dist in dists:
                 yield dist
-        elif subitem.lower().endswith('.dist-info'):
+        elif subitem.lower().endswith(('.dist-info', '.egg-info')):
             subpath = os.path.join(path_item, subitem)
             submeta = EggMetadata(zipimport.zipimporter(subpath))
             submeta.egg_info = subpath
@@ -2008,58 +2114,21 @@ def find_nothing(importer, path_item, only=False):
 register_finder(object, find_nothing)
 
 
-def _by_version_descending(names):
-    """
-    Given a list of filenames, return them in descending order
-    by version number.
-
-    >>> names = 'bar', 'foo', 'Python-2.7.10.egg', 'Python-2.7.2.egg'
-    >>> _by_version_descending(names)
-    ['Python-2.7.10.egg', 'Python-2.7.2.egg', 'foo', 'bar']
-    >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.egg'
-    >>> _by_version_descending(names)
-    ['Setuptools-1.2.3.egg', 'Setuptools-1.2.3b1.egg']
-    >>> names = 'Setuptools-1.2.3b1.egg', 'Setuptools-1.2.3.post1.egg'
-    >>> _by_version_descending(names)
-    ['Setuptools-1.2.3.post1.egg', 'Setuptools-1.2.3b1.egg']
-    """
-    def _by_version(name):
-        """
-        Parse each component of the filename
-        """
-        name, ext = os.path.splitext(name)
-        parts = itertools.chain(name.split('-'), [ext])
-        return [packaging.version.parse(part) for part in parts]
-
-    return sorted(names, key=_by_version, reverse=True)
-
-
 def find_on_path(importer, path_item, only=False):
     """Yield distributions accessible on a sys.path directory"""
     path_item = _normalize_cached(path_item)
 
     if _is_unpacked_egg(path_item):
         yield Distribution.from_filename(
-            path_item, metadata=PathMetadata(
-                path_item, os.path.join(path_item, 'EGG-INFO')
-            )
+            path_item,
+            metadata=PathMetadata(path_item, os.path.join(path_item, 'EGG-INFO')),
         )
         return
 
-    entries = safe_listdir(path_item)
-
-    # for performance, before sorting by version,
-    # screen entries for only those that will yield
-    # distributions
-    filtered = (
-        entry
-        for entry in entries
-        if dist_factory(path_item, entry, only)
-    )
+    entries = (os.path.join(path_item, child) for child in safe_listdir(path_item))
 
     # scan for .egg and .egg-info in directory
-    path_item_entries = _by_version_descending(filtered)
-    for entry in path_item_entries:
+    for entry in sorted(entries):
         fullpath = os.path.join(path_item, entry)
         factory = dist_factory(path_item, entry, only)
         for dist in factory(fullpath):
@@ -2067,19 +2136,21 @@ def find_on_path(importer, path_item, only=False):
 
 
 def dist_factory(path_item, entry, only):
-    """
-    Return a dist_factory for a path_item and entry
-    """
+    """Return a dist_factory for the given entry."""
     lower = entry.lower()
-    is_meta = any(map(lower.endswith, ('.egg-info', '.dist-info')))
+    is_egg_info = lower.endswith('.egg-info')
+    is_dist_info = lower.endswith('.dist-info') and os.path.isdir(
+        os.path.join(path_item, entry)
+    )
+    is_meta = is_egg_info or is_dist_info
     return (
         distributions_from_metadata
-        if is_meta else
-        find_distributions
-        if not only and _is_egg_path(entry) else
-        resolve_egg_link
-        if not only and lower.endswith('.egg-link') else
-        NoDists()
+        if is_meta
+        else find_distributions
+        if not only and _is_egg_path(entry)
+        else resolve_egg_link
+        if not only and lower.endswith('.egg-link')
+        else NoDists()
     )
 
 
@@ -2091,10 +2162,9 @@ class NoDists:
     >>> list(NoDists()('anything'))
     []
     """
+
     def __bool__(self):
         return False
-    if six.PY2:
-        __nonzero__ = __bool__
 
     def __call__(self, fullpath):
         return iter(())
@@ -2111,12 +2181,7 @@ def safe_listdir(path):
     except OSError as e:
         # Ignore the directory if does not exist, not a directory or
         # permission denied
-        ignorable = (
-            e.errno in (errno.ENOTDIR, errno.EACCES, errno.ENOENT)
-            # Python 2 on Windows needs to be handled this way :(
-            or getattr(e, "winerror", None) == 267
-        )
-        if not ignorable:
+        if e.errno not in (errno.ENOTDIR, errno.EACCES, errno.ENOENT):
             raise
     return ()
 
@@ -2132,7 +2197,10 @@ def distributions_from_metadata(path):
         metadata = FileMetadata(path)
     entry = os.path.basename(path)
     yield Distribution.from_location(
-        root, entry, metadata, precedence=DEVELOP_DIST,
+        root,
+        entry,
+        metadata,
+        precedence=DEVELOP_DIST,
     )
 
 
@@ -2154,17 +2222,16 @@ def resolve_egg_link(path):
     """
     referenced_paths = non_empty_lines(path)
     resolved_paths = (
-        os.path.join(os.path.dirname(path), ref)
-        for ref in referenced_paths
+        os.path.join(os.path.dirname(path), ref) for ref in referenced_paths
     )
     dist_groups = map(find_distributions, resolved_paths)
     return next(dist_groups, ())
 
 
-register_finder(pkgutil.ImpImporter, find_on_path)
+if hasattr(pkgutil, 'ImpImporter'):
+    register_finder(pkgutil.ImpImporter, find_on_path)
 
-if hasattr(importlib_machinery, 'FileFinder'):
-    register_finder(importlib_machinery.FileFinder, find_on_path)
+register_finder(importlib_machinery.FileFinder, find_on_path)
 
 _declare_state('dict', _namespace_handlers={})
 _declare_state('dict', _namespace_packages={})
@@ -2195,10 +2262,16 @@ def _handle_ns(packageName, path_item):
     if importer is None:
         return None
 
-    # capture warnings due to #1111
-    with warnings.catch_warnings():
-        warnings.simplefilter("ignore")
-        loader = importer.find_module(packageName)
+    # use find_spec (PEP 451) and fall-back to find_module (PEP 302)
+    try:
+        spec = importer.find_spec(packageName)
+    except AttributeError:
+        # capture warnings due to #1111
+        with warnings.catch_warnings():
+            warnings.simplefilter("ignore")
+            loader = importer.find_module(packageName)
+    else:
+        loader = spec.loader if spec else None
 
     if loader is None:
         return None
@@ -2214,7 +2287,7 @@ def _handle_ns(packageName, path_item):
     if subpath is not None:
         path = module.__path__
         path.append(subpath)
-        loader.load_module(packageName)
+        importlib.import_module(packageName)
         _rebuild_mod_path(path, packageName, module)
     return subpath
 
@@ -2256,6 +2329,15 @@ def _rebuild_mod_path(orig_path, package_name, module):
 def declare_namespace(packageName):
     """Declare that package 'packageName' is a namespace package"""
 
+    msg = (
+        f"Deprecated call to `pkg_resources.declare_namespace({packageName!r})`.\n"
+        "Implementing implicit namespace packages (as specified in PEP 420) "
+        "is preferred to `pkg_resources.declare_namespace`. "
+        "See https://setuptools.pypa.io/en/latest/references/"
+        "keywords.html#keyword-namespace-packages"
+    )
+    warnings.warn(msg, DeprecationWarning, stacklevel=2)
+
     _imp.acquire_lock()
     try:
         if packageName in _namespace_packages:
@@ -2270,8 +2352,8 @@ def declare_namespace(packageName):
                 __import__(parent)
             try:
                 path = sys.modules[parent].__path__
-            except AttributeError:
-                raise TypeError("Not a package:", parent)
+            except AttributeError as e:
+                raise TypeError("Not a package:", parent) from e
 
         # Track what packages are namespaces, so when new path items are added,
         # they can be updated
@@ -2312,11 +2394,11 @@ def file_ns_handler(importer, path_item, packageName, module):
         return subpath
 
 
-register_namespace_handler(pkgutil.ImpImporter, file_ns_handler)
-register_namespace_handler(zipimport.zipimporter, file_ns_handler)
+if hasattr(pkgutil, 'ImpImporter'):
+    register_namespace_handler(pkgutil.ImpImporter, file_ns_handler)
 
-if hasattr(importlib_machinery, 'FileFinder'):
-    register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)
+register_namespace_handler(zipimport.zipimporter, file_ns_handler)
+register_namespace_handler(importlib_machinery.FileFinder, file_ns_handler)
 
 
 def null_ns_handler(importer, path_item, packageName, module):
@@ -2354,16 +2436,23 @@ def _is_egg_path(path):
     """
     Determine if given path appears to be an egg.
     """
-    return path.lower().endswith('.egg')
+    return _is_zip_egg(path) or _is_unpacked_egg(path)
+
+
+def _is_zip_egg(path):
+    return (
+        path.lower().endswith('.egg')
+        and os.path.isfile(path)
+        and zipfile.is_zipfile(path)
+    )
 
 
 def _is_unpacked_egg(path):
     """
     Determine if given path appears to be an unpacked egg.
     """
-    return (
-        _is_egg_path(path) and
-        os.path.isfile(os.path.join(path, 'EGG-INFO', 'PKG-INFO'))
+    return path.lower().endswith('.egg') and os.path.isfile(
+        os.path.join(path, 'EGG-INFO', 'PKG-INFO')
     )
 
 
@@ -2375,20 +2464,6 @@ def _set_parent_ns(packageName):
         setattr(sys.modules[parent], name, sys.modules[packageName])
 
 
-def yield_lines(strs):
-    """Yield non-empty/non-comment lines of a string or sequence"""
-    if isinstance(strs, six.string_types):
-        for s in strs.splitlines():
-            s = s.strip()
-            # skip blank lines/comments
-            if s and not s.startswith('#'):
-                yield s
-    else:
-        for ss in strs:
-            for s in yield_lines(ss):
-                yield s
-
-
 MODULE = re.compile(r"\w+(\.\w+)*$").match
 EGG_NAME = re.compile(
     r"""
@@ -2450,7 +2525,7 @@ class EntryPoint:
         try:
             return functools.reduce(getattr, self.attrs, module)
         except AttributeError as exc:
-            raise ImportError(str(exc))
+            raise ImportError(str(exc)) from exc
 
     def require(self, env=None, installer=None):
         if self.extras and not self.dist:
@@ -2536,22 +2611,15 @@ class EntryPoint:
         return maps
 
 
-def _remove_md5_fragment(location):
-    if not location:
-        return ''
-    parsed = urllib.parse.urlparse(location)
-    if parsed[-1].startswith('md5='):
-        return urllib.parse.urlunparse(parsed[:-1] + ('',))
-    return location
-
-
 def _version_from_file(lines):
     """
     Given an iterable of lines from a Metadata file, return
     the value of the Version field, if present, or None otherwise.
     """
+
     def is_version_line(line):
         return line.lower().startswith('version:')
+
     version_lines = filter(is_version_line, lines)
     line = next(iter(version_lines), '')
     _, _, value = line.partition(':')
@@ -2560,12 +2628,19 @@ def _version_from_file(lines):
 
 class Distribution:
     """Wrap an actual or potential sys.path entry w/metadata"""
+
     PKG_INFO = 'PKG-INFO'
 
     def __init__(
-            self, location=None, metadata=None, project_name=None,
-            version=None, py_version=PY_MAJOR, platform=None,
-            precedence=EGG_DIST):
+        self,
+        location=None,
+        metadata=None,
+        project_name=None,
+        version=None,
+        py_version=PY_MAJOR,
+        platform=None,
+        precedence=EGG_DIST,
+    ):
         self.project_name = safe_name(project_name or 'Unknown')
         if version is not None:
             self._version = safe_version(version)
@@ -2588,8 +2663,13 @@ class Distribution:
                     'name', 'ver', 'pyver', 'plat'
                 )
         return cls(
-            location, metadata, project_name=project_name, version=version,
-            py_version=py_version, platform=platform, **kw
+            location,
+            metadata,
+            project_name=project_name,
+            version=version,
+            py_version=py_version,
+            platform=platform,
+            **kw,
         )._reload_version()
 
     def _reload_version(self):
@@ -2598,10 +2678,10 @@ class Distribution:
     @property
     def hashcmp(self):
         return (
-            self.parsed_version,
+            self._forgiving_parsed_version,
             self.precedence,
             self.key,
-            _remove_md5_fragment(self.location),
+            self.location,
             self.py_version or '',
             self.platform or '',
         )
@@ -2645,48 +2725,55 @@ class Distribution:
     @property
     def parsed_version(self):
         if not hasattr(self, "_parsed_version"):
-            self._parsed_version = parse_version(self.version)
+            try:
+                self._parsed_version = parse_version(self.version)
+            except packaging.version.InvalidVersion as ex:
+                info = f"(package: {self.project_name})"
+                if hasattr(ex, "add_note"):
+                    ex.add_note(info)  # PEP 678
+                    raise
+                raise packaging.version.InvalidVersion(f"{str(ex)} {info}") from None
 
         return self._parsed_version
 
-    def _warn_legacy_version(self):
-        LV = packaging.version.LegacyVersion
-        is_legacy = isinstance(self._parsed_version, LV)
-        if not is_legacy:
-            return
+    @property
+    def _forgiving_parsed_version(self):
+        try:
+            return self.parsed_version
+        except packaging.version.InvalidVersion as ex:
+            self._parsed_version = parse_version(_forgiving_version(self.version))
 
-        # While an empty version is technically a legacy version and
-        # is not a valid PEP 440 version, it's also unlikely to
-        # actually come from someone and instead it is more likely that
-        # it comes from setuptools attempting to parse a filename and
-        # including it in the list. So for that we'll gate this warning
-        # on if the version is anything at all or not.
-        if not self.version:
-            return
+            notes = "\n".join(getattr(ex, "__notes__", []))  # PEP 678
+            msg = f"""!!\n\n
+            *************************************************************************
+            {str(ex)}\n{notes}
+
+            This is a long overdue deprecation.
+            For the time being, `pkg_resources` will use `{self._parsed_version}`
+            as a replacement to avoid breaking existing environments,
+            but no future compatibility is guaranteed.
 
-        tmpl = textwrap.dedent("""
-            '{project_name} ({version})' is being parsed as a legacy,
-            non PEP 440,
-            version. You may find odd behavior and sort order.
-            In particular it will be sorted as less than 0.0. It
-            is recommended to migrate to PEP 440 compatible
-            versions.
-            """).strip().replace('\n', ' ')
+            If you maintain package {self.project_name} you should implement
+            the relevant changes to adequate the project to PEP 440 immediately.
+            *************************************************************************
+            \n\n!!
+            """
+            warnings.warn(msg, DeprecationWarning)
 
-        warnings.warn(tmpl.format(**vars(self)), PEP440Warning)
+            return self._parsed_version
 
     @property
     def version(self):
         try:
             return self._version
-        except AttributeError:
+        except AttributeError as e:
             version = self._get_version()
             if version is None:
                 path = self._get_metadata_path_for_display(self.PKG_INFO)
-                msg = (
-                    "Missing 'Version:' header and/or {} file at path: {}"
-                ).format(self.PKG_INFO, path)
-                raise ValueError(msg, self)
+                msg = ("Missing 'Version:' header and/or {} file at path: {}").format(
+                    self.PKG_INFO, path
+                )
+                raise ValueError(msg, self) from e
 
             return version
 
@@ -2714,8 +2801,7 @@ class Distribution:
             reqs = dm.pop(extra)
             new_extra, _, marker = extra.partition(':')
             fails_marker = marker and (
-                invalid_marker(marker)
-                or not evaluate_marker(marker)
+                invalid_marker(marker) or not evaluate_marker(marker)
             )
             if fails_marker:
                 reqs = []
@@ -2739,10 +2825,10 @@ class Distribution:
         for ext in extras:
             try:
                 deps.extend(dm[safe_extra(ext)])
-            except KeyError:
+            except KeyError as e:
                 raise UnknownExtra(
                     "%s has no such extra feature %r" % (self, ext)
-                )
+                ) from e
         return deps
 
     def _get_metadata_path_for_display(self, name):
@@ -2787,8 +2873,9 @@ class Distribution:
     def egg_name(self):
         """Return what this distribution's standard .egg filename should be"""
         filename = "%s-%s-py%s" % (
-            to_filename(self.project_name), to_filename(self.version),
-            self.py_version or PY_MAJOR
+            to_filename(self.project_name),
+            to_filename(self.version),
+            self.py_version or PY_MAJOR,
         )
 
         if self.platform:
@@ -2818,21 +2905,13 @@ class Distribution:
     def __dir__(self):
         return list(
             set(super(Distribution, self).__dir__())
-            | set(
-                attr for attr in self._provider.__dir__()
-                if not attr.startswith('_')
-            )
+            | set(attr for attr in self._provider.__dir__() if not attr.startswith('_'))
         )
 
-    if not hasattr(object, '__dir__'):
-        # python 2.7 not supported
-        del __dir__
-
     @classmethod
     def from_filename(cls, filename, metadata=None, **kw):
         return cls.from_location(
-            _normalize_cached(filename), os.path.basename(filename), metadata,
-            **kw
+            _normalize_cached(filename), os.path.basename(filename), metadata, **kw
         )
 
     def as_requirement(self):
@@ -2867,7 +2946,8 @@ class Distribution:
         """Return the EntryPoint object for `group`+`name`, or ``None``"""
         return self.get_entry_map(group).get(name)
 
-    def insert_on(self, path, loc=None, replace=False):
+    # FIXME: 'Distribution.insert_on' is too complex (13)
+    def insert_on(self, path, loc=None, replace=False):  # noqa: C901
         """Ensure self.location is on path
 
         If replace=False (default):
@@ -2943,14 +3023,18 @@ class Distribution:
         nsp = dict.fromkeys(self._get_metadata('namespace_packages.txt'))
         loc = normalize_path(self.location)
         for modname in self._get_metadata('top_level.txt'):
-            if (modname not in sys.modules or modname in nsp
-                    or modname in _namespace_packages):
+            if (
+                modname not in sys.modules
+                or modname in nsp
+                or modname in _namespace_packages
+            ):
                 continue
             if modname in ('pkg_resources', 'setuptools', 'site'):
                 continue
             fn = getattr(sys.modules[modname], '__file__', None)
-            if fn and (normalize_path(fn).startswith(loc) or
-                       fn.startswith(self.location)):
+            if fn and (
+                normalize_path(fn).startswith(loc) or fn.startswith(self.location)
+            ):
                 continue
             issue_warning(
                 "Module %s was already imported from %s, but %s is being added"
@@ -2963,6 +3047,9 @@ class Distribution:
         except ValueError:
             issue_warning("Unbuilt egg for " + repr(self))
             return False
+        except SystemError:
+            # TODO: remove this except clause when python/cpython#103632 is fixed.
+            return False
         return True
 
     def clone(self, **kw):
@@ -3002,6 +3089,7 @@ class DistInfoDistribution(Distribution):
     Wrap an actual or potential sys.path entry
     w/metadata, .dist-info style.
     """
+
     PKG_INFO = 'METADATA'
     EQEQ = re.compile(r"([\(,])\s*(\d.*?)\s*([,\)])")
 
@@ -3037,12 +3125,12 @@ class DistInfoDistribution(Distribution):
                 if not req.marker or req.marker.evaluate({'extra': extra}):
                     yield req
 
-        common = frozenset(reqs_for_extra(None))
+        common = types.MappingProxyType(dict.fromkeys(reqs_for_extra(None)))
         dm[None].extend(common)
 
         for extra in self._parsed_pkg_info.get_all('Provides-Extra') or []:
             s_extra = safe_extra(extra.strip())
-            dm[s_extra] = list(frozenset(reqs_for_extra(extra)) - common)
+            dm[s_extra] = [r for r in reqs_for_extra(extra) if r not in common]
 
         return dm
 
@@ -3067,45 +3155,27 @@ def issue_warning(*args, **kw):
     warnings.warn(stacklevel=level + 1, *args, **kw)
 
 
-class RequirementParseError(ValueError):
-    def __str__(self):
-        return ' '.join(self.args)
-
-
 def parse_requirements(strs):
-    """Yield ``Requirement`` objects for each specification in `strs`
+    """
+    Yield ``Requirement`` objects for each specification in `strs`.
 
     `strs` must be a string, or a (possibly-nested) iterable thereof.
     """
-    # create a steppable iterator, so we can handle \-continuations
-    lines = iter(yield_lines(strs))
+    return map(Requirement, join_continuation(map(drop_comment, yield_lines(strs))))
 
-    for line in lines:
-        # Drop comments -- a hash without a space may be in a URL.
-        if ' #' in line:
-            line = line[:line.find(' #')]
-        # If there is a line continuation, drop it, and append the next line.
-        if line.endswith('\\'):
-            line = line[:-2].strip()
-            try:
-                line += next(lines)
-            except StopIteration:
-                return
-        yield Requirement(line)
+
+class RequirementParseError(packaging.requirements.InvalidRequirement):
+    "Compatibility wrapper for InvalidRequirement"
 
 
 class Requirement(packaging.requirements.Requirement):
     def __init__(self, requirement_string):
         """DO NOT CALL THIS UNDOCUMENTED METHOD; use Requirement.parse()!"""
-        try:
-            super(Requirement, self).__init__(requirement_string)
-        except packaging.requirements.InvalidRequirement as e:
-            raise RequirementParseError(str(e))
+        super(Requirement, self).__init__(requirement_string)
         self.unsafe_name = self.name
         project_name = safe_name(self.name)
         self.project_name, self.key = project_name, project_name.lower()
-        self.specs = [
-            (spec.operator, spec.version) for spec in self.specifier]
+        self.specs = [(spec.operator, spec.version) for spec in self.specifier]
         self.extras = tuple(map(safe_extra, self.extras))
         self.hashCmp = (
             self.key,
@@ -3117,10 +3187,7 @@ class Requirement(packaging.requirements.Requirement):
         self.__hash = hash(self.hashCmp)
 
     def __eq__(self, other):
-        return (
-            isinstance(other, Requirement) and
-            self.hashCmp == other.hashCmp
-        )
+        return isinstance(other, Requirement) and self.hashCmp == other.hashCmp
 
     def __ne__(self, other):
         return not self == other
@@ -3145,7 +3212,7 @@ class Requirement(packaging.requirements.Requirement):
 
     @staticmethod
     def parse(s):
-        req, = parse_requirements(s)
+        (req,) = parse_requirements(s)
         return req
 
 
@@ -3170,7 +3237,7 @@ def _find_adapter(registry, ob):
 def ensure_directory(path):
     """Ensure that the parent directory of `path` exists"""
     dirname = os.path.dirname(path)
-    py31compat.makedirs(dirname, exist_ok=True)
+    os.makedirs(dirname, exist_ok=True)
 
 
 def _bypass_ensure_directory(path):
@@ -3248,6 +3315,15 @@ def _initialize(g=globals()):
     )
 
 
+class PkgResourcesDeprecationWarning(Warning):
+    """
+    Base class for warning about deprecations in ``pkg_resources``
+
+    This class is not derived from ``DeprecationWarning``, and as such is
+    visible by default.
+    """
+
+
 @_call_aside
 def _initialize_master_working_set():
     """
@@ -3274,10 +3350,7 @@ def _initialize_master_working_set():
     # ensure that all distributions added to the working set in the future
     # (e.g. by calling ``require()``) will get activated as well,
     # with higher priority (replace=True).
-    tuple(
-        dist.activate(replace=False)
-        for dist in working_set
-    )
+    tuple(dist.activate(replace=False) for dist in working_set)
     add_activation_listener(
         lambda dist: dist.activate(replace=True),
         existing=False,
@@ -3286,11 +3359,3 @@ def _initialize_master_working_set():
     # match order
     list(map(working_set.add_entry, sys.path))
     globals().update(locals())
-
-class PkgResourcesDeprecationWarning(Warning):
-    """
-    Base class for warning about deprecations in ``pkg_resources``
-
-    This class is not derived from ``DeprecationWarning``, and as such is
-    visible by default.
-    """
diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 7d423192b74f12758665e9019748f490836d70d5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 100359
zcmYe~<>g{vU|^UdaWM7kGDe2SAPzF-U|?WyU|?V<X5wIANMVR#NMTH2%3;i9ieh2}
zv6*w2qnJ||Q<!sDqFBH*YZNP(W{YA2)9g{~V45R}159&9ae`^CC@wI~9mNf%d7^m0
zG;b6ynC6S(1JnFb{9sxjN&rj?MhSvxp(r6REgU5RrbVMf!L(SE7?>815(m=~Q4(NU
zGD;FmOGQb6Y3V5G6vh;m9KKwcC>chEDv0f}QL^C-c`_^vsd5t-D_IyBKoG26K1w!{
zA&<#`p^76_fsrAcAy0yZAysh#W2G8M4I@LUQj`KjMG9jIYmRcRN|XvXjM#EibJe2M
za@C{Mb2Xwgz+&t<EV-Idnv4upGAWEH962nxT2WfL+ELoMI#D`|3@MyZx=<TH?&yHn
zkir$E3%7wghb31pN*`<*PmV#ZVU%I6QIruQLlwmT#<?a@ri=`!rdeii*MiKt0yT>{
z$`ooAZwg<Id9Fp21=uY99OYcgC`&L~AV)dZD$0tHA=NrXu$d7|3qfgNC@lh}ZK7;b
zL{piw>{u9>8L}BBFcn#(h=FOBJQhZVJdRZR6!B)pCdO2iEQbk9MIkB7QI09hQBEn$
zQO+sMQ7$RWQLZV>QEn;BQSK?sQ64GGQJyKxQC=y`QQj%cQ9dcmQNAh6QGO}RQT{2+
zQ2{B;QGqGUQ9&upQNivEDH17?Eet7=sUgkGQK2bPDbg(rQDK=3QQ;{vDY7jLQ4uL}
zDe^50QIRPMDT*x&QBf&MDatJjQPC+XDXJ|DQ86iMDe5f@QL!l+DVi+|QE@3+DcUUz
zEDTZcQ3)wJDY`8TQHkjcDSC?-qmtYiQuI>{S{PCcQj?pRqf*=%QVdg!S{PD{Qd63l
zqf*@&QjAkfS{PDHQd66mqte_NQcP3KS{PEy!1C$t3@PR*7A*`Z7GQoxCPP$aie*+7
zDE#^uqOw!0qH<EKqjFPtqw-Q1qw-U1q6$)MQ|ww8q6$;&Qyf|tqKeWP(il@5Q=D2D
zql#0UQ(RgYqDoR+Q`}k@qDoWQ7nG&AFJz1=2eUjDGDcOTmPS>kc&2!@Fho_Qc&GTZ
zFho_SR!7yO_@?-^Fhtd+_@@N4Fhtd*yiN&B32I@Cs!s_{329-7YH(*r2~7!WVMqyU
zW{PTbXGjT8iD+R+iAZg1W{zrdXGn=miE3d;iE3twYIbKxiB5@WVMvKdZE0qXYISEw
ziA{-XVMvK<W{PS{ZHsDmXGn=pNoZk6Nl3MCW{&D`XGlp*Norw8Nor<_>P$&aNoiq-
z>PksXNo!$<>P|^d$!KAS>Pg8=$!cMU>P^W`$!TGT>PyK@$!lSV>Q8x-lAlu0!WcEd
zogt+#rKp7=rKp)HYGP_(>ZH_(%}k68?hGl#DJ3loDJ7{Bo0+2~yECMerj)fXq?Dyj
zZf1^}k~(F<)P)RSb>%4)Eet6YV0F_{r!_M~O?PKVsZ6PAVMwV0`)7tbLrQf@O$$Rx
zP3nwh=BSzO3@NoKbuA1jbzswGr52`gWz9~V1+}?8rJ;o(r6F}%Gjr4&cZQV4l%^Jj
zl%~`v&CF4A-5FAvQ(9UWQd&}HH8V%eON~fr&16Vv>jjmp?I|5C3{mq_-llY>bhR)>
zEl7En(w)-N!WgwMbw1dRg&;dp-lz1Y^tCWXElQoAIw^G#Sgb!~LJLFG;*<|56H_L&
zFh(s&nVd4Eg&}IGJ44FUlxZytDbt#nqL!shPnpre5VbsIX3DG<hNu-Ovs31@Fhs3P
znVT}Ng&}HH>ikr`tktPYKxU?{Ni|KG-^?_Dtw<<!eyVBKTBtb0%?m(ohPr<th@G-1
zWpN8b)Vh=<DN9=zqSmJ@OIhB+5Vav?Mas$+hNz7xA5&JPtZre9+LW>;Wo-*X)aKN6
zVB0o>ZCeNSA%u;vxhHiU*k-VJ%DR;GEeugxQrD$UO5Fm|m9imaV+%vn)|5>tn_C#7
zwq=5H$d;6?EsRmyQ?{jSZ()eqk+LIYXA48r&Xip#yIUBdcBSk|+1tVpwHusI_AO-0
z+7q=G%-)~Mp0zKPJ!`)c!$PL4Jy8eT8Bz|U9Bg4oIoQk;bui^n%HbA<s6#17QjWGT
zL>+c#NI8~ryoDj<cr#Pf5qE}^6DcQK7*bBA9%*KdI_l1law_F?3q#6jF#lNUk<_E9
z$5PJBVU9YUayI2$3q#ZicZQVnDHmE8QZA&PY-Wx+m2xrVQVT=WX?KQ{%PCh{7*ejJ
zT4kNdI@`<~bvET{%C#1TsB<aTQ*N{{M4eB$nR2UzA?iZP?UXw$3{e+T?xx&pVTihv
zazEuk3q#c9RPL-RDGyUaQ#ex|^)fRuq&!Y}(!vmRHT7!hwPsK#JxzJm!r06hbv^ZJ
z%JY;LEey?!Q8(NfQeLLKYGFuum3p(8IqFslb1;MEr^F~G1_rKx#N_P6^i+kS)Z+Zo
zqU2Ns#{f?*T`Yi$%Mqa{vsfWfAtygQGdVFwAuTf}RUtV)uOu-uFEvG>JhLPtGfyE=
zp#WmEjzWGBLN!-$X;MmNQEGBYeo>`DNk(c>YJQrYf<j0}Dog{y8pi-nh180I)Z~(4
zgkWA`ZfY@CNxnixVp%H4gv=s^g2a*xg@VMQl46D8)PlsK#1g1O6cQ5j6B2Y3wDR&x
zv=quS5=&CcQj0*k6ms&D6LYx0I-z><ixe`8^%N9b@)h#(OB70rQx)=y^}s6f3sQ>`
zOEUBGiWN%o6><~vG7Cy`5=#)_#szkkLQ-mGUb;d-VsUY5ib7^yNj}&r#{f?~E-sv2
z%q&(&NiEJy2ZdfqzCw9^Q8qXf74q_na-jiSTv=R_nhOh}VjV8M)bw<4&=>0{B<7_k
zl;(lLJ2gcCA)%+B;8~)OoS3JOm{SZj7aTJ=nYo$Z5K62BTg0VTm018W3~UxC3Kfz|
zi%arz6#`rX6pRgw6ms$tQ&NkH6-qJ^OB9Mr3kvd!O2D2=NJvjDiBCx^Nz~9xNZ`s%
zEy>7F(c^jvYJ6%k-r`S8D$dU-ElG{f%mwN3(`3BG1JVKErWR>3-eNA!tk7h>#a3FB
zlarZri#a#3;1*k2W=;uMmbJ7bGdER}`4($#c1mW^Ew-XmP+;F;E6vNv%*zgO(`3BG
zl3$RTr^$4SHM1C`gtfRJC$r=wBLf42CgUxxf=Xk<<ow)%#1c)$TkMGi1u2<D#hQ$_
zI6*;{n4X!JUL{+QS)dnRmYSE6U!(^Y)+<XbD$dN$t5U!&U0jfwoSBxHT2x%6gk42Z
zYGG++QEF~#UP&=7OL7y7vQvwSHJM&AGcYg|fnCj1B+S6T@RF5*fuTx1pt2+*KTp9}
z&lHrGK<N&YQWc<PrzC@d8X1F30Jrr87#J8*8KM|d7^0X`7^9d|n1UHJnQ!q1xCWS*
z7=$Ml<$?U3$fcm5pb!d5vgH}6d7xM=N>u>m@jQjh;^NX&a3WDiRDgyC$PsX#gR=@K
zaC0g_NgtGSz{Y{njfshY9+=~|lI0dhd^{-H;^S{|#mDF7r<CTT#>d~{iH|QVP0WGH
zu*b)z<R{0+uVg5a1_cF(_|@iY6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu5bEa{<{A|2
z8R8hM;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A73o5FLOER-#QuE4Ud@_?_iZe@6
zbs^E5S{zf5S)dP%d;Nm!^mtfdSgao(pP83g5+AQuP+26(z`#%e?m;myFmNz}`N^Q5
zh6O!{4eDk&gA|#8VvetbA&YSVQw_sH#&CvU1{MYoKa0820Mc{^@fNUvWZ4)Z8G;!M
z7*ZI58CEj-X|fgxF)%RPVuyzKE%q=-LcGQ2nOByWlbHhJ^ZKNwCni@yxtff(7|Rer
zS0n>6gts8Es5mtqYE(VQaUfSRFfuXnF$ypiDKjuIp!kD{fq{XIfq}srq*RH4fuV$<
znPCBA4dX&aMurlm1&k%k3s`CxYZw+XfkZ%VE|LXhHP&0~={fmHi8;l$*h&jh5=&BV
zamN>zB$lMcmn9Yz-(pG0OfI>_kyezSo1I!&tjTnXy)3b)q_QCO7E^XPy1V(}Q&N+2
z5{ptHMs$K)!vYFxMjpl@ZIGiu92f@4fG{}lEf^RWG8t;Y4zFb_VO+qpkimr^Rw0I|
zmZ_GxhB1Y)hFP3JlA(sNhDnm4nX!hUhRKGZP^g9>m_d`t?-pBpF{p^rWG+$xB||k(
zFtTQrq~;c{WVyu(_R%fI^jnPCMWEn8cQ{Xce0pjLSXF#{AIRC@t~nzMBO9XtqZDJ2
z5y<hN)Pn4IP*#UK9u(rWj5Q1k7{Lx#K{&jG3FKt3<C!4NuVHRxW@ISjLvnm^YDqlI
z@wzY{6zPFjpezM(FgS7W#K#xI-8v2AR!G_axm1p^$OPS`AXkIZ2iT<`r8Nu-7#1=F
zGeA-R<1Lot{DR7rjJKG}5_2H-fNca@#svvhP%4-UvI=An17i^=wvs_bA1pXPY!C)p
zBF4bLP{Rnagb_qD)}SRirdzDZIjM<7MXC%83@e#$F=wY%-eSs6D$>W|U9R|IP}qQ6
zun^<|P>Nw-<X|kaCDo(gNGt;7a&%wvKzx~>l$DxXvJ7Mk)Sq@BJ3#)z>Q6qXKhgaM
ziG(66EWY7^_y%IrDkPiiK{ml`0nwmn17UZNB9N!ynHKE&m5jGo5{uG{!5jzyjxY|J
zoW$IultjCA3=9mPK?W5$p&JeI94H}xBP#(~TGTRtG99R7t7Qabw^GKUm=fkJmK3IJ
zrlOcCwG`$QmIbUOY|WsdC)QRbNrr`tHH-_`Q`i<VrZI^z)Pja(gjg6#I4YwcWhG>Y
z1DwX$!A;ko)RNL7P-T@_tWc1XSdx}sl&fB>kegVMnOmBx0IHG_OEQykQeoAW9v8SS
zO35rPDJ{v&Db@p#dZ2s`)2^WjZF1#QDio!HS}UOTPO3s~W**o~Xb}oFCO=KVH!)ek
zKUg6G(k3d;FU?6&NCGtp!Bu_=sHLb?TAZq-kXliang?n}6e|=I<)@S;r=}<*Rf3H{
zxJE(2sk8*#L{%tHRVYu)194LG6p}Mile0lpE6hikIhiGupz66KUm-g$zZ_IwgUy0E
zPXW_usS1fjsR~*}rFozVUklXU&R0mx$;mHQC@lsx|MSz}O-rzEz~-e^6y#(kXO@6N
z1MDY-M1{Q6^3)<&kRn^919En5X>kdpwTa@g<kF&|)Vva8Z6z703jV>+IPpwVD9Oky
z2K6FRGC|F3h5Y2?(xPI8G*I6muTmi&)Kh>*GkSX@GfyG2q!{dGSX3$$mlS2@r5Ec!
z3{ES}O9q=;oB@j_aHOQ9rYIyPC+8QXWag#kR6<)Tx7bn=i^?<es(5k}lk<x!bXALW
zRf}&i>b(Rdc5ur~lk=7kDCs1XX6B^C!)(1J1l9npjf25XxW$^ASdyG^i@CV6_!b9T
zB}-O*X5KBHc(8^FaP54HHN7amwBQz3SYl3Ts%ueEevu~AEf$cLTa3AoY>6mL#X#0W
z8{(-5Cu{`ea8SFCftQVui&2P?iBXM_hl!1`C<s(VyWe7mHXCno6_w`27bh2G7L-6*
z<ON0fWtl0dMYjY%MuSpjQD#ypDA;ZZfSUjDsd*(umGK4nnRz9*ctL6)0-)wPAA*~i
zmzIA^Fta4J2w6k%Eq++DDjpIyr~;{pxwi!2DnNZoP@C|U09+_1v$zD*wnrF~T9H{?
zQhbXKt_0Hf7lbt%Kn4^SBqpcc;s*7pGV{_wb=@uT#FUiy#N?99GH{PB9%OK8UTV=T
zp|s4rlz3!+7vB;FRTrrhB}E_&`FZi6-ry}kP=%9MS`ZJjx%ieK$p0y+X^EvdCGp9L
z$r-7)xLxzgGK=!_KyCk9T;cgepj;fBT5^j&2-?~9P0UM7Pc6E|<B|yq5@=X+2O;_l
zx42wEVIBYua<IM}aD;#p$1Q$nLUYc~OUnT@twfLw^2;xA%P-AKxy2Kj2g;3kt{`vR
z;s;aU+yFKO+>X5^1ZgBf(+0@N#o&hFEzaV^v{Z1*{T2_H2`y!yNd{W*-V%Y8PC2RY
z+)#XryD~F1CnY{7GcUFH79Y4%7GInSw!8Qi7uYy(*xuqU$&ZJ}IbSBEjT;Z?7~SGe
zElbQP1+^lf0s^Ud#id25@$i9!TYQkNa%NR3B!)O#-QD9|JcC1SaXWeXIR-^SIl=y+
zLC&ra4zII^tFyO%Xb6PM<Ki0T>f;{(;R$;Brj{gvdbI(tTp{QQi#NCsk6UI=Doo)m
zo`A%X3^<S5H9Z~9;dRX|D5-?&<4Xl`<KY>O$FDRe2QCZJ3Fq*;KoS*PfIBL)0M6kr
zN=?r!24yu++D$FGB?T9Nr~dei#JrT8)S_D=a5+$JPA!TDx4b3NGAl|8z%dNYEb*{z
zQ4y%Aa!W2CJ00flVwco{qSRz?wt;pYZ*hQ1k=(@0yjx<9Wr>+NiAg!B$f>Xxqjw4_
zL&3dM35?!p3UdoX6iW(AFoPy*Q68uVrRSJb49<KCNr}a&;QAmXwIDSwB{eS@R7r!!
z7Bchm6jDLOWid)W2GrmI`2pNA0rjV97_u0$7)zLH7_yj~8O7nPR+d|w@$tzyiN(e7
z@kQdG#y(3?YC%zvBdA5mc#EYtH75<d_~nR?2dRmV{|72?L4IOjtdanQ6jBb=gDC>_
z=s*S+f&5$~32Mtpfr!~40$ipe2vExl?D^jylR=F&4n`Ixun0z2g1iR~OB;-^jABV;
z1vRt4V}NX_tSPK1Y+yEf3VRAi3quq~3TFye3qurV3U@GrCQng5D7;sJYf(qgkWo=;
zVoIfMW?pegVopwK3cT`8hL$$PkZKrIk%Nkj)MC((60~%H*6YFW+7{G}&P>e7tbz^9
zfwUpaMoux{At;bE+*GiekV-{JHC<&~4T=~&P=Q?wY7ZfdODZi<fJhdl7J}tKW@Q$o
zreGuxP|Sf72&j(+N+2nWlAumFlOK2>rU(?eMKe*O2^2%1&TMfB4<l$s71S_hsuDpf
zjlm8h#Xf$JEjaCCE=nyFK(bC4-MXUGLJZqLsR!&k5m4^}ocz-mG8sykni-Zb_Ax@c
zZ7Z2?amJUV=7L%pskhibE$PIPTWsJF(qgQhXM;44Md0pXtP;a?52yv53<_XS0D&+l
zxq|p$CxJq-hOw9f)TRdod<|n7qc}q?Qwd`YQy-`!&RA6fj(O1NlxG@zxGO#h-1^PS
z&(j4LqdE#jkgfpI09Bd-C~1J3vY?a!8Q}t%<D8#Yl3GzxnwW#`T)0)5OyG=vOA@DA
zP3EFmpi+Vxma5{DD#3ct3ke?3a9BKOY&^B1L>v@Ypq>%~D+?nFBM)Ph47wYTmHTOO
zfy*NFA_LTKy~R;b1R9bqsVo9@q>JW*QqB?(u^dDo$`UXO6wu(@%>;4*sBOr>$imLT
z#Kg$O48k1DU|HOS3uycUc^EO3C5ttMNt_{yHI)rs#IUEZ1~X`~6)go7Bdy@jbW}j|
zAS6N(lao^mN<dQxB^jATDWHM-#N5=9)FM!0JyoGNwFK0!D9K0#8v+euaFYb0A1aap
z>i8%iGCgt`0xcoL6p|_t1wkpO0Ekbjti{MC@HB~92xv0-6}f=|6j!D!0(I}TK%ojU
zfq|(?6=#~!gSk3BsnSoA18dZRO5h?;{1&YM*$OfoDMcaT5){NrAX`DHiGz`am5Ygq
z5ghQi<IsbI3L=#iQbjZ~B3BYAJS_}STq(T444QmJ1)x|~15F7PmO@H?P%#YaFDR5J
z7J~<d(?AW-s$kI6hdQD_R#(8S7+m^ig64a`J<b%27%VCV^&g0i!=gE$pu`!0pqyh0
z3QA}MN+72qSPL2ycf_WdqIvl2yTu7j21Uh|NVdx1vK5qMi}18+z=LB9Sq#NoDU87k
zDNG9(K_%%zM$j<7Ull*77ELSw_2R*8wkjqa1x==+l^_@TfCy~$8ZX?1pm4SYxe_!O
z%)rFP$ii5qgx{qgEf^t1TqRVr0Edf;Kn0sK$Q|G~Vyu$J;RbMZ18Vevsu~amu|ayk
z)eR`Gpbb`nO~zWkvB!ga5+Cn|WUUNVYoQALG`X>6X+&-Yr8G#;gGTBgR<8zm8Jw>X
z1h}*YWiNe@-Jp6K)cj)sm(-xrnu(E%m4g|a0Woqr$itwdUJNSakxOjI#7|KnDA(E{
z`$HimKeaedy#z9wnwY1c1n!V2q@^a7loq8bK}%wV^vtr<JOxmn!mkLF=&+VcAmhD2
zt_B4<2P4Ef*6Lcl>RRxi3AiwQ`Tzg_|0t~jkZMrN031y`poR)#2}2Eo4Ff1mYceJB
zGcqs)LHjuh39wF6d|D!S5;*}h&X${)oeCOT1CL)ohK&-CIyniDp+6KMP`dz>KR}%z
z(2N$i{SWePB7Dv>At4t$Po)<h4>c@4AwdURD}kn5u{Z@ZX{G=lYy!=d>cD1$6BV=|
zrfDfa25cb)LE0|G3W<3N2?-cI%!CARmj`5!0z@~YW&_Ql3d8%4(4fdn1x=}NL!Aop
z*DV3`&_aqga6+5Jz`zgzi!uiGA`l-X1A`(4ly$(7Qv@E~tzjr(Y-TD_DPdZ`3>xAs
zP%2?5VXa|kW^87Jw4ST@O4zd4YZxRMY8k^B@>IYBxnYoj+!9WZN=62R3dqoI30Dnc
z3R4PmGjlCd33mxk4O25y4P!H?C}XLzhmQ6p<|$x=5j2ES!KpI^8cd)Vg%)I>mIJsg
z51M#{22Q-6Chsk-%wllsAul<#C<l}ilR%9+7En*RC>X?KE-oo5@&d8gA%S0fi^Ds$
z5<F}IG7K_>9Up&-Jw3G~v81Hv7H>RAcYI<>VnIo2QPEn^kQ?(YZisIGqM+2mTWk;x
zsCf;VQAdxEPzDBuBv6EaI;;##T#QoSc{(0O4n_gc#1}{&C4xYuD}3%K1(bUjiepL`
zKr=_6$N-POgGSwbQa}OAlm(i*V_L{q<Ws_0!j{6)%v9u4!nS}NH0@B!oWfeeT*gr3
zQ^TCX3W~fMh6Nloj0-qH<MN=nz8VIQnZXR2?2zu!Eru!s{b2Cg1bv^(q@u*4N`2@2
zqSWBjqO#27)MBU{v>B*Z02*rp)q#mA0bnLyKoMv>yacMC$Q2Y|Tt%Rn$6M^ViOHaG
z(OXRU#kW|%18;1pkRd<zjKpGacyoYF%*jkD+6#&%w!{L^*gz3zE=7~&78_(Fu1F3f
z#|l<@ix*5m+T?j9=%Me+z`&3X3Vl!+#{g=jGjV`OMlMD!Mh->}CIQAGkQ$U20F}C+
zSO8}cP_(5mf)>}#VOqdY!vLBk1=q&6m<tM$K~tUq`Q@oa0nWGh!Hjs{#AMJyk>U){
zLWuNK@DhdG#N>?3yi_#TAx4W6i;^?yLCypfoeYdc=g=o*K+b{Z+8PE1&@>BE4nr<u
zEdwJ%4MQ_SEn^8&7IO-7Hd9eW4dViq6qbdI#T8X{C9KV$E*RSa_Js_fB(Q)Zg)N1B
zAyX}L3P%ZN4HGE(n;F3@PSDJ030DnsGh-UF7z1>Io4c|MlFuQzx(1YgxvGvp^KS`g
zlpoa11obi1i=m_R;2aDS)rBrCNJeQS7DGz#h=>RUXUJqi4ruvMW-+W7FHX!&RY)vW
zNJs#+EkRQ|SSNTui-AC+1DTMnWnOA(O0hz5er~ElMq+X{q~`F+%qy(`w?knwJdi>c
zT!?5g7L|d@3KvjS3QD4&`GJ?9@czZ9aEmd%iXSqfudAA(r<$UxT3iI`)@$<I;w-K#
zPR`Fu%S?wD04i4?37xCB1hjMs)cFG^uA&3r^jZq4Z9&8J1v#KGZ05|o5^zKp`GYbE
z3&fNFkXu0MyXY*4h1QG!P4_i}(g|p=iGd9?4IskE#K^`7B1IV4{&BGIFtafhfz(w=
zKpn0TlcKE|qX(vRHT1MJtK=cmA-Z58s0@?>D?q8u*%=rZ;N{T^aCwx%Sjtc=0iFj0
z(F`?=*-S+;pf(ApoC2*YsAZ~QDtZFuF)U=PWv*c^o&s8F0IFVUS!!5{CX_JOuq<Fn
zVP44C%vj5s!cxNo;elyZ=&T`I4QmQpHd9ee4O<F(HfwQD4QmQVHdE1r8nzV9Y}TR)
zAUjjIf*ER<k#sXJWXxtR-UAlnUdRYGksBmdbO5Bbgc&Tu3bMI`87vECXR{PN0LjD5
z)a0qU?VOmWker_a8K?xcE?{khlmx`=RZ(f4LOy8bGF2e~T1O#C+e1=1B*PRdloXYw
zDrBZ9q-LT{fn|b{x?g@?Dkw$gLzc9`vQRO2x-S*9um(C12g)~o;Is}Kr-#fUf+rWz
zQ$1v|tu!yQqEf*>IJFp(`u#${DY=SOwOCKJ7}Asj#dQ^np@E+9OHgS8W}3Kx+j^R;
zMW8NcktZlE3qukRw3LU;ixpi1C0IXDT4o22XMoynDYrOaAp%<GRp^_Te2X2_h5<3S
zKnxe~%-k)G6zE9fEyx@ll!sPg7L_wFFf0UR0ML>P26hQ17G^F+7Dg^+78VfA$0)%l
zz{vKW351zgm{^!a7=`{bF|jbqFoJks{V1s$l+i&LT-JjIT|sF!g>fNc78589r!Yw}
z)Pm9oGiWJt4RZ}s3X=^(2@9ynlfo>?uz(e`W@8~}VK8`*yUM{QKN+-+5L9Tvd(Yq^
zEFM%2CV-0}P=d)UDON~;%+`U&>Jt<o9B`ySx*ni<$ZsVZq{YGsT7!~Sl$e`(i!&`A
zx-6&25)|g3woOq8DBxM5I6)SJt-8exF%WF}EvCHUTP&ag2t7nW`p$zw6f{)AzyxZS
zaDWz2fW$FsMNs1r98#c838+n9!kER>%v2->UO@!P=?q{|=4PfM4M-Cbv}mV>p@glO
zso183J%zD`p_!?P5i~}q$yDV4$rTET3a}Yvkn`c;mJeQX0j^CF6_Cb@L5)Gs1Y2Hu
zm98szJ!xtRwCd48RtH|HirhQW<R}8orxt-?{1y+y2=J^)F}T5aixoU;Rs?F36=j1G
zI%h~_0c7TOB_m{L4y{BEV_;yo0}4J+69p7}kcI__ECR`4tb+kr4Guz3mktzI&5WR>
zST#%wL2LOKt6ZQ#k^qXV1O@PntO9t77SxwX0M95xIuYPhl>iEhqQuPNR0U7)dQ5O*
zR+9;Ac~LlM!h;#&a8S-HdIm}_XkGv*dJggexbeXR)`XHrK;rP22l*4>Z1Bhg<1bsN
zqd_GkvWs&Q3&61lbv8IYKx)!Tb8?_w%S|kRxi$ingqe_Bi{?;}{2L^Pg7~C`?@Goh
z8ziS9=3=2;IAq6aLt+5z=7a=D$qaL8Bq$hPg9tPyf+Rj7IT6Ii=+%S56O@69LFEmi
zSD(Vv!Vtv_8GnspflTj2K}YVQ*r1a;>?z#faXSv^xLqr#r3fl0K;t7I3}S;YIE{f4
z8>G`+W$lum3R(REoexwmMrn|N)@p!Oe1ivJL1`~VAs0GhYVQXwG*&WVOFp-FG7^j9
zVM@Ql{mxh=hcV@<hpZH%aKYwk^^gpBKM?8~#LDqR(2z4E6GL2B^bRvhAoJQV_x-}}
zKG38;Oes<ByA%nU5Qp_tvAGb`Edu3S(DX)9PGVlR0*IBIp9|{7Du8FwAq@lt1qGkf
zM9{hwa2-)nl$e<VS|(JUky(-op2-C@jX~ZmC`e6F04=&yNKH)60Gk0>GY&BgG%cc_
z0GZ57NKj5l05zk*xh}J)xCCrH#39KUiJ)Z=sYT%CMSgB(Nl9vo9-g2CuaJR-4`da<
zU!(w4!HjU^0EK8EDp>72AxRZA9V#R$z*h*^D=28>WM-!-BqTuB^y`6Fi-6XwYvS<&
zAKdw1<;+a5`98)f1x)9oDkjS5_CA@#;Q0=iUU1?lR>*`j5aAv`c0MSLq+}Kma=QS`
zNbnMul*}SFB-bn9aXr+0j6xk-j<a>GNKGy+0q?{BJ3R&3FoF31v_vT<Gc^S)2}zfr
z<(HZHd5J}pkdW78DtZF0JwfpYRst?SAOv`r3e>vbL~^|hrt3lL5FjlWKTS?Zg9tI%
z{vMRkKY)mjAmS5<0Ig>PH-jMdpq0$63=9n4K#3JJAj!eV!OX$T!3H9WKr*<?Xi!0o
zD5F73?qQ1>QdnCUqF6!Q=@y14wiJ#O&K8C!_7tuZ?iSEwJWmQQcru<Zm_d`js14M;
zG<M8`RW#rcKv4TPGbObcv}7%{7`zn)S~$ZCxniOsEd^SsB|^Fvpp`f94JIWSkXjA4
zwh7!GgbtvBii(6>$f~6T1@L0Oq*Sz_OX#Aegak<3u4DoY<UrOr@uHZC6zrflz9kCE
z{BRW@H-VCa08*^0V~qWQmv3U|Au0?q;b8z;=m1)_0^R|m3oa#)T9OHH<3Y|LKOl;}
zf)X8SD!V0&;^*R$qSVA(Q6wL$67VrZ2T}gbh5Hv&C*-BWDsWJp0V?gmv($Md#h}WE
zzJAWkOP3<e&zX7YL=~<&=#3bdr;%DMu;@j!TE1h6C~&I<rc@ruwQ`s-1ZuUwloI7k
z)anbSmDK7Bv|I=+PZfdIV=E!K7IXAm4`y9FxPl|fz3@5<rWaDS!%BQ&>nv;zj$>e8
zP(^aE5@ztiEQQr-xE4zM07c_Z5b+B{`~eZ5@F)V=ffP{SED0)sz=bX^$Z}Ap1vKl%
z!3u`V9L!)jj8Y%eUIrET#cR-K*VV!8az^kXEZD*;&>}4G(yM01D0XQ3oCDfE=S<;E
z;RDaFYozd}2(&Opai<8T2(>Uo@uUc+h_o<7@up~|h^I)jFh=pEXr)M|NVPCV@uz5~
zNT<lOFh&Wa$fn4(FhmKa=%mP}D6}v}38g5eD77#|38yHhsI)LdiKM8esI@ReiGs$f
zG<AzIK{bqvqe60iP7Y*ACMf5FmbsRtqO|mjL4#GrmC&7#8lV-~3dNbZnK_9?3ZRyP
zrXNcA1M2yK!Uf!+0Bw0lXQ*L_XUGJRj9`)pECSw!Q_4`JR>G3S3Yw*GVTk3cWvXFV
zzy_L&U}PxNf_6phor_XIV<gZ;yx;{Q;N~pIc95e%a|7V+VP<Nvf(CRIt}V>Tntqz>
zx7b15%*@o{TU;PUWjtvA(Ji(lFyj_ya$-(S5@`GvJa$ra5Zo96EfWSShA#Ih`U?_f
z1q&f1A5h8xZEgdtaEp)E0VN+$R~<B8&c?{b$i~D0##O?I6~KD1ZDlCA4HR&oQ8aMC
zfzl{soW2TlS_Wk7o(X*ZgBS}#2~(vGWR$&z5w>-#im!%o0W&1%ASYjxuvA7sRe=Vc
zm=?m-f=A_<s|>+YnV?ENpa`^W7Sf2zO$03{1#d$I)eXg|C6EC?kUHoPIB44*beyg@
zK3<az<bTi_(D?Ww7Dfh!Tii%v3*f0V@B*V-67i7b@}S6zhw2A)Yl=0QZ!st56yIVh
zF9sWc9=yCzjS#0<g2EUyG0wos#>fPk7GnY}Wa4AwVH9Ahl0Xh;h<y-kD5(@QatTkR
zY2Z=nbcSZeTBZ^P(4-@H43Dvf8MIJtAroi>8k{;=Yd}+;te}~&LM2eTbzz8=sAa2R
zt6|DwD`PCOs9{>bUc&~Kw*ZNO)PQD#TA6GZYCr=vOjUvKKz9P|9Z*O_4rxd?EfKcX
z4HP&Epm9Jwg`m{(B2dRp0hX*0kpfyyR18X+?4Y7Cr!2K71H@xaOi4kcXK?B*Vq|1s
z&}1*-07VjLq!m2!SHub8vJ|Bj7T;n84X71E##BJd#n57+h@Fvv!51F>?4Y4PK1L2k
z9%j%877w!kW0f*y_+!L3N>qT-J!pjqINgJWI6zBSKx16#44{G18ip)TphGqvvVbNL
znweY}Vuip(1#1lxXx4ZkXak%|3TR(DOX6Kd1_sBJ6z~r8k_-jVwmr}ifrJD-P}a>%
zEe4I4gQjUgsXH;R60@+&EP;2i6%rCaN>O(OXn+i=)KLg2Doxc)NC5S-OF_G5OY#*!
zict-OM|X05QBi7fL4F>%&ko%h4llYYAzkv4jMPeS_c}2pB{fA)K_LNb7sw8{L5Vr#
ziIv3)kh#uO@IE6{&!vLaYGkG<WR`%OmY4%-;8rRW6r~oY<{@QfjS$dmTxPLCQfhJ{
zXt#Sp0xWSQB!KsggW80N(4HuGf(^6~KUE<&zX()RB<8`Ll%JQJ3ip5lvTH!)GpKoq
zVm2a)C_p#lK>P$Z4?K6FfUHMP6D}Fz=BLS41X_1}i>o-b1X|uh68KS2Ef1OnF9I#i
zg_Ydklnh=e39jtH1gP8w=Lb+?ECv<43|ychgpaXG1mQkCcr5@@1{yE}W6+QsDBXh7
zENIFXmS(e<KpWYzL0O%#$`X`76f)BkphK^jkWmUObu75c1sdWnD9Q(I8`NYj`VaES
z84zI&8kJ=NFFA!|OtAaG1jrMh!WbG+p!MsZ%n5QH15=eal0V|XQ{IW0dBySZC|&`1
z1BAg|(E*o)S>WBiAg_SuG#E=6i!?wPt&Fiq12h9x!w4Re2YHey@d6_QgIi`ED8GTq
z4)|a^c-Ipsiy;;C;Q213E);m*S1Nq7Ij(>Kr5}(fkcEcOAObBG&4g_F0@qC7HNeH7
zG@n?kkdvR64jRVFEK$f!O)Y_hJ9Lf+qi_Z7;0LWUgeNf2tXzT~ctf5JDEdG%Z?FyV
z_}mC}8F)MnI>8Kb8fb|X^aKi!W59h6uocKI(NRc9fX<J>w(~$r7Vuzw3Zk?}4zs*`
z1$^$o5@xWGX}Dj(OD#b=DN~W`@Y7^LOMl=B9G0EHOWCkxr%enD3}v7M2+K|aOk9jr
z{7A_VR6b&i!Gn??2p5AY^>&7K#xy3-0*V%n8U_~z@CqR2L}5k-2FTzkxIlzWae!xh
ziXqh|bk;xtp7J0g@`$qBGfe>^1S%FmBlJ27;0;Q}puLdb24p3~T=4K4%s5c(1yTSH
zGUQ|qRtZX<NR3k+$ackY&?HNKUQVS#eqJhQV`>R#QAax5n56uY3<a1aiFqk7w}G~5
zf}NF`qM(tPhf<p;<QJu+7HJ|<14auH)Tl8AZ5#pZs;*&(H2^iO7cg`%EMx>N336eG
zm8oUwU`$~sWhmC_V60)v0xb>_sbLCZU}Pv1DP)504Ax{W0?nA*VgncY#o)nwP3Bun
zdIpeE2vn%9WGX_NCjys9oHpsHd8rizMRvWg)Bsv;F2pGGw@M!=HDGKK)U$zXI<V7&
zn*eTstc0w%N4HFrk%0kx$U#vQ0|P@F$SzPzf`OffiRoXJ3_hDs5+P{40x00XWgw`}
zf;6kkT*C~W)n%z+UI3ZZWdVuUFw`)BPC;162%Xnus$m8-S0J00s_e1N>w<Q(f-*j6
zRc|q3YL}R4-J*w}$u3rKB><lzF9r{r7Ci-364++yK%=HpK!JifS6d~D6flTkQ<S6x
z3Jp-GfV#ZJptZu8450G}vOvcu*nnz<8ip*!GR7jQLM{*sbS44lfCbRXjT(@+N(y5Q
zV+}JXl(Lv=m?as&$xEe>3*7r;uG#^~%cxli6h5HYj+9c!l4bCcPEd7-Etes(HE7NU
zoM9lj1C+TzITD;zKw}c+8JWo$;8GXV7A#hW92W#CMnL_=^3)>8Mgve$4Q_RTT8kh9
zkg_x)!-419{WO^&%?(f^1YA;TvOuDSr8qS;?-mQlq9Rbe4Nkof0-Q5A;^V=IK7I};
zUceniHWtw8GA1S_P(zx75xt`b+T0f(;+71G4RG6ofq?<kdjavm=@qoVy@t6+tcEd*
z0TLHAEGdkj<Do#S4@wz|RB9N(s}mR?YyUva>RMLN9yn0?&0+%c*=ksd!)h3_K;mp=
z3`Jp}cmkdAk;MiQwP65}HLPWfMHMxy3)n$CP%j5W*MNFHeKnvpgp66>z7b^AAV?l$
ziY9ZSI1{8v4s8cP4><xg4vJGtbQBVci}RB+kq&JF#Z4t@I|0!SRw&H_b&0^WwhpMi
zhc*Dg<KduqOGwZIl_H>x%Lxgf_9w(zL>&6(DWq0pmOyF^@RGEm{L+%lyi^^e=C%S#
zT1d@H0ht6c9-1uR<#=&wi8^R84x)RZpaE%omnRm3mR6%Rz%`+3azN<~;xbT*1y>X(
zRzmFo4|jmgQ->_nNdzr)2IUIyZWy>TK&=d9+rY<Tfo8x!!@ZEL#h}ap@&P!|OY?F-
za|j7Vso?cxwxG6Z0wRn&LEQ)SVn`@}n)a0n@KF*4*hW(1&3p+7#idE037Di*(8LsI
zHaH_c1@64^%$yw1=?EZ0keeDS8H=tmFfjOOa^B+1%qvbUDv8g}181&V9I#jfxAlua
zo8KUL3fwdXwe)Xs#e;(^J}<RglO3D`5p~loHi&s(^KY?$M|@a8q!A=P!W+=wuEJVS
zegtJv1|AkhA<&==_;efrCKe_hMlMDOuHr)~ITKS-lEJkNG*^PU0U$m&Q&up7j?DoL
zC4jpBDNL=*pyjlg47F^T47Kd(47D63jLi(SoS-$-B`gaWYq@F|ComS3)G#h!1ub%`
z<*wnb0cAvwLcJQ!1#C6kHLMGnio*)^YS<UB*KlWXEM%<Zso?=Ft((AD1lrQdi7sB;
zSHn}oUB+1SqlTsEM-4+QFKGQ{DMQgdh`yqAC7{Ba8#L^ZCs4u#9RT40)4VlIS-dse
zHM}*<H7qGCy(}yYwLCRon{61N`hV1Lf$U6ST*y?*SHf4rUBd_N7;r4$ui*h@e~A4P
z7>iVDxN5j18EW}U1VCcVObY~S_!lxZG1l-b5USzM5?%;eGRp`JCxIHq1tK*9U=swu
z)rw#ZSB;<~!vfJ7?kq8|ICqwC4QGv@4Z{S+LXQ;I8nzm48-_x?8V=AVw8V2P3=H6j
z)x?|}lm=9>0%*x6q|>ZXlnOdzBC{+tr&1H#PXPB%K(#Yy;H4O;0D{%p5OKuJmqKxB
zVQFe!aw@2BNJv0ha|9}RAdOQ<C%z22aR8L-Gt<B)sDWlhbzmJ}*gP82p#h-wKWO)D
zUUDkvD7Q3tUILv?2b)&KC;>5joCw>O4W8o%odA~yIeY}<7I0AuS`>s_6~hV&q#_99
z3-D_BoSf961aP+q?gY5QV3|BKuPi?sRycqc9e}zb&~wnh#TICI0pyLOR8T<y+T?{a
zngA^@k@g-VJI)$Z=0k@KAiF0N5)~2>kk@U20>23EDp;QfsoV`kE&M=zWAF(InR)4u
zf>1{R-0uRd7(wfmDWq0_wl8MpBSt?m5m5sgPeSr5WF;ne7aV959aQ*&M|{B3x!@8S
zBm^EAN-hD<q9`PlLY5|jA_pW{UIgmPLi?_I3JU(9-YBSV0geOEwh=_MfGQGLtbjrZ
z8XxeGfW=EmzCwNyeDw~@dZ-<sqztkc$s6DvEx4zdSb}IQWtJd?XaacOP%&tr3Ut~d
zbWsDy9Eb#{QI(VmI#dyIL?oy^R-B651BR|M1^F8`Fa_CQ0Xhl?HbezB3`LhhZepcE
zPJVv20(j;&A-57Vv}_IcGen22f>Lf}JeaMNprZh35<-sb0WWt21t_R`%FHWCEh;EV
z1?^=AuNNvPElSNnWS9H`P_rU22iXar%$ZkQlA4$TJ_84QbWce>$TaY*a!Ed@fs+b8
zE-?{&W@0fS43PpEl2%HJN)hMnAa}`&Kyys6@poZpt&N;;Lo~&2v4EyTZgIs2r51vZ
z`6#}{jhNplzQqk~DuEVY++r?HExE;9kY4~=LJK~DFdlSpWf6SL3EZ#+k0pcaWAKd8
zEv}^0;*xl97rO|wORWf04}(Vsioko1B|u}zY~X+{z6GLF^HRVS>@6PX@CbN8fu<0+
zw!X!K900eNQ}fEe&43cnkpo3V%Ao$84#-5#f};H7)Z*gQlv^wy7u*7!7y?U?x44Q@
z3n7tP4BnCp*$@pLp#Y6-gSXw?;)NX?Q36UJw*>N1%Rvlyaes>+O$5D}z|F|Oa2nK1
z04=&_kQM?h7-nQ)Vq@WAVq@ZB<X~cA;$Z|~E+#%k5k?l!h7m>{R?rwZ=;$}5e*!EV
z;D!VjBNr0~qX4rQBNsDhTMr)-7ju;mQquxDj*rsj2W=w&twjMhFF+gbp)(b%HLReH
zJtOGAJ8<IyTFINh&bg@NsNtw#G-s&g$m0Nw;)yfVa)A1->7ezuoFxn;tTmijY@l_v
zpaZ~bSX~%m7l4{0HC&RQ-rgioQv|dfB%QIAr%I@Xa{)&UPYp*6^FroY-f)II9~OoZ
z&dN)S47GfW3{@sIe2}WRhNWmjI71{u3S%u_9baKu9v_0o$WR!C;1#Ap)EF=rFu+~I
z+sp)Z4f_JF67B^&HM|SK696Ecg=vLRB@8v}&5X6|HS7?-*Ra>Hr9s9ci`ih~kvTb#
z(Xqr5a6Uw?L%<!%go2#X^vt~Y)VwmJs@}CCF}ENGR8l3Tr&?Jdx|yJY3B?Q@=%FJD
zwy-H2(D_1oX`oYtAVwE!z>6V}ZV*PQ-!&kLK*!jCvMpkO8>9}ErwnR`D?rp2Yv*Jp
zfjc{}(Rvh1auW+Qp!GJ`If*GLI;c$`bfZ%;iwklRE1|wYF|42{Gp|HL-5Gpn7O1`k
z?VnSJd0Z0_IG{c_a(EKgtbsNKAZG_7#&W@ZA(WtoC<Kj+L1!bNWr=#Rf)XTD5KH}(
z6!H;uKWr^RW@@n>_>kcQ&{|?}l!NO}SZ#^F9R?2**f=|AJP@`9J*QF^(ZWJ;HK<}p
zQ$W}Vs-E-m5!E}w^87sT_;NCMqB}()v9u&VH?ahCymC$@teXm2yND<w5)!~Co55WM
zId>Oi1Ehzgke>&y=0IJqlF9<8ak;69ptXgGB?_RkkU`U5u;ZAKnl#8$FAC6RghFw0
zVjk#_V$e7Zsz(tCApx~DlBiHzl9-p0SOhu_8FG?L5xgS_8leYIoF#$wav>_k1n~N!
zoHFE&BrNuzGxZ4yX*r4M3YmE+nV|g>#R}yasi1}t=ny(c+YlZyi6x+;O-euw5NNro
zke`!+IK&RT;wcfDxuC=S;A8HJ;Rn{i%>o5LehH{*hZ>cF)C2;zTA=Yz1f7mZR4~#l
zDJ{rJwNlUkclKfPBgF}z!3NNwMe(2m(-Jg6v4uPog{B%5vx(sK7O?giN(?AK+L)Pn
z3dp$-?rv~<6ExBVKF1kU9O@_}f+tBpyUr9qtyXX|2(_R<<T^;F31M75c)?)~`~YrP
z)tU^>X9@}6)0iM0gE$=2;(#pqRLD&%D9Fr1jDwfvfeICnn_zK(>N8OL2{d2>ZFNIV
z`~Y>iQc}Ug4WMBp*kK`{k`rt<#OdHu1dBlPsG-HBi8-(>gRu0B-fe)L_kiAgK<fb@
z_sifx;-|@5qylQGuoUMPl_0g6rh`UjLE{3DRuEreF><S;2-K(mpX~%bzqCjlq*?<s
z*2@oRAaOy8H&BUnivw166&ZqT;z)yLhFknlMbJ_aw8{mZvTpIB1ZR-}NGn%yMq)~S
zIjDjt(gQWJz-=Yaybfr0ZgGB2S!!xA_QP$Ft2cFK28LqL8L<p1984TcEQ~Bn9N@uB
z4kj)p0VWP69wyMyBtlGlpl!5Fe9S7$0*nI8984UH9H`Ti$fjZpM1uySL0c4yK?l)*
z&TuGU1dXgLWCRUFgBNBn*Dx#q4Zt%pG877d7g{hT?qg(Na0MR}2T2Sl!GJVLgxms6
zfXux^4hKw4K`PczRl%3OLbnltI?#y<8U^{q#hFPtmAZN0sY*@w@BloSfXb-U{4^c#
zs*cPw@R`}5P7<o)K(j&6-WcK}6ws-i&@*vB$sAI`D1awtAbAXVECSO^a1j8>$DpDx
z2~pg_n$h5u1Zkx?Y2f-IBNe%iQ)~^c@`_S(Qp-U7F*Nrg4WVb|CFhi;q^9VAs+T-y
zd0MFeE_|RJdswp!d`3RF8iO^UK!cr#F-T2jNcI3NZUN^W=qP&;=xB^vY!J^t2K>N-
zd0+xGh6i4AR1Hd;;E701Q1atpLTh4!&zC`&1_Grs&^#o#i4C4VV+76XmoXIaftI3y
z*r0VO;PEG>VkL-}3qvdq=uBzQK4?aULN$=6CR0_jCwL4*Apuk!gVvToHeq3m&LEN)
zXm%33za2gZ0bk3e2{|hQ6zw46Ktl;2gJ7z`6O5o?bcOQNoE${>`Drp0F@SP6sE-B>
zyIUL}6F?5S#R1cgEeLOM!iRIaK>-O`63M^@+BC_-2s*xs19h1MTruvo1)$aVpdbVX
z7!#-`0&3wGvLPlM8NsfF%`$_FBv+90!SM<vz>zD@$iOfY<R(yjF)(s5qD*KZMubty
z5zyWRP$>+KTi7y(6owQA(BZ?NX%o;H;owOTriGws6c(6V8VmH4G)-1WHyAwUV+ty#
z!Q;^20LF5V4)}oRxgckPtYu)5VdVLTwju*@N;pcWfz*S%26ifFd1(z}3=8Ps@>-T!
z)*2?5!$7MlYnVa(pBjdErWzI~i@AmsNd*fcbfL}%yBzEXxbrpHAaxCUYJ7HlQhYMR
zpNgQMhpR#F41-Gj#US5-=N1`x82La2KO>qC5oe2QGWvlKvtNjtCX1h+o1Z4LpI?Y3
zV~D00`eqH#X7wUwP&LI3K9mL0q$=V9xd*iV47_TmNC?CQEjR$r{X#c#fW$xxe<0-s
z=+Gc=QBdR#k^rR}aI6%89FOE7MA8B+iq!;l@j+*$gH`}@@iH-T2{SQriE{9Buy6=)
z@o{i)2y)3WFf#n-ie>oE6#^Dx;a~#~kAS92q0<2n3RIkcqOcg`DU^L7ki!`nqgcRm
zWNbyMj0_A_cHoM_H?aV+RST)o0hQUHLLD-)0<F<fa})DGM;L=f;y{IiA4YKonk59e
zp%}CQx*c>y3}XrtXki6tNk9toLZ%v~0;v=haqvQmTILRhEJhxN0)rAJP;mx2hO=rn
z*hwJMT|spXXd!Mc<iZN@qNSqLLWRV1(7K`$h?~I<1iKHeF$LM3a8c-f1h>STV(<=k
zkncdIWq`-sAa;NU9@7#ta}b?F=wYy#`FVQCW1&Uh1~+&~9-;t5DFHx>qCmj`UL65C
zGNFbcR;-q>g8{VMDTSeiF_Up2BY2vc2~vjNVg>ufZza<$Hi&a>aX@WP)nqCHjlmRw
zjyqb(2pMleBqK3K28JD=%mK>AEKE%QtF#b9a(WQ6iov68xE4G>j?-s`4959@@&a>W
zUL~{)hgb(57vlyyF&^ZsVn~Yi10{8EISD$LZUe{_;7X8#i%IAo8%vcq4wry(Co9&h
z2r>s^HrR(?0&D>&$*u-j0P-dWBMS>S5#!DSpxZN0@&HpROEW_%YZ_!1D`ONJbQde)
zh*Bx=I(fz@PUt#$F6cUW?iA@1ffT_O#weZ?nG~TE;TFay-V~7((H4d%z7(+(@fL<C
ze#m8VQ3Bu`CJSzpSD6N<f=*8XcQ=aj5(|nm^1<8hP#ZM)pbLzO!79P41^kjhUW8<6
z1_lrtl&Qc4v;z3932<S|RKpO@Si=l1ju{p(gATR;-M$C9QzB83nSmh~W*@3$h|vRd
zYY~kDM~ro<kPcsdo<ah|o#2Cyq3u`D+EE4Q3e!}?Db$FJfvN}6VFvYT6X7jZP%jf@
z5CF8K0dzZ(XBy~aKX@)ijA5XvE(Q<vBlV6GV5d_+rU>#B;6v%43F^Fb^cFE_w-v|{
zpke{06>clIF$)vLabgU7mJW90MGoX58}O(M+$2Ja319~ez$^pJgB5`9<AM4EZW6kG
z@)C2QT~qM&PDMyZ=;o&>K=1U?NYzW%Q%FcqH`X&#Pe{;2%v)rZC_qQ+!DD@(V1T&=
z+BHB5+{pY=@H`08k^P`!G?BtwBQY;UKfg#J0qS^7Q2Kz)jDcF|mHDM`uasvNXMp5E
z`|-6Bb8@s$#|3miDL^3$bk=`KMt(8q_Ak)oO5n>Dz~c$X-Erup0}8MJ1a+05o`?Gb
zRJ(w%pC;&@AW-heO)P*Mj>86V?=2S4;1jg`yTy%^<iW~{f<UDnxMTto;Nl6?gg68$
zp1|dwFnBixW0eTf2rObF2B>m?Wp7Z{24Qga2GyIORx4<ty+E#pF^dtw0*PmX&;7^;
z)tHP~%%BEjGk6@j>ZvE%hI#OSP6BxEW&vbG8Z?ep0$PKOlt-b*zkosmG^Pp)3)qkm
zBte6xUO=;Fh!6#J7a_p}JER#NlSnOyVrUKn?Zt)O^ORYvfMhlJ)K2ISB={HuaMcVq
z3g=2uP}qYm*#aHb1-j(|d}<0fT9BLaw>S$b;~`lQsWJgY)GhYp#5_>5{T3*)Kyw@n
z99)bX|CyM${xY#v2_r`sR3%D#85DQ$_yQf=1&S9?Oi6+U1;FzLkP5v@DJV5JzbqBD
z9vi%}6O^%#0s*wND-e{JK&!VvXV8E&6bXVvz$pt%fLvV!IyUbG$i*Q08JMbsklk4X
zwg|<Upjrde{s1Q{Pzw~am!XuQ2z*IYEn^KMWNjwsf}ds(o39o$s=-{t4C-$d$`uMh
zJdv2f$iNT`y44M}5C<hD<kSKxfWfsKc*GnvrU}<8prLl~(i%`PfEGjpP>m=k_=6VG
zqWTYXnpS=hq>#;rCsUAPVP%azYOVkksNg#a6H638+qJ+4k|%;DbRok&plTE0InW|#
z@F88G?O;WSJq3`JenlamBq0SNz#Ua^x&Ra4#1YKM!0-l?IKbT_4#*xb9>yvG<U|50
z(om8JC>4W}2{?&>Q!@DCBhXeC@I7MSwR*t}nv98{jXcl>bRu-HTDK%$7c{V4Tml~^
zMh!1e3IUx*1zI}>o`gl3^$IOcEmlZQEKUV2x&U2PQv$kS4OKPdPMxC6V$jq=VsUXP
zIOstG5y<5|bPN*hxDZfk1nn6~1>M#N+2f#I3|a7yoS#>gS_GPK2aWXR<iKMx2Xs&#
z$W5Smf|3l7*6h?uq*@PjCm>i+5je+!Caz&64royGmH@K<<FivM(F-1K@J(HymQ8&8
zZ%}N30-u3{gRx2+Ii8SI;f^lQB3aPbB&gL_<WU1&ZC&I6+r5;<0$yebzOt)~vB;x_
z33L<`C})GWiLo!>039L)I{&g4aX6F@Xd4r>+Q>`;O>HD3Knp<d61&V2aQ`S1bb2e~
zyk*z`TT*Ij9%#xi6|n&C7U<B#jO5&ckd;i}WptpU<v=xXD(Jj~a8MV68?<v7B$Sz-
z2MJQdnmf=CQW5CP;#(Y`lgATF@{4Y9fzDt|Pb~r6(+FLl4bBUo16$F88a#Z*#=^i*
z49*bDLW}~8prPU_e&m2oOi4jq=n5JN0oC5%3<1i5ReUv|V-*<}GS;#}cR4avYC(57
zvJ@*dfhL?;p=S@WrhvAtSk$lvgAQV3%whshXp7Xc*09zvmN67L)vz)#Ffs%)6gt&_
z+v}hu+~C&w4kqX%GI9!104+Q~9XN(8;w~))7qp<ZIMU23QtkrJ41vboARAF2d&)G5
zQVT)5#~{NSu%>PTvI(HVw>TBtJ4PH~UtF3AX+EI14RrD>bfXt|JQuWN46?xsv_1yB
zm<gV-u<kTT1D)egng=%>nhs#@f@W**NHfG9xN#8sU~9(UYjYJ)yrQS6px~LNkf;E+
z0NMF)voedpYgj=8@Trg;KA`ns8Tl#DL;fKF2)cx-xCEt93bh_?5K@&69*h95?}O+@
zU#AC}G%HFi1nu|%cW&TLgd2wJR8R<j`(B_$u_+2@^PPz9Pzm%ZP0&nPX%4852{#Uu
z5@1~eBzJ;W5kuBxfzpN!WTp$W-VQ05K<BRDW<kb1kXO`#>MiiNSUzZs64H!;m<k=|
zgA5;l4!Z@<BSBW#fHN+*{sI%=N=%!Pfq@^CXF)@^41A#bB0+<{OyILnSr|d<)w!6e
z#E^3^D2qT=2cZl_fhsmoGYOoJLA!jwi&Pkk1R%q}!LXyA?=dnk_(N8vp)FkoH+w;W
zhP)IrK>^Z#D$7h%NXah;Pb4BON<cLUbQf=82_*lf!lzY0D>|{60_r7#rpXc0B;X5Z
z5)zPn3)&?Kx-|xxP@#*+Asr(~ydZ|H5)cUm6uGcfN1C9`sIaBjs8i>V4N94L(8X$?
ziVz;_AURM%gxCU}M*%ND1J4m<7Q^xks8CSI0IiJ!cbLI9z7;DJmnMP7RZ|hJ1J%6H
zX>!OsFnEV)ej0R{ASm3?;v*?F4YUgsGzAHg1x+ZxT?ZX`K=>FmERkLc3To(aQP67o
z7VHKMkQ5{_f>R%u04G7vQOMe$BnYmVIXM_no7s?bjWNszN^YQGsAACdoS@zSXlxw3
zX_&Ewp@vbCp@^#nGSmk?H(!&f$`-O81=M&f&C4t-g>O9pw^6`L1VD0#p&H~Op%^sL
z0&aqU#>`hjw`ziN9(pY(&B(xD4)PADVq*aB_`v9pf;W7iv@<|{hxZ&nrv!qQewBdE
z;1&bVdxE<-c{X5C&{2vmu)YN7ut{*82kA?|W=IVRRr2^sSU_8J(ip`UnnCNZK^Lwt
zRT+8a>4LWdfEo|boA^M5HnML)9eAWtt4i8A5nN`cq$sEsfod!yNljMB0gBn6q6j=N
z589eu1iBm=)|Y1mCphpapP+_m5tf1obi6<&Xd`aCEhy~3yJnamYw|%0>I9fTdv=lX
zC8%2uR*pLqwV)ea(?KUAGo~>0GJ_h~HH>MXz2%_!Jf<3EbB0=`LJ9C}GINy)s4bS5
zhtglpFG8(?K)DD-1t?vB&aws%Ppo7t0<8sr`nxC<)Z${!ODzY_$fG5cTkP?m4sm?E
zC&<H~77zmy==g6gM%3;wR269KmdVczL<wRY!Uf&^cZ(w+GTztG%RdM_xl#mb@_{?C
zMWD_~Q8cJ41CAn4v0ntrctxP(T9giw$N~}IY>6Pi859(s`$0`-(1<z*BMUPdBhx=F
z2@XCE7A}4cZVoPn|6DR$JREEsJm3LXP_~2(w18>Q#2k2r1Qe~Pqr;$cvx|xt7#I>k
zoh?V`C0~%cAwk1w;IZ%I5>WXAIx+!rgFU2g3mQ8~%Lm<X36?D>0S}^pj?OAdRY2ro
z@CX37*v(5$h30ZlR~fd%8@l`tdgK+nfCHHhS^!j9l$;8>4IXrhAEcE5ZfJpSra?9Z
z;w12`fZ$PD6m!7U3T&BLC3H>&;uX-vp`a7@Kx@sxdh&}h(=+oDbK=2kT);xGfg<>-
zbV#cKv_1x0=7V?kry!XG%Auec6|inRmpOpKJrtDsK=n2UBRC!~A`ev1f+Md5{Qw-M
zC>HP$IG`iXzz5(&u|Y1C!E^Kt=-?X$q=Rqd!2|k?QM{?pA^m31kv9@4k}V8T0x41{
z(%=Jc6u?K{fDXI?4ZJB9Wq}U1QHLBu25NlegJTJnRzO4Sd7wLolCu-jQ;Ypj>JCs^
z1bG+SOaXONz~|L~Z{>ze$S~gG0Y_s>Jm`EftaoF9Ggl@o;9!@+f!qLbQW2<h$^%_0
zj?qE_g(lc)KFB=_jNr3gnIMOzR>{E+vjPo`gBrx}RFYX-Vz0>rIfoW>&JlFG>@6|q
z@o@3^MJS7ou$*vJ6wkoGkOOx%Q<XgEE<0pr!xDTvc-cTPiLTc{Iie9}7O2kwHV%|a
z;h6yL7w~aSxu``CxYPkj6o4EHsYf{&nf_PF;dC(MWGhhUf=e6*1_lrtRI7qR8&vRs
z>P~QIGr&*QHGz+>fY0CtM>zPV1MrLxIHMx^Ixr8xVgY>k6gHQ~g0{#byPV~Jl_E};
zgDeHbHb!6*a=azn@u0&$z}-`jSs16=;r0Re<ScAHhyhidXg<K5SfD4=fdZVAz*mL3
zAJcuH!64A8Qqc9ju+aVmYF=P-YcvA`LlY@(1)VI1?p6>VoKUc4OGEHJGf?9Yv^Y2w
zdV(H^4~jUXYzj}_Fjs@lcq+o?YLG++va6Z?S1I63BcQe8DVaqm1sSNd2*O}zLt2cW
zCNSvs2Jkj+rUJ1NX7Ei9EDKmum=-cFU|Yyg%Ur@<!<@wdz9Epa8GJ)vGh;1F4MPn}
zJXZ}<4NE+C4Py;UJWmZv6C>obohnmz&_E%mVFX%nsF0gl48BkrG}c&9l%JH7np+I7
zeDc!4M=WX-Yl3%CCxXr+1y@6$N(_V{ElFrm4O0uMuu{|06~F~Aq$&le1z}J<jHu<o
zl_H{bP@a*Qld4cs1X*L34|4^~SQLw)Jr?M^6x=pw^$)TNf~)g$QsPr9l4~*Dfvy*^
zARW|EgHGM$RDxExDU{@6nhf?HxOsqPctC1VMq)v+LS=qw5oq=(zcjA|d~FkW77o0L
z416>cNDj247wnfz(Bu<zUAH}oS3y&SpxJ}ujKsWj@Q^GdWRcvP1a>93T?I<V0g)jd
z{(kYGD|MY6ojqJpj6-VdE0iS`WrB;El6=TH8lb34%!4`%JUs}{1c-5VP{@K-&w|F<
zL2J^I!Rv-^@k5hACiK?jqIA%qRve()8_SCl3vRKcq^6|ifv%|p%^w$l+b2bfKn1~K
z5b+J9nhO!AxA;&SPnyuP6xg9LT2umRkF%8I7UbMwPAw`zZ;%ThIR~83`al^JRCO>g
z^Dy!-@d=25PJ3fyW5mp==vu*MqZH|&yb5aNgYzroII=8;0xs|#VP?=xEm<rz-~;o-
z8Pb_*m=-YxG4wIivQ+Vuu-34EmeGYX<VmqGl(1F$K*vHEKwEYg8K5Jfplf`<^GGS+
zox(LNHVieO3kaAK*D--E*8&{?qmY;czD+k(0k-cNG^Pd)L2zZ409rSZSq8Zb8Zz*i
z04m~;_sN1XWI-bMu6KA$E98T2cTWX1#Y%I)i3+?05;~Bj0G)6IO+kaEyz`MpB|sZa
zU?bY#Rsv}99n}?xr3;{x3T{h->N$|Rp!UL3YieF{PJS_{p#jR@8jvl3putg)HA#@1
zfTT|Wp}s1!0A#2l(lSiQDp!zUpi`Ta^itE)l|Us7XzB#CG6`~+3uuvlW*TU}KKODA
zluagZcOfs^1&0jS5e1+tVHA`~^HNfal)%%ysp;wJh_W<44<1cOGa}%DX6S%2G-$w^
zX_8VEK!c8{pkt0e5dmovL(dZ~0u75MmVkFgE0iE+(jbE?kR}@V4rb6j%doTo8T|ws
z4l3(GZUz~XTB!iqLYW6zOAPlRH2s5DsAiTZfXvDUD^>s<6H^2}_yJ-7$SCL{>Qn{j
zE$a$7i6yB;i1MO}MYklk09=D;aupSTT8E&b0eou?_~^zW&{PcQu)#{ue#Ur=%fdNb
zVcol;N>HYki7!tq%8M_}LtID>zM>pl7#HP$j?9A=7Cgv_?-ncA&9``<-UBPY#a)tE
z1Ul3g6qDe54k19T)?0ia32=r2t6c>uK|rSlF!1t#uleEuEu&=O0-c$J(U?Wmic;Bw
z+9&Y#Af&Pfty0KlDv|>Y50x-vflshm$XF}~s<cZ$=hiSRWQ3f$S;CUV=D<*FSHoDs
zlEv=8P!yEHQo|qyx&(@20cQ<U2^aWO8_>~utcjqtW$;+_gk)>zA{9{LhxSz=?c>a1
zh5WMAqN2={6wq8$UJA741EnX>!3@czNQ=f1sj9d%IRn(h(=W*_0Pk(jFG$TRRwyk1
z>B}zw-SJqOmstYoD1+*jl9I&a>{QUe6WnFc&9NXI(6|8|fDdX7fLEs^<|&lsC6<<C
z<QIYOqb^9S1nof4Qvls*4$f+&#i@ubWSO7=u<X42@;p%28gyg;atR5Z*hJn16r7r>
z0N;zAs-SFaZVE0w!H4Fhq?UjdGa?f6EhbPERu0<7RODB6S`~bs6{tD~*P}_53g8Po
z^uc3fpi2T%6v|3-@=}Yy(k1x{iD2)8c0c8T7hHk2_$z=C3#>;1?x})Os-A*#eqM1V
zXy;QR<OsiFG|y;&)(nAzNUu1x1hSzPkrP1UexO1Yy*Yp~BnE2&XzFQlLvkeeV4};Q
z+L#^MR=CAdT#{IFiygF&I6o!z7JG2KXSjce2ZZ4s6mW|Jlp!<o(u;4gfLOP<LyJ?3
zK(UjVm#)bS&g8dPazT2TbBog<ISf251<GbcHH-`lhv9jPONs?_*|G=|6ARNHrvFUr
zRXXTRX?*z~rJ4riG7tt=)1W27B@ED<rd0x6YXZt^P7Eo`4xr{VD5o)kCKVYOAm>6Q
znlLdi1f&*$u0I3sx`M4#K&)Xa$S*E|ZgvJ$FZpQ-384LJpcq7-QOpEydn-y+0NqoT
zkqWv_P@xEZPAL5D^_2X)RBOnYWbidZ#R@6;dFqI*h~Q>qVqRrQ2FOxyuPZSJlou*t
zJ2_MGk?I*(2*RqiqGFgbP&K1a0$S7rt%m&ld?FPR(@Ii{6pBleL3_ACyO=8BnH8Et
zLDnXMR~Qt5w|T>BDe#m=Y9(axlb?SGxFQ1`Zjhe`SA#T>k&##eS<C^Mqy#l#K#3Mq
ze?yMANAd+CU_niEkTPg9T|omB<oQL3MU|T12>@tY0^E0i)O-mb6CsfTYQTap^ms>*
zAjo~N22N2bNCZ?Nf{wWW+XCL*4h<A=SV5<b;DJ&EUd@bjBEl`!g8bslicC;<G4nq^
z=)fFSr2N$iss-CXl^JVtMs9uzbddQL2gn~F>u+(u+*{NGQVY&4U;>n7ZgC@}y1SsP
z10Gl5=VB6JtdfRBHf;O~NiE6%J80w#gu%H3G-U{yc`4#6VN78JPcblp7RG|t;xZ>*
z0xgG41)qkX0B*H`>Pt{DR+Nf}RrtnJXc_?@+XCLU3)%XE6qTN7p#G6UN<O$#gh+(Y
zfK`A_SAjM<LJiBz&ns3a0pA-7x?c}8hliN!1G@%Vv%!~N7J(xLy5kCzFB3rJEL0Wb
zs!7nY3_S$}jd0MBWANAn9kH4SIv^Hy>stbP8JYmPxv4C(C_fK069(@{=|GBeP@$S%
zib&*`g$8IE4m1S^TA&N6fWSk)P``s#;^ZfTXWtURYn?!iEKqF(cOR@)LYg{-#X00q
z3TTjl!yhz#2y5Ge&QAlk?lX%al|CpcQxr-IkaiM-cDELRHZ$kvL2nU;?DoZe-L0O2
z0;q!uYL<g4BXH&bRdaB+f)X@1V<P&iI-oOCKxI`PI1PaJ=7Cc{LISi284s%ri$M{D
z+{R5w%}Iq`UV`u>D64>r);v%t30g@Jk^w!XG%sHvy)>~XF|Q;Q)MH3Ql%TjQgB1g?
z8XK}Q5WJfX%|@i;tl^hml4=F<PGTh_O(Xj2P<^20I5?q#A~X>ixG<l>0}MKMp#VCf
z7b$Cj3w-c0A*gAf9edD;=*s+3g*5QxKcHZQn}oxMNGJ1FnL<WzpkoVAlVR@E0T-X3
z!!|)<l9jL)V`>U$%_XRr4ZhhD+@gogp@Ns*fr}|H0V=DCQW+Q+K7z_9&;UJyFz5(y
zrvEG~Rm!k53oECvv|-#Z3M|l&Ke)gG)$7m|mQG9z3~*n&KvD>3nH$tUsYru*kfZ`y
zfQytTbfAk>AaxpOd=73JIJcyN0|LBu3#O|QT+M(wMTsQ}$?)SAl2TDBO$A8eK{^%&
z+~I>?I1M@j4xCuPu?s5flJoN*by{*IsID%7ob<1wP@E5{q99#FxZ@zbG0-+?aK8@G
zX@o8pPK8AoEJi`qW}*T-OTrC8_$sv`Ij6K3G(-r>#R{PAcMf=N9n=s2SM4aP6_8Iy
zKs^KjloC@@tRYzfwDKGz0P+LUlK1=~_{nr28PGl=#34-y35g}3Q~y9$YM17Lo3)@Z
z2T)pvEq90X6yg2Od{Dz5pXb157l1M!G+}_M6hzbB58N)*gscX*#hR91l#G6(ZxLvy
zhnp2~rxeCa07e0($p|r)(M?kr>r^keLkwE_4xZ5g-vCksnsg`vjoTN22E-v3V1T;5
zMU9{)0}rS<o|z13uYp_7MUy~n1W-l;yAW(65&_PJplP;LP&Nc@fB{{S%)-RM%)!FJ
z28S|Sl1z+Tk{lu&Qs7BBth0yUya#G5fSS?^m_Vx_L1WWdEa0_}pxc94s(Qc)3pyhJ
zYCt6rTY-W#f^V#V*O~Aw%%DylV(1gxM+5aI3ktxRK#isp1trL+uC8l(da)8DYHtak
zSKd|JNUAg$Z?Pv96o9mALR)AppuhwzPAw7yb%Xdo7DJi~prc=q!WB`*fd(`rLFoeA
z4rAwG<oX95|3vBcgNiQDz#%vYA#)Q8K*#7Y)i5js_1BrJ`kf(bYe7BX#G<6k5>Sg4
zwq+fXAz`O;pser!xgIjY?U+}oP*j=+o*D-o&6=1~kdc^InwwgbnXIp;0KXCr(oTSO
zyi*{}mPA-~SJzdCgxxQ`=r~8+s6^c=16@nKSnXeox|&S4n2J(wF&CF6VY`m6s04H&
z3@9W(ElUPgFdrin;6taND`%^ON*F-*j6yD_Z)SvEOwE|Zl*Ll%1Row{1syTHkg1jd
zbo)7Isu~n(u*)=3SV6}KRyl!_0`Y+eTQdn7k%pddQFH+`8tn=qW`feeEJje<oug<o
zNCY(a1HPTSNFKxm<s|TFl|{2bO6Pz^o){tW;G_X2z?rX<fq_966e{34kcEi}w4RoS
zu?QrN5jyZR0<sQrvN32Fcp)=r%QI+=Mb$>)y{HZ@>(s&372za8Yyyc_hwN|%RivN{
zUX)r4S~Ce+zXrMN0KCi_v;+=X_f_#DrzG82?V^jILo=8WAy*U$2|mycO{6>q4!$Y|
z1_nz|@G*hrB-x5Ue2icNH3-023$!Bzw6YtLV88)Z0}n7ztqNMV1R5QIML#I}fTlh`
zL&Km30*J4hTAZ8+zKAiuC>IfM>bmOaVFanKOTeeVf!AU|vy*x}G#3?t(h%6cMKYjt
zg5?&=qG|>P1}C@=S;2f1AA)=iN<3g6x`CEV@IbC<1>Z4a!opC(Sn0sXP|L{3P$dIe
zDHhKJCYfs(!x=!?B!#h-v5qkqwBDMrjuCWt7o=-f1sOmNOU%hk0c{orP1t}2^b!>U
zTmuwL4J=T`iy(Vpt)UGjP&ox($O6uLpo4Go%0Om;0vNm@2{MuaI<OB?sQ9^QvJ};V
zN>=XR%Dj@q3h<S-MH4|)8yo0~%e;I|rduo^cidvcsDW!37#O@j0mTPO3am_^Az1K4
zjuc}NNDigJ2uc$0Km(03SBXKYE$}_%Of^iP6T+e84MP@V7E7fYBSS4SBSV!)2`gwv
zbrU1>+%x7n<~*(x##-h&W^mAfDmtdBn_xe~_gUi$GKk-ybz-7IQht68=v*hzKw@$t
zc$Ni}k08MdYW9P(6KFvzXkilime3&Zg}_Lm2WlBX^=5+3N(09Lw0{C_a%O_gNCWj%
z6Tw}|QqcAhkcH|6m7qJ3GxO5b6>{@aN^?>n4h7xV0V;k#mjQy$8ob5k3*JRu<O_-?
zUQb9QL&fHTvMx)}d{F8J=U>nc=%NK6F1QQ?6EdJ86BO?epy&fd3j+rz`nVW{7{TcQ
zYkLE{TIm3`)k;iJtSL-UY@n(Dd@&<r)e;AE)e<LoBQir27jz>sH*_O15BRz+(Dhu9
z>$>=$*LCryh^B~v*C~N6?E+oQ1-i0}Axa2*VHfCHF35#lBH-(~K-Y39g0JfmgI?Dq
zo&ve9OCnV=MLk8Mg`t@-N-9M&MXQA&N*bKgw2OK`+153rs1jV*z+wax+u->f$apdA
z5>QA32i^z(WkzEIBk*}psYS)8cX)vc2T;ocTsVMEBLXdtNnuQ3Xa;R=W&}-0E?@zR
zF{Lm!GcN><?687Pn$TqNE7}0ciX8Faap(B>qCKE;nXPC$D7JQk2vFcdhH%+aGK)ZE
z<1KDTQUTA3z`B0BKx)Ae4JN>`4Qkfrfnpn!5g8cy7^_76N^^1oit<78Yj{>xfz*RN
z1Ip!~vK(~c2V|uWWMLQ6E#~;NyrN}{3=Gi4Q$?T|<RWY<rNC=@K&}7<69Z$F5{er@
zV?wY_I5-SIK13Ns2F=&NLl=}OKy@-`rUtZJcOiJW7sOG_x0o{XZ?QX7mZTPY`WJy$
zxva#J2|!DAN|79-fZIVhmgB&k174fYumE(q0qE=-CQulG)}O%~!~(ijzGwx=5umUt
z!sZ;1J1dBG4rs*<I3PjgF9QPuh>hDhjHuzm5}%P+jBpMt?O=;F(7L#4Bv(nI1QKZH
z6D-zHihPiBu%{kI&<*U6aA5*F;TA_~dOCRV0?ZxYxesvi1rwk&d`l=EltN&+5}f4g
zkenrt;w((HD2@ZABoGECZBXkGG~!y!10sVVQ3%>71-erY6p@UugKU_K)`KE&BZydw
zl;Xk8#Wv&ux<0oN<Va9Mn*mfkg61eOLlEXG6i0%ZpP<qi?8q|E;xUFShGH(zSW6A~
zq9O1(UZCj{riF~P%q7fOEJYeM%)ty*JT=Ua)k)AQm94UXk)f7_k)cYZhJ}S8i#>&T
z0S6@0m@_aj#IrXsfU8%AT9!JNJgyWl4X$26tJ_)pz-7@d*3yzRU5hGl(9}S6Ep#ZR
z1U!CerBGd~$%zy?Yd}E+ivC;70g*<aH7CiSStp^;yi5?oB^5-1+Z&**!imNCdEg}|
z(8VR-D^nmv9cx))PHE~b=G2O0^u{RYTH+2+;DR=Mf&v$O9|R*CBMT#_I^$y&W2{0A
zYUBij64V%p71X4I99adrMhBc&S27iW&fzEmSzELL<UerQ1QVbHS_HZwc{<2FAk!Ea
zt58!Uvfa=dy20wm$-QilJ4eBp2VC?Pt;6CT&|1$~NbZqF$sw>z3o!~KG~gu(==>c}
zzQ~sVCpu7aW5{BtK`l=pF~1w+2yhXHEqFk8N6*FS99Rw@<Q$B07S$oQIAFJ%5(pg7
zQo#jCu93waIG`~|&>BIUQ3YDP4+@?lDQv-$&VW{Q?7<sEpqsT9gB%44eNc)PVXQ)R
z7(AF@4g-~9&?LkFDl9;S2Drcgb)P{U4{-+Yc6bKRcKBkA62=s!EGF<mMP}GS#U@73
zsm36A&=m?PERcH}7qF(VLfN33MH#Z#LG!WTEuc&(Y&Hxf99f(TxN2AzG8XlfaM!Rl
zGcMp+$WY5x!dt^u!<xe0%v{S}!dJsy!&Jl6%*@D;X9v2uJBL44pq7J?p+pe0{3?Z`
zhGl_J3d=&q8rC$H8jc!P8-^0z8WyO2&Jw;FPMCghD~ZdmiUV|ZWkE@?ew9sda#3bM
zi9$6*M6swAJcJA0V+bmvU}2?@2vU=plcoo&W)zERtC)DXZZUHGV&pAa0%}OJq*kOR
z!%hij1+O*H6fOdl-;hHl5ewwN`Tr`Ykp)ib;2HtmG%Gp;k^pslZ?S*|>u<3q=jRq=
z=A;(w2id|2>Q;dbFFF9?Gv}n{6@i*onq1(M#31()eE~HD*&x2U#SNk3!QC)^C<oR#
zzQtAyZn55C0hOl^GhrIQBH+>qOn{3h(8We8KnV=gHe~>BBxYjdU}X8v@}Gr82;7AO
zZ482}r{Q4|`p?14!&oJbnm0=G;vvq!C^SI11f2Ll0Z_sKnZ5)?+)5_DDoe-|M*(ya
zA3Q?^*%1vI6$gz5m*yeej{;g*0$QC?S&+Jt@s_Y(eu*cnp`Mxot~rV(gEAA?b6^7O
zLr}H6ALK(w7GeS|a2G^zKd9wHyvvJDgDg1%BCuHpD)Nq?StpEY9b^$bC}?2$6vPH$
ztU*P<LQny663s%iwmi0?0aQ%Diw4LkehWY=_8A!&YM6>NK*N4n%r%VZj5SOPSU_XR
zkd>0b4B#7Ynf!h+>T9yz5|0P>XA?_O;S+=4b{J$r9ozr{b?zZ48nUtd77J)<6Ki(>
zlzq;DyaH()fsRO&VyqHC4ZXBHl+hOye}InB2Mr@+ff{Pepeth+GL|tEsFkoRU;_;-
z6sVQ3Ls+0wLW&JQEvFQwS|*riQ2<P3aX<-24HIaxy@WH13$({Jg&B0dVG4^lLkTzN
za4pcaP$2!9?1}!YNV8ms;TrI{pOEYbZW9%Qmha{lAzxaWlAnyUG$Es;q@dVJU%xoD
zq_m(UKR>5f4^(87WTb-CW#;Rr=IMjh@D-Qn7i6cygS=QTqa-&+IVrI?Gg%i_jq4_Y
zmxw?H$UuuK?Ck6mKx=?fQxt3!(o;*)GAl|-i&8bzi&B$8;_8Ug%wbAF3y1WI!6OuD
znK>n?MH=dm>qXJjmK7B!*rN88a3l=yunf#KWkm%V>S_7;`bmjJdL<PlXr_WjVl+T5
zOHDyI4Lop#X^NhnK8Xf_ZfQa>2V#>RXr8D@17RU3EWi$>*aEOAAXn<?>Feo{;%SoI
z3bG}QG&>*x3lEX-%)FHRa_C}&V$hw|po1zPlM}@yMTwc|86~=<1)y!4;LXs;`{rRm
zR-_&SatLPZh7=_xr-D{lC}`y77ndj$r6#B5l|a@b<s=rDXj;MDp{EBK_5!7uFi^`M
zT+&-9gcgHu3ewX9jb_5vTZ1R@LHF{&hi<?*4>Y?9TAK`aDcpF3Q=P2_y<?qn67#Yl
zt7ae(0rd}R9tS5g;<FMwDE#vCbRp9%$X4X#Bi~H}3og*Ec|;Z=Gddk%dr6^DiX7E`
zRkjqxF!+v_Dt++E0PwmI@ODzfjYFWJScOD|v{FzJr~sPDOe{{-D>@IlAeiwMS21WQ
zY))!fYK|rkqAt6|R*+bfl34_<&Tesn*O7rz9Owd=f?KSa#feG9x7hMZKw^*;7@eSI
zLKmoEC*+b^P?QQ9P|nXoTYt%(2^q32>IJC=w_LykxcPFPk%8d~s7?g+D;Uf~z^8d}
z{AFSV9TCpLEW*ga0y;l}iIM4Vl?rN2iM?vZXz74zP;kRT1+rHXyb!aQsYn7evbTT<
zbP7)}LkV*VxHbf}-87l~ZgGHmuPKQoiB+})TXB$vTQPVlGrzP%K^>-7LsMOorRXrI
zfeaqcyan?ASrCD(Wd#~RkY|IPd&3B7l45JjrKgr?%3zz%hYTu##t@;MQ;@x&anK_0
zFeGT`4>B+a8s91c59xqg`{3q1s4EXy0RZZ?LgxKJoioU3xu7;?5vb)?1Zs^zI+{~K
z{s6^Z5y;_4Llua)1&unVgW}eRfq?;ZMlR?$Xci_877k`OWar?AvspRBIatAvjfs)V
z3p{F#F*FZqM}mjuL8DlxyTDVJTNt8PQdm-0TR@wM*@8hg*!O~lzSUp@zu+Z=Dd1zV
z70NP;N=g%Rz~efQ6`vSs2Q;7qPCJlw2MfT5LV%XJg9c$2GB6@-_+<t=7rdwU7BA?y
z{L+H>f}+&4%!;Drpr8T=3zz_>dr-vaf?^wF1p^}w=(xf3beJ;{JAXk__poL(NGS+|
zT@(c!AFE|dVW<V47M0Ch6b3o(zQ_SG@D57bH4O2rU>+Oj6uE_<lSkQWK*R7Hg<&;}
zwM<|+PLRqNrdq~Y=0YxT9$@nO#o_AiuIuUN=C8>G9&@?H6Q5Ze59(5a3jlZ*@D>NC
z#S2b&w?RGyw}?T#L`aG(%FizWmnhJsrjTJS=KP$LBG8TCNGS&#Fn1Uk7z{xH0~+{X
zU<M6tf$l}(V-#QnE#P8dtdev^4k&PA5*pH=xg&8<vIj+1ktB!(8qEPmN)gClB+C#{
z0ZJiSAR9qFC{QxxU?~ELVI)0JNdiuKE*P^y=t(byy@er)4Kx4%o+08&;cj7w;z;F8
z;Yr~I&(LtC@C7qy@)z}ilBXFo-oY(s=*~RohHQ964=&L`6K9~VFplI3av(TyK)R#g
zli(PU2IUb&J*3-?tr!C3b!Sj$fHE2bW0i<YYFc7xP6^bBMS57flO)*83yKzOHiHTn
zHzb?IFl@%&vxM6X8V&-_kRbV)3GC-v?9e_U)-E)tQ1e8xSOUXhsBVnO8F&v9lvtrd
zs0>-4A#|n`M$qw|E1CRmF%>0gG8ciO1X6P1oDTWPz`)>x<PK$YcYrDuSpO#;Iza=D
zCTIx(3JFl(5}XFiAk`gcO*K=$1n2?`(8k_y1}26S1{MYu2GAH)FoPjOv4#NyWUWgi
ztU!AVnpI_jIQbxm4e8oKaxNRhVx+7D&bOdiz#rszPzePo(9oR^nxjDJ+=7&XG9B2x
zpiVkysQ~y$8o62~(Au0DrV^$UhGxcQX3%gy=)mM=CPs!r4rmdj$#hE~7(5>2mYI|4
zlMmY0a7zRt0=lynA*#s&o>#mj47n&UCo?HNHxYEpdTLSSEtZnXg4Ci(py@}JA`Vb%
zh6hrogU>#M+-H7^3o4YHQ;g>ITb%K*VVq!40DxkEfeCb}n*d{#Bt{^>)cR?1W2?rC
zKp7CJvIQjyNEPb|DqP=y2yoejAi&`dDo7ka)`NDMf=e-2CCkFZ2rgzY$}>>X0hebM
z808u4Ob!-?C{`?oZF8n@wJ=0+f@hbxi@HE%m>#TvfF5rGUIGt3YY@Cq1T@?QS{VyE
zW;V6B1j{rssHOua1W>8~jXbPm@^ga(HMY{iiGhIubgOO=NKciRYi>bFCCmwWHaUs8
zNhyhT7!^7;OTd#oxGe%D>{L*|f`W^Iu}TQlDsZ9(OF=Ush>c<md`uj-9iS2@1IZ3F
z@4$xmQ8Ew64iE<UzZe{5u(5ZDJ=kuV0JS=@@z@g&I_xw)UXu%J$^;i&pi&x=MnM4s
zX%K>pg;<J~C_yPB4rCvw^aCYI7A79h;!kF9n!!krpz;fxAko`)so+JP;EIzq6_g-B
zTasCC@kC`7_$KCMrh!sal^nRMSCv@+I%o$hrjS&c3A(@wEP;|1KsJH$DToH&S`Vu?
z`t>>)+Tph!bTEKczPT`fE<P?{1`U{j%TH#M^3x8b`~<D1WJv^t2-sFozupPt3I))y
zXyC=fiA9wP#hJO8If<aXh@kBV3RRf}kb()ZR{^dYJbGTN1MS;^b{2vz5C!iu0$mqY
ztfNp|0y<zVDzm^dFAa2GD`=HjF?0<M$bL{y6Lf7^VhLzB8PW!_#F7jJ_}GVnMt-qg
zacY4kc>M>cr2%T@DS+<5hPwrni$UZ2i6xmynK_`%mEcW)1(gMrpf)vhPz5offs$ZB
z83R;dg0EG8T+kFN2O6kcz>vZK8jxMc)B!$Rb0K3I6Y}*6Md!dvAz2_R9>ML-tDsVv
zJw3Gqv}t4|^oj-0tn^C8TdY-}CK4n)f{RAbB@2z9R0xW37FMReJd7Ows#K8^j~+Os
zV7X%fbkI0EbX)f=_NdGPP@Qs%1Jv3DH44DjaA`7wYYlMqSfmST-hi{gCs0uha=<NC
zu<7L>CxF^044gcST&!%r+1RUuFdgBi$&NMmfs6m|Ab+!fsv?O0z!rfCkVQrBK~{pS
z0r?bk&jJ%8mk?MKBd>u<3~*ipb&HYvQK{gAK0r5qM6p5pQtT<<zSJ!d-_+cE&`wxn
zS68WmlLt%+l$Jr^56^_q0btPGv5=e^pPQdj#g_}sw+gu>nYpPbnG@tR5C)fQpaaQ3
zW8RRSdM#rKG>K%ffO|a*WsJpokfZvtSZkQFnL#J%E?@)oXTZ~d>^01wl_?+<HsG^e
zB^k0nH-9r$g@c_9${(PHgF+(Q!Jz3gaMB0w5`Y|d06*yyNmUML@EUZZaAFGb=%6Mi
zxXB4l4YxS*@{2$x-e(knHs0Oh0PSQ2`S%tp*xN;*_$>Mbic}6*fFO61ivEHk^dE=-
zM>3cI$Mg?I28PL?m<E-s3@o67CBzuH7zLQBBw;au97%ehB;%*afi-2Rf$Zl3CFvCK
z4TN9^6@hHPn#g`KGBEUltOhmRKnJ<;FcpEsFp?Oka0Mr^Sy<W^sjSVQ9ujj33%G}b
zwuUa13$lu?nK6nRx{i(~l^3#-u9-2454x6)KLxUuP5`==P7u15PACPkmQFYYvX)K+
zx|U89d;%Cllo)g^ojAA!qgd1rYQZSMwgrLjT+c5m0T+Z-nFWyLajEI)SXwRcbPB4n
zz?BGisQ@GBW+<jC@EnaeLk&Yb(&bg`;NB&qQwkavy2TDXEC7;jAVphMCV2P&=h(q=
zPy~Q1hcvaLG7I31pLl33j*_Q9g)c}sI8TADC9Yvy04a1CK}9g=I)W^gY^EX^P|K@^
zaRF-$Ll)aY#v-d4#u9cAyO|Mk16D9Y2}cTOyn!K$EsY6sCM38y&g=(nNd1z8Y)uD`
zM}xKiLb6htf@-lQ=PkA(&=70^!ly-`5GVqz<thSg{Vrl;Vqhpb0!om4j>W~PMW98a
z;PF%FN~v3HX~iHDky0ioKiuMt2i2i@Y5Cwb`)W|=fEvQ!BUczf+q#87Yh?acNuq=l
zvL2M+0wrD4-~z7!5eE&mFoA}FvY0^2kHi_kLBv!73NEH*#uP?z=tW@**g*22zIO?G
z3g`|qhAbxZ-~wILT*So0z@W(i@i#aG9)NN?ypjWl1$g+Rhy|n)(i6MI0Zt!@B^gDa
zqmj@9gDoC>D9CnDD1gfcX3$bsIY<bAsvJaG0V_nQra^5=koUnU1r&y$)gBNpXEB33
z1YR7Z$#RPi6y))+VyhTZU?8FsOZ)Q{s3rx~*atx_10_iYrYd3N7=cCzN=F-1%&;>s
zFn}Ed+M5J&P%&b+FldDictIHGXzqm!wJa%23s`Cx7O;X=cr0YBVJTxM3aDXm0bSz6
zS_4|!0b2jT4qC|p8p<oQfQm7Lmg#9S`&F63``Dn03{);^Xexj=x`7UD&Ig}B4{8a4
zmRCS-IMJ)hEC9DsG&zdEV_=|B-dh6j8O->Sd{AKB5&`uV;!{DVK*HsU!KaWEaWXM5
z+!BljZ<<I3T|5q%S-r&zRSq!$b}%zy$ted&9~;<6NKX|lF@Q&ZkAlJ*G)4hhV*?sh
zW?|uC<X{v5<0?hu7(f|gfcYOKfq?P_Jb}Q@%>^G822TH=A;krtN|&*g8FUm8<hE_l
z&P`Ct0<Sm$&t7P<+~Ne8A77kVm3oU4v;`m@Ts5+QNw(Z<5DmKL1(eo{K?gywfRq*q
zfqcvfk}NJs%q>9kFLc=?*to>J6tL-+K;8#6i5QsJpr@uFdl?)lC>l`GAE?O&(hN?2
zpu?YPK-2FG3mM87iX1>ogcmZ@Kn{$T0yjArYoP0%Ye2{7GJ#eX6-t1ISy^jXKp6;}
z-azY%m?Rk%GR82~vevSda1<w$a6%T4RDGynT)<Vski}iYuz;tAX(8i6rdswIh6TK!
z)kO=LiaKi8K?@yA_);Llx2!en3mH?GdzoUGYB_2-OPCh$*KpJ@WC<(~gy?2uC}CP4
zRKo$fMxaEvhO>sXhBb`|G?r4sxIm<avxXg%6RP-1L_utjcsN5|8Vf@SQ<m5SM%YnN
zU_Xe1?3%z><c4t11jZt{8g|fD53sA4vLsSivY9|?N+dzIuQM_r%tfecf*v^)&X6Yu
zw<!-Y5>>;vKngUx4n35L9dy5(UzMFwK4`@NC_^fNXTCuE(!89^ylf@#Q4XLw2a!d=
zd+0&?&2u0fpDIp06=?R-WW2=;n&@f*4Q@%_VvEnrOG&LL;saGa;G!3?v|}l#IF<lO
zaD&nvZ+MVrh--XsXh48}P{=KIPk(Uj1l}JB$@<`o%nceUhwjh0#Sx#IT@2bDdW#iw
zU`r~b&I8Q`-C_luG?iKeN?wqyl%T|Rixqrs*e$lqVo(NwEDq%c^(#PIF<~pGz(oKk
z_k-ncv4AF)i^M?=6$3exvnVw&2fSG27E69<N!l&8l3dVcL$vGy_VaB}{s5h-#=ykG
zD8R_V$oHR(g@;K5G>FB-#KgkL^Ph!<hmnnmiIIts>mL`32qPCGA0rPF6C)p!03#nG
zA2Syd4|sJI7b6do023cml`KjQgN8f2&_l^!oS^9;SOE{3Gy-KR(Ci#2TY)nOb1e%v
z@v(r~^~EYFjKQD;%?jdy7U*TM)v#nU7dzFkf)?#%GZ(pmRMaqJaexjcTF6+-R>D=o
zn8MTy8VF^tVPC+#kfD|%oFN6?k<Sw_WGJpe?#S1$)o^5k&WUBI@`m>mpu1>5>lHv7
zUqGE?Pz-^C88itGjd5_p5xm|DRCIxwD{vFsik^TwvphxcGzDo4fm56kDEh!X1<;u{
z;L`37DE)zJRZxOK8k6M&FQ9{#p&&boz=;8#0w6sO9*_%Q=S|*XOuNMkb}&o?JvGQO
zF)#?RGcXi`D+?A8M$j?-T#O=&EKHyYNj1hQag=z?ERKiz8KsH<RS%$Q8(d`CL1(H`
z7)lw6EYcZj8B;*F7RiCm(O$p^DxivlY8V%Q3RQ5m0V<>lg}`%EpjI?!MK+V4CQ}uE
zULxqOnfRQ{q+-x=nkr#%tp`t2U_nimA^}h!f~PihL171)+SG(Jn;=r4VFGl2^D;3o
zD1rP9TAK*EDHb$*3u-ihPU%DOF{pk-vlqqdpb-vGf(CmXl$fhPB{2i2WMlztm1~2P
zaG4C?8WVJgco=wW9^6#`Eo-k~E>Zw3?OMQA!<@p9!U$THwGec;CQA)t8ADMT=wMAr
zh6U_3%%DR$!GWbvXi&qvfMX#;IwMHdhM~})Pyrf%jG%Hkn85%%RjJA32dR5GZ*hXQ
z6oZSsTYRW16^cLw9i+(#E(<{&5=a{be6@=vsLX^ObH<#Rmr?{uxwlxs4N33{g4Dbc
z^x&0ZVqnk)1+NTfkdzU$1QU|5KqROYBE-nTB*e(Z2p$j#fbY@)yAPvb4oY3%;05)$
zz-0ww^8)C^LeP3RIdBEd1gfABtC873sRHaXkYiv80^E8A=NoX>8ccxP2p-|I0l65|
z+5shqDgl&akdau7;x15Q7Va+4RvnnTK&zyYUBXlZb_vK4MXVq<f$annV2eTHs}3NG
zK_-HRn^COAJ_82NYM|N967YVGg`ie3bf_eSaUm0ERsTvRKXAlovJ`<Xpf3Wu0leKD
z>?CZi0S!z$Be_Nd#WkQ2FuaS!L8S;dAVAwUKoeuAi`OARu>zD!!Mz@Ai~9MQ7#Q4;
zT!7kvgXBa=+ZZE0;K4$?Gr&XK*qp(`#K7Q*<O~^<fPi-xATH6Az&g$XE|@?gB}H7I
zhzE@kLqY)5WGGqzs^Gy16ue#oyuJclM}S);pn|ywR7yc&4Q-ML6i7uNCxYV_i2x@l
z(CEfOP!$ha1PvaAXJiAd!r<ZHVq)ZC<^bJX%)w#KA;7`OAqZQY0Ui^<7}5bHO7M^l
zh(I1S1RcVFy7~h96gXr8Jc<)K{oM{avmbPAtZ!;bB51vhLPla<N=|AKxC$)>pE;0|
zpO>l-;0;-e09ma8SrHZrIzZS8>404L0(e^m&@e5`ObsP{Q2nT1lCKXlMhSX?5qOI#
z>~u?oqEztEIrzvOuwy{G%;AQ@rmkQk@t`gs%sj}ZbjV4epwqpIQo(0cCW4OP%q#}&
zvV|N5241TLJwg;#2ZM+5Ghj!(K+XvQwJe~{N<lil6Es?hk<3AH0xk|gZAVC{4;qjG
zchgrgf{SOY)83%;7lV|fMUle{u>u8TJgC$LVGtYCivwE+%3h$ZIJAr{G6E%PY#U)V
zGBPm4BUvPmY7wYLg#|LWC57Qbc)<$V_yk(UlFgJa0v!})$O6yyYl0T6z+yv_8NE$~
z%~_x(LK2d*BvG6N+UEyz6^esE6#}Te4i19|P}_zvg)y7CNT7rPvW5&al>r)01MLq^
zVeMsxPQJ5%&dm--ntTVhIUP{ioX|lFMh4KXHcd9aB4Z{7hAIuee9%2Tko*DJ^^V97
zppy^E5;Jo^r$!ZR1{I~Cts0t4w>VPslJh}}v2U?~yA#ElY(-l^Wy~s&BG9l9Bx!&q
z_-~0oPBzTXi-(@f0ot(*8;J%tn6yBh3JzF^pcgTqMP#X<umqV4+GoMRB*Li1$i-NN
z8mh=~jS{M$W)mo6!J!ITx{$)SfB|&gIH++1Zul6bFoOmZvKZ4CG8sykn!%@z*Rqr_
zFJJ+6t08N#G+F$LL8;~a{=MM9s4}W925p1^<^NjL<B|%BK$|ggDiu<|d-GC2J7_{f
z+;lB8S&O!Uf(Wq#2ENP@wq4I06c_?XK@|@=-=wG<qz&6DM>8e{hCER4fU+n96KL#(
zg;9vHN)aW=VT%KlKmuhycp!mVs*t)K)C~gF@8BF?v<u`2Z0Q};5H15b0%QzmyB><=
z$T0)iuIGni8W>b=psybUc@VrG5Gi3G+BBe2J^*Ah$juy#EZoo~f1Df~MIbrc)eLAM
z7xrofG$c^e0jfTVnHU&gMLp<{4e$<caQy)~z8QAHRAy>1j#@)m!3DGuHopLr<`qE0
z{76*_Xt^6`#8Sal0jU;A1m6kbmzbLh8Uxe?DNurU@j$ELK#gk!TZQ~$Jy6QigKl5f
zfSHC^TMWxk3bqOXi6t2@e`vrA(E&LKyj2*X2Xq1tc$gc>hT?*pOwf)g&?GL{N{|70
ziMgo=J2j&XV&RSinW12dIDa-XKM!nYN@kG`C=fvvA=nOEkV-I12VMx-!dwllMM2e)
zvO;JcXw6z`3dqIqdF;&8Vzkf%xeixo>XxMz=@wLi$kdW#P}m}Z6=o-TNP)r>WTp;0
zw6pRv^T6H)3#-GHF{*2#1|gdF^*~qr#DjXr@L&V$$L4F0hf#(wKxGanTY-x&@Sr(p
zi6sN5BNERDuZ=aCzzZqC>vLf}kb|Hi8MImwDd&J&ZJ=z{2g)>{91j||trA5}A@B;?
zZzU_%)+R_ll9`Cy2+A~7FoQW5S%ksai0nMr37R`ofF)c|+CgMMPz*v^Y`DuY7jPAt
z1)huoPn9u)+b}FOj9IKj1|^JHYzx?H7(qL5vsl5)S2^-Hz<h>yjv9sqoS<<+&~T3?
zQ<bhWxZMSs%Y`*3p^c~_1yJlNB!XtAAuBCXi$LWYc;X4s%LUIqfd*S{u|e1Ff};n#
zq7~dV04*Yg9n{7FGYBb^;W0N26u{uhkeLs(4W3bqi37667Zy^82rRM$wVc2agdo5s
zfx>n&$Rto20JYqUKqBBp2P+wGiN=HSCiuQ8(A@`Vpx$y3o^C0~IW>%+I>QEbjba5O
z=urRk%wo`~yWk6C(Tqy~ofrZ#8MG4yayJ&}@H$XsSzHMz-4rrQQgfk&YXU4x;z4Wb
zz!%?xnzA4cXd?^wHbGE(7jj??=vWaY&s@+^-JrAUHBd|h7gf;SfF`8%jNO5t77%!E
z4X6nOUVWyc06Nb-HANv2ygdeN63CI@L1U16V6FtOrb*08PSsJU%uLNmDON~GfFH@7
znV*-C09R400NG~?J+KsfZYrpJ0Q+7~K>>7_YC=K*%C<F7xWz+nr2w5K2s&RbPa(A;
z5wx*W&#%Y^G^59Kix=h`aG>21#uBUONo)cG1H)2K!T=RI4D3Z9K1vn?B^VF}7f7JJ
z6`*JbFJoc^-y6;ZYD<BNry9m)(2^y_Dm}=>hRBw~)+2*2<N#frnE>)}JSZp=G?|M)
zg<jDPQ2AvG@(9Z<PPp_f7SMcIku|8D#0Cn6RP=i?!1rXY2YCV1k6>T|-SG<+Ln&85
zBWWOcQ0Y{B3{+AuWHErwu3N}hBmkPcFJY<yt<GYuVP3$T!n}~N$OtrcR>N4soWjxz
zUPV;HRAdEGS;M@5EroR<Xy~z~mZgLpv>&^u0lKT3u?DmYoVA3zgl7S74J&AWb~95g
zTMe5FLo8P<dks5yJyKDjOAX5czJ(wcfF{RX&~!7wbT>2Ba@4TaaK!VMuq+S&jmgz;
zEMx|o;R14tCVQ0wI90l3=7H-=@ak^R(lt>1Q*5nJkY8M!nUn)M%sQtevmhr`AuqKU
zbn`W+c>-BqRmGxLo{<CTBCKRA0yRk?6YyMmpg06KN;Cz*Q|q9<KuR%asTQRC0QG!|
zvO$}!c|pY@ywZd0`v6_7iqwAs6@Iq_Kye6K`(GTNnFpTA<OEICg0t=|Za6cw2z;0t
zxPrR{F&lPZza}R*H5563$~s370dnyz_TthcP<jG0K*^^Fd?z&MZbz^XsMbeM{O(K)
z4BJ2{2efpFfrW<|GFU6X$if8LE5yMF+AIJ{Pkf-M2}U-?B9IQ0bOlPf@Qy4fpMYwR
zB14d~Kt-@7GrD6zq7Zk03g%lp;PA-H2cLp|1>_cRMr17VV`5-H84m`DgE}|hj0oz#
zf)0mkVE`>;0xe1cbrO3)8IU#62X>e&=%S=Ng+v9=@EWMF1f>a3o1_?aTr6nKU@oW#
zPDw3JPR#>#@)YumQc@vT5hPVAz|WT}%}oN`hyhM(pv`SyV-#!^)RPj6)O8d<yHi0F
z^jJzGJ##%n15l-nCTIi}gPRhcR2dJoA|Bxc4Y1*mHdeGcaYiDX0CEtdd5YrBVEA5P
zT|+%1J>w)puv2st)X`<Y;v_i{s|i?4hT2J)>p*9rL)=c88xiIZaw$qO1SNP-G7M&5
zU??^MZw&x%4}nZTgOVetAI-3U6|@%~v@d=kQ!Nu@P_Kpwv;a1kL6fD*4D5DL>o*{=
zs5n(2H8D8@d=!6v9%zFr(wW7ev;bEOK8Fy+Ij~#-b`GeMm(Ebb5Gw%66<}vEE@Yg@
zRLBy{0M2uo%tfFfb;tpiFF@<`AuB#_v4CbBz)BzlIB#;<fHDqfnX26fb_NE>0&#on
zX%?~K6G<K+h%iZ$4N)ZC;(+zGZgFOoq!xj<vfpA&&PdFJ9&W)5nUiG(O?&FY3Kb+L
zawFOH3RHT4>No}#0Y(wVDs3b=q}+vY6q0;MQ7mXSh7oiu254D|CR0%zsQVv^#ZECK
zeMsis23Zd(0U7u?IEunS#TO{8fJXa37&Kr38tqaBrJE_>bko7u%-G3T!U&>^OhEIp
z9gHO`9gHQcpr(2UBY3)jDTN7A{emx&;Q*<vWo~C^XG~)PFDm7zVFsnDT9y({P(=)y
z#dTqbHL7KUnNq_BTJ%uD)xlW9*1^!sT+30z0a{D|u8=uvIKh=^Q(+9qd`-40GXkv_
z&~2Uy@b)EaP@uBtE-1L1nHU&Q@ArhIPw-l0Q1ht<w0elKgrS46h7shPA|~j)&`gNl
z9pfz?P|X{kmY7_UUsS0HNu)(gpo6oRiokUqxb_3rC7`5Q1X`KQ#=*c)42pjiCMHIn
ze^v6}ss-9=M8vuc=*;bkf+9Oj?puQKpk<|rIhj?dkmG?<ZV7-E9F#(P;Gl{cT)!8&
zff53!!-q({;HkV@Jm4#gKp6$J4gwVIMG>Gz92a`U_ZQSm0Nn{ul3J9Sa!U|YM}u2{
z@t}FW%+zAA|88-B?&<)^-C~D&AL)MPNRTT)9){MNP|tk@B|UH*&cwk4J{X#j??2Oj
z4ptT>4ptr}rhjbgkgb29spq0Z^rQ(Y&OiwlT(g4C^93zw1P!v5fSS0>S<Ij<Sk2&>
zQ_zfRFhdPfu|WxI4P!H7kwFO?nC}E`H!>|`EOIJg2Q6)E22D3JS6PC~F6eYWXytx!
z2`pN{BTJBu1vnhQoeEG`KyE70WctMks*1qvuOb)F_$`DFTBf4O327hsgHjzR&Wl_@
zEo5m>vVnEHisQj;GEl<@GzU=xZjPmZVnF~j&6HD?3W{FP5MA~ycE5a3ccoa971FK(
zB{fJw1D$Dmi#@YA9%K%r<Uu4mP)v)0k{u{c7+5$M1(=!svoSOMXJTZ7(j5QUm{@*-
z(*&sP4Jr!Y7?e3c^FPH}80&f=`yf+Uv)GE{Qdy$d!Fin_iUYEMyeJhE9KqnQ1=aFN
z`T02-P%mgeM`w`EX#gn!rBH+t4RzSfGqAy&Xh^M$Qn`Q{b|4H+7@!maZrr^Eg*iA3
zu&qqwh>r)kCO%#d6fPhiGJuX|fdsD}OcJGw1yTgUU~52SB;){~U<PnIQj_r(3#f8{
zjusTfgYp2_dN2VBdC+a;pu_3o<BhRf3X$~F<it9_lMXTw<h`OTp!Krc@$q^2c~z-J
z`SI~ZnIJi^MF;|9B{&AuK(>Jkc19L<4kk867ACMbN+5zN0gxK7??8v~Rq;TUH!p;p
zlg(7ZoW@kC1X<4z$&eSo!cf8jK6npw6tD$o{03B*m#}8Bm#}7Wq%oH<6oiy;g63~h
zn3|bWn6sHcgZsrX(8KtcK*t2<aixH1@L_!5T|QNw;Pm2H0$M>;0ve70r3nS(*)veN
z1G(D+wE7ElEs#QSelF+|g5=Z!&<bMM9t4i^%slX9h+if*EIDX$LCVHQpg`mgNG;0E
zEH2K>&jYXPx+Ub7U*hPJ3B4c_BF63?3}JxQY31eLVt4iP4{`Afy2a+|=<Mtoe2dN1
z&)?NA1ia-CdJ7f!OxjzVndy1?;48V%vt$et1A{pzUO-(01{TnHe&B^zEMiQ2;L{K!
z7>ht^P~r#_`Jhq+ltYU_Hw3`u#1=9_TT;xRV}XjSN?1xjQ%ejB89{55vzdzYK($s0
z8)&4hnW>g3j{~&G8$3L~kj1!w1Ei~#8GJMlBWMFf33m!pFAJ#31?kgd_5&~D)MUKH
zRRB8MBqcR3ITiUNi6Zc-Iq*(j&|2;yP}qV;8NtK-MfX8r59)swd4bX?=t^)+7VvD;
zEf(;0aZuL~T(6)96DR}vfPx7$r4L&A&ci4KTA#)QI>n2Hk>h_6NCiqDff6z(cY*^6
zR82reLi%+;>)yeOf<ebIGcE)#?JnZ00S_7!@`W>`Fv7NZfoJNhkZ0;ZC5k3fl_5B3
zLYf|+L+?{TyATyXXPy;91{^_MH`sm>uv$M&$iCWJtl)+4u+#ybU1I@hMDy`2{=EFW
zc(A#kB0se_8svLW#$*65;RRKjMHQf`5me&AifB;60Qnn)iy_yKb%2IR7~A1n+d$iF
z!4VFsESZ{_ARBB`m_fUiHCd_>!LEh%L_rx0l=Bkv6u@;Gs4fF_MvL=v%2H8B2EqCY
zic*U~9fHg}P*+u<C^ap$2$V)Z*Qu9eK*ldnA_-KEf>JWLy#;C#)G)-#K+`Z2I8`%u
zFf3#Qox%u8g@s71E*41kMGVw}(jK(!b&I(uH4QQ`4K4@4MIflrl>-VzP$;o5G5xPn
zMz2`0G`qm@qR9dd>mra-!Gl$|Sn^UUN??gs0O3*aM0W8lKB&nlP(C-PrjG|-)mIEQ
z5#l(oyHc1K7}7xQ0*%u$uyQbRfto-pT#Q8^nOj_-={nGOQECzBd^qrwOmRVCa%wzu
zkhEBn@s==>FlaUgbaOo@N5B#WXuKPIr#ZM-2U&zRAUul+c|aJ{i$k#kJRF>onw*nZ
zlnOrCA1tc?vkEf9M&m(XERI4Q0?x_I23@(7S&Y0kBqcQs;b2&hX~0HaK_kW`8Q>;u
zr4IBwa?tc1jE!_+6R7vA3_pe*JirXm2g)F&#i`)-VRA-h4k)pM=Lw->;~?`O!3B#j
z@S<hVKq+|mIyD8hrWEEXh5RJYJe)!X=z<!^b~AAHN=z?G1zoWPy236Kbgon$blD6v
zx8<akCFVg6ss#^ELq^X_GE(7p^nok|8wI_pED^p_Co>If2;`h?g?MnfjgLoMBMrM|
z7gYZyf{vnsT%40ySejXum;=i6#idE0@<LBR!3|}=8xj0a*B0q06sJP2Qo|fM&q<BX
zD~82WLIR}B@GGhZbyAp$>_E+CL5!3D$x?`{K9PZep%#>-K;;Vqe-Vg}k{v)50|<k&
z1L)`*&{^f6Vi9yCUMWM72&kYhVFc|0?pI-CC}CW{3|f=`Iz$k(#{{%q6QiPVL#`-5
zt29d)iekX#fIG<Gx|OAdC55q+p=e48Xo)hzLPi#bS{6`isfNLZA)Ntqjd}?;Xk?p_
zAy1@)r-lVoFc+^V;RW5f+RW6%Si)DrUjr((S!-Bpz}vBESejWtBi1R5rHn=IYFM(s
z<JJoVYS=()L~EEA2!d>8WGE4;VFz8*4m$s#2DGn}waV2sueh`blxGr4z_A2Rx(bl%
zi&Kjg5Gf=-4U*_V!?p?<nQ7qbfKyX6{cf>=n>VSTb}c9c#K-^Q^UE&*&%%H+f|aH)
zWYPe%pyC!^a$-qx26)i}=pepZJjf^U-Qos!gCWVV2(&i6XbWhj0kmB47At5zsrVL`
zFZkYo5YXujEuaL!2Re5LwD&1BuOvRN7;^N|OOQ73EJXvTu>o4cdW##h9TKz;wKOO7
zmSB8QDtLn~NC2GPH92l^LyI&}riJvaKyw+8mHVIr=Wnq?GjS1U*cRM&K}&qMxS**w
zKCieRlm<cdFatBFN6W&@#mL2|0q*mHmd%SWvN3{0K$wq_1IpuJESdnS*g=&zto(-c
zc|l^upo^6tqsgEe5;UCB$<)r2#t0fyZsF);gbufWwpMb~GJ|GHYM4{ldzorkQaDnW
zS{OikqCov)(9ZTOmJ-%xrlN!zmKvrkmK4qu&Q>NHhCDV9Kb|FpGnhe>tEv!OWCTG%
z3tCF*!HWp+rC6Yw%)oPFpu-+Oy<*VKf1t_&JU*S80yZHzzo;m+xF8=gat*$QJ~gul
zF+2lS3sH&OssUwUP@N4PGz2vO!Gnf8pk@N7Q;#%YxRS9biiv>%x-t9~Bl;$xq5via
zhRqzX!9i7w6oAwK0QEM&gNY~&7LdC@1&1(bTnuz{Nfl2A_%wWY_lU7l4bn9#0i6Yd
zScVPSQ@~uM5B46YE(y;s%1$iGFU?B<*Br{GMh4&^1!Yr1V@Rn7Qgw?tGcV0gllc}a
zXqLAEeEixi*0h}b#1c(La8p^6@fJsMWidDbLy{t>RdGugJkSG^fNXTx3QCS3*F!oQ
zJd9O(ctQY+0VqKMiV{$|1P6r;c#aOSwG_0YA2g(#!UWzs$(X`i!^F)1TGL+33>r2B
zEtZ4q)N5u0tzpt+sS1Jz4RrhkG-C@sS2QsPG#vusf{GW!Sze&)b3munfx3F2X%W~s
zAKaiKS5P4U+HVOuA_}w$3DRf;Ep5NWnw(#nR{~Bj;IT1SYmN(K38*wFDZa%6DTpAv
zBG8boCetk*Xc+-+a}~`1l`inA=avY}L7)k<VrabVLj*hzcy6jnA5XwzGeMKF$QpF=
z2`K%+3I*cxMbSi%BPW3fuuH)ND4BpW#0gl200k1b$OSj5!$8V6f&vg!$by%SYqH+r
z%rDAJha|Q+AO)a8v1l%+6z0fFEr&>ejMro?0?UJgXF5nF*uGvS28MN@&;Tu#VPF+t
z;^E}u<YD9kZ9rlw0?DGJF;MyfC0KAh4La!?G!_9``BAl_hM|P1jG;&&oB?z+07wj6
z*Rp_bEoWH32CA=Pm}{A8LCXi3iW*ATLFagYYVZ=KGRC5y67WH|j0{x*B`jH-pe;vP
zT(ykh40$pv3?<x^b<j-A14_A|nisMst%PX-Zw*sHR|;b~!$PJ7e9*cTB+391VPpVx
zuwwaYSxWf9wJj4PL*X)n8}qnet~G$H#bBwjbb+?3!R043Z7HZj8K8<t9kj<N5nMw<
z8j>(MNcwICwT%RBvBYQQ7Tn@VOfD?VEJ}^f$xqHMY6L|L5A+;Jh!8x2Z*diYrcp9M
zxu+-*6wlj01h~2d$G9#i*1*-M0I1^*szJdulO}6XA4m$EN(?|O(A8Ry+7cA?h*Ah_
z>;+JCgN6)2l^|#f2$Lkoa~38xMgh=1Ge%Iw$iyhX$ipbWBE|?hCWen0tPiEZ1}bde
z3BeCM9|1bnijkqptb}O+GiY#WA!t*LOf6FhOATmo0C=TCkr?P&B~XKjk)cow91U!s
zqymlxFw1}eJTcE)<$~N8Dkw@V%giq=&Z*Re_Igq<gC8_`pPW;gl8R^-fxQko$zuU1
zSQdf^P!tq_nlIq6E1C=n<3*qtV}XPiC;)G<Lt_-usz3`wkd{xNKm-+FpcNCK-~yc@
z&Bp{bE*TU!utEW}V;a;=1?L#h8Y@s60d$B4=<X><i7d$g+M8O!0-b<i&SG_8h!v@2
zD`BZ&Yi6ur&1Nc6V`M0FC{(Lq31$FKw6Ih;Ip^mVl$NA|Zs5u*)`hwk-hBWqicf?r
z`Kko%c~r<R0<F0MkAuLvHIUT0h5>ZH9n!QKxbQ6k`3+JQw}1kN9cexSoY=tS45-a@
ziwiypl2RlEN|>m@b&DTlDN-lmA1LTRU0w!e3GiM;9!56iqGg~a7IMIW*r3uC9B?2G
zXvhn)v=(H6CJR;<fuz8ZUIZ%MZt>@p=HwvREyM}Gy0d6G$VQM2u&4sD;b|JQrwI~O
zV3HY3vVaa4Xl7gphQSP)j8%qy`9-<l86eOxubDZi`YD-3;G_v|MSvPCiA9;k`FRQj
zr9}n##i^j>-{6IApxg>MmjrZ6-YpK$K2cCjSM(b+0LmMmT$x^;nFlJslQUK_f^SEI
zcns`Cknf7>85kHO;XYyl^HGXxkdHu3RB#wVHYH_&R>?CJiGk(|AzdfX#WTSSnoNnH
zBiF!HwR3(R<l@Pae1!o2V9y8zBLf2q9fkZn1!u6UbU+7tCzq!vXc%jPM}QME^NPV*
ziz{<MgHnje=wdyEP|zi^U|HBY+{7gC;Sm~|3g!7l*`Py)!R;>aR?VEu+{}_hP$8(N
z;HZ$6SpjNE<QMCur<Np_r$A54E(c$@TTqmrln7d#layLgl3Jt#QVDUOLTXuRo&xC3
zY=z={*qKdWCx8oeutmkGskz{*!jn=#_q?a17H6jC!43z$#Rds~O;$*!#~V~kAmWW3
z>Vu-ypdtkvBVYm?EvuLq806s5!chd`qZFQ?D1j$5&?5UPF3<?DBy4vgL!|+<wqpeK
zJy{q)vNqs>QRH2O;LM=O1ldghN(-9IkYoZ{par_#26QDOdYS>X$2CEY1CL#T_7Q_h
zdPqARciI7!2A~aO;3ZekjUH9z-~e?=Edh<y=cR&1P0}+#;SNg13W)^;sfk6f08Y#U
zEk}m5qkpl01}`<4Aaih_nK#Jj8#n~P1UMK$6K;kemx9_=3@qRYI1CqpidS&zhU8aJ
zaOKN^8?(${lBI?L)HPcOJ~2a+8M@qyXg9-VauJS)%v6K+gJ`mXodjvYf^u^ac-t^&
zofcOAL^ClkSb+Qkst!QoiemqYKw>C<0u^+iMi$slutq$nngETGgKAjNX-h>GDWHA2
zpxu_tCEyLKHO!I>HB8_ocMOu?BPBtlC1{(eD`=Sp8>Bb~Z5aiZ?zh;BQ%e#{N{S$f
z8`Q+mWPvmyKy7O9s)-^{MTnkyx|tXloIrknq#noy3NFSXkT{AzKuH|r7w~95=!{&@
zXg?@Mnwg3$AP0oFFvKc=eFfT)!&t*uBmz3`2ISXb5$L48NS<5`g9}5fL@iSZ8>qPm
zUUk3-mGvmJfwmPa(T4u@L6ZQ<`MKbo1fbD;@O8L}u#0r_ixi4e3rj&G;lCJ_LCphj
zvl`^yqUWF)UM}#$60pXiGEfc&p9llGg-Mh77E5tSQSmLt;#*9`(6M7gnguEG0)-E_
zIn4x`Fy~<6W8?zQi-50js^W<$*Vc&9iz(OE)KaOM2F^no_5n7aK{UJQINexnO$80G
zD5$@w3z8~JEy9!m%NA6E<iRWTv8w>90;|bMEV0wmhAayMiGr}EJ=`KF6H0-i4OT6J
zX;9dJ=bGEl=bEL!bIXiTEGcZ@t%j`7({|ZXq`@afF-EaN&WnoTNRa`b7sVLGnaZ_*
zJ4J9IV-)B#DcKaE6yX*|(0Nj+yeT3nqAj4i6ZunlQ{+;_QpCYB0;#+y@+lH2l3<=7
zxDljKlnYw(ZtM>koh<^Ld=8rK0F8ZsE{0Ai1D#t`3>wb`FOUSUONI>Pg44Ah=-f)M
z??417SAtS4Jm-}#fKptsPzhrSBdEpN#0V;e<H3gr#WR<%fUXAxpXv;5xPi`=s$s2R
zh-Zi9yeeT&$a(9~0UB_lK$GJZo3Fo1sE;dn<N%z};Fl?aQot=%@X=qlSV6h7xJU=o
zo&qhxgdI2o-UGHBlq7e82)I1hLl6R7c!G8vWPuVQsN@E11mgm)eg}<gRSCQ1l@wJ5
z<Y(rUz!$%xWL{8#3onE~Q*|kzs|7)a05F2iPJ-;1FVX@X<&eS*y0tlrX(6LHgE?d`
zJxh^G4I?N~fMr+~GKxWDKsTnc`Bky27Ax2)s22ZXv;sFkt5_AHRf}VPG3sctg2ST-
z;XQC!3i2at_I?Y<)8Om|Ccs`@4I26Zc@^BI1fNe08psm?9TAG`(c+S#_;?h5qBM^{
zx>FcI#Z)t+7z3z5<X0tv6jGpDQd2cli!@g<LhgdbvV5UvHUk4gHOMWXAY@=f3u;gb
zjgJpOX$ycd7AUO!LB0ST09(UY#8bmm%u~Z$Bm-)6rZAR(7XX4Tf~jFFG5~F9tYOMz
zs9|2h*ax~shhYKBLXdk|syyJiIS4clPz34-fd_m+i{^_Iz^xvHk90s240+&#twFPg
znI(|g8B{J*c?BdECFX)^c5np_8m0wLlB9t0SaM=XYKoqMf-`7rQ4cz^1|BQZ1MSVt
zEJ}r)W|^8(saFKLtGMVQXnh=O5oo}<2y{_F5oirt5oiRl2($tKw#5-F;0P*$*|N(M
zi_$R)SkP&Bb)WzSEkp#Jx5vWB1Ue4o4;vc`qX1(SKf-_Dv-VKp8<f346&E;*!zv|E
zgE*ZLw8XNPxt6g?2-JNoVX0xr0v&6@3_UM`tulm>p_Yk}p-Q5J9Wqh@y0iy;c_B+J
zQyo(tR|=R$S});(6dRBUTF{6YXe_o;p#YTmAXC$zK{Lpx7B~pO`5qAykQFDOgbLb9
z3R;l_8V9|_ngiM@2U?K=9wPwdm|L7_rFqFEpzC}<ZNHS#<kTYY9j@Sl0z7uW1}aTJ
z_n5;rJ%KxMJ3*r0>;xvjc?uLKy`W$Q1s4Mg=+HJH(Cw{4NWlw@c$D?rpp*<MNWmct
z%DteC$wgwILu87@Km)Kf44|<a5FcDRFo0%mz|9uWZX?ja5e%Re4z(;LY$fa^ELj{i
zEX_>KjL=P`%zjmBkZT~I=?v6?$SlbK-Sz-k90pswrO5~`IyE`LR1v5IEh+>x;Uz$x
zO#-n%UIY)KL1vM8APE$7L}HNvNRc6k-~$neqeKw_1WKsW;Q_?R!^p+X2U<0X8bIKY
zpQ_lHVl7Y=3@YF4^tA0YV~VwGp<<Ajw~LM`*NfE#NoZI>Wk3l5Ca!4@6$CA0O)R#H
ziPqDKi3N+QpoBlDR{;-y&`K0g_(SfK1Z^}amP=s-9pO{MQo{(22WHUy*R`P2*g$vR
zfzQFJWvgLLVU}bl@`BI{K)3NR<}szPg3i9GVNGF^WB}chC&^I5UIS{Bu?90}awLi{
zGB7|EBPS|=`g=L43K&TpwA3OmT_K^kC^-Q#MGY!!z)1?4BZ|TIfh(lt=j4EH1p;Ll
z&{?_26UZPfppaCsRRAq6(u0Jc6_^bQGlghyAQ^&seI-SSMzIK+LNZ{E0viB6RRBD7
z1+JUH1spVCr9hT3f$UF6umTxdoR9#@pYS}LkN~l#I5r_c0W@w0>cyri<b&5aCFa1@
zRat`l2d-@ua!ZR#6p~Uw{Zw_36KtW52U`GjcyX*cXy_m}u>_oUZ?S+R!8IkMdIz@v
zKp9t)4Kz#z>iFgrd4f_js0z8o30~BYl9^m`ix)IZUYrU!%dWTx)DqC-C<68JZ!s4a
zB|~yWAV_B~Xvl%NC>7e^0GAlxv<@b~B?4%<_gYYb2e)jwK?lZwt~~{9@{nSz5<qxT
z4_r~A)N!D47gW!IO9jy37d4E<9N^Jm&<-A^8b)zYIlxrIl*Lq}RKncM(8LIu{R(CP
zt#AT4;TB_sCTmd+$f+QA++r;*NKGz=G@-!F1IWq0x46MkUmOpTE}9Qg4$=(?H?S{`
zGBGe51o;9~+k*~=2W?bgV`O8jl0fnSO1NQ+=7GvMuusCk!=9iiFK8nXoToBDGsvL3
zCqX-$jKFz|xdwCwB6uHD77O?sL^sfVm^F+wY*{SL%uS3np!q$vEEXGvLOIYFpC)sa
z6f`sCp=2X)<W>oJLR*$#E;#X4iMo^)<Ya=XW@HVTtVP>EO(sy%0Czu%K;Z{&W@)m6
zlR^<_@b(rfq^|=iCvUNU+6hJFppj~(RP-4;(1dJJaVli#%qdVvf-7QX&^8~?@t!=4
zT%Z%l7^}pP!V{b#AX-pLD^N)V!r;&>fre%YV>1)DE6B8vp_Va^ql6h0!nKT<p!-BY
zVd@pbRLfG!3Z1!ks$ng*DpV<9fgJi!!?J)CboOKoOAT`wLs3i#OA0fn4rv0NH3<r3
z)*7aTpz{zxVXXo_-hrh`5gOJCxrqg!nJwgk3mnA7epRYq|3HeVVt7UdRmPzHMV<mg
zU6lwT8o(mp$kAjk+6YRF>L3DKn^b~W;79>?FVBI7SlPhwaf=1K+87cOxrqhE;0P)@
z4T?q7#0=Wz2a1Z^#DeRfhyW#U2GEQ)d_Eg=A2Db+9~3zvpk1$s<}f5mauW+QnIYK&
zWVW9sV~8e`pPwcp3<*KnAE2Ef==ZpQn%&^`F66*baCHi*6^mwr>dZqR;xNe3;PbM<
zsScF+ia=g1x(Jd0*@&<kJYEa#(4~Vs16q3q+Gxwg$-%+F%*D^a#l_3Q$n>9ulZlZ>
zn2C{#gNc!chlvra1ErA%YI(!6DCEpDSYZR+(gG@K7(rbZNe1XvMJrG<djU%gV+unG
z6KF~lbo=5$M(DUGs~>nfANahkDwf<7Q(H|&u!tsW5y&2Jj=IHBT9gA0Q}FS*x424+
zazJB8Ma8L_Ohs~_;uUnMS8-|znvZXZ#22OJ=9i_$=cbs(rxhipgT^dggMt8DL@|Qy
zY68tsN-!2(MIW#R<sDGj3eG>E-Z^Nf3%aKbG;#>KauTwvkP)<Q1=Ipqzzn+eHio&D
z1(b(MSZY{7`K6h$z%B(;kF!;^fNL)3g2Oz}vL*03Sx~kBml2RgYa(K!IcRhrv<4A$
zKsQ(~sL}*qo(<9i;)JCZffn*Aq=B~f>VSp`q3aTLK(i8{JKhxXOEOZ6$}@{oAuV5&
z2n98MLB0efu3}InR>QD>0eK+OuZjb@3(g8Qs0bRb(PRV{V(0<RpIHpwGzaq0Pf%Ec
z5)A`r&kxif$l8C9*AOcZ(DZ@RK+!JHmK9C5BG5QwQ57gzXMhS$PEd;gGLu&d%Ict8
zuE_?;#n(UzcwrWSoKOsLD0tRx2PoqpvIZzq-x7j57}Nm(Zxj6jay7Vd&dR|ADslxF
zi*AC_2WTh*8G{@K;up_iWMDu&!UKG{2y+T^3UexJ3Uex38f2RQV-$NTM@lewI0rN+
z!wDVG;Y#IB0biih%oxQ3JwJ*!g)fD_g&~SBMIc46g&~R`Je0!_B>)-5i4p`4;4nl9
zfroAwqJ&eqQ>0R)!2>)ZsoW_tDY9U;Xo_5ld<#RASSojlLW&|-Ogxo4MJYuY%$7)%
zOi@Wu1+%46)Kb)27^0+8LQ*tSv|1RWWKy(KbXpjqWK(og^ja9A<Wlrg3|bhX<WoXZ
zj8cqS7^4(YOj1l+7@`zY%u>u-7^0L?EK)367^0L@tWvC77@}0#K?`ziQfyl|qEu7W
zQq@!Jnwcgr7Mnz?rgEf&rP!x9fCrv5QXEs9S{R}<Q=C&=S{S0VQo>VQQ`}k@qqI}p
zQ#@K2qI6OsQan?<S{S2rQ@m4rS{S1AQhZbVS{S1AQ~Xl`S{R}XQn^zCQ-Z*LF>GgG
zVTdvcX3&fTZxpIB4KGS80L|$oCW9|U%P&$W$S+CFE6GgEK`hLHR8ZympiL#<>H;(#
z?UxK{{e$8fgh6ajss@)0pe}d`Lk)8QM+##z=tK<08kQ7>QpO^M5+=~BV+}(*sExu9
z&r-t%8qxv}bg_Zfr^U0^FcsL9aMUowb3zBUZn1~vW#{FW=V@{kfhz4HJy4PbCG%Sx
zu!LF^3K9cPnt%$wq7qQf=mz!cIpbkRL1=P-PtF9Fj*xBBV1q!rypXhmb)x16@R9AT
zTnr4w;I=3WXsH%tcnjQ;69sL>fpr8C16-g6C@5e+7<7m$C}V&eSX{@zz>va_&X~d|
z!Vtp(Is~|uy_Tbd0bE-!fzLf<s^zTV1a*~4K!;ezm9Ri~k_@#BC9I%P!dk8xuA;aa
zF3>Uu(6X--)`ctxvp^e+YnaoRYFKMPfy$A>HixB#1vGrKfE_$^!|n&Z5)#}lyTx3V
zT6BvQJf>R&Iw4+@1roxj0i(%*H1QA!3SRJ5BSDn2C_pz?-vZqq7w_lj>k4j3+~SWf
zN(GJQz@kc%8{F=IL<4w70C?3uXn_DWdy7Iqc7gjFXt4s?Lm&i-70_AK3`|1cH3U51
z#t3Lf01q=0Bg=m#P=)r7g^B53l@v-mflD^nCUuPRA5;f`Q!*$PYY1Pk^N@*wK^f#0
zP!?cdtdc>o3oQgNYy;J+VB5fb70`+E3|XKNP^J>*8ip(uP!7ssEsz0^in0}`q%fwj
z1v3=A1C1cC-{J!|15#kY3rYH*wL;+f8xqWj+<|QnF@}+WK@H@1P-Vx!3~B*@cGhz+
za{Q_iLGegNVsS=tZUKe|K)wch08~SOhBULli@Kl_hPPNi`iel-6k)L+v}_clAU@s@
z<Oq;i42)IixeB5JrJDy*3Bq8TL9G|i-~;H0m~2>ttz-n-3cW+1C>2ylpr)c*Z1M3q
zCGqhlNLCA@_!%Nkq{WP|L-C%1QtdMkfyKVm_;_=C_NB(h6KNl4r?f1n!pCP{dP#h|
z6(0LQ@<iIlN{s)~Q{&@p@!5yXf1nl@I3htU5YTFD(3o8_Q?UT3-(CYgLo|yin<<!~
z2(+P3lNr*(nGW(hIAP%k>(s*dcn6SMKzWRTk%x(eu?jtYL27XOAC#m)1!^`E4=h<h
zns_*D%u9`rcLUi7N}8Y{d9>67l1IrvAa$VH6YP5v&<qpm$-#P%xp`0+fT{!*(6u6<
znGeL$Qkc6mS#Gh!XQx&cfk$7#wHv6AE=s{n_u$opz946U{KvoqT9*Yn1H4KA#ktw3
zl_+inm5b;x#Q@rGTP#)rF0nvmRXnKF0-bHa<adi7GPVIPo;0Bs<AU~;L-zH*17#8{
z#X`{|CI*I3kPE?4#{@cIyh<9yb*LpDibFx=HmJr02P)|D2vGf+#Z=1(DN;ehk>E{;
zGN48VD5({zfmkK13)nz2!k~I`0S9Q1ej#Xw6z2l28s;o+@Ck%GpgDg~U0T8mIy@hw
zOOwSf(T<UU0o)w{jTeHjdUZijK4=>Uc$sLef<`s830|uSUeA}53Ys^BctHWQ(L*68
zH9ax85^|&{$OI71%g<8?a1Br}F)=`ufEuQ!5Sd@9kegVk09rS%ke`yGkd&H{Se6Oi
zf{~(747$$-ysjG3(*c<Y!k&5HLB!1DQqXl|nI#Ia6G}lEKqn{_D}ZiN1RblCr(mFG
zpr_yoIiVD!8H6*7LD!pur@T`@ds6Zhax>G55=&A++hL$C2CvEi-5Hhx+3f++2f|Rd
zLw9F_L_oM`FDRLU7I|v&A)Wi62+HE%;S6v}DFi73Z9{}il!FevM4IIRo!xkgr7W?i
zxJVSV5P=2U<h#Y>6LyO;vp60S!jSVC(aL4$Nth57u*x(Bl>9&|&OtMp;2}s3(5_iN
zc9x$koK=b_i4nY^0crzGKSq*-=X1~jqG%_C2f^|=Xx9m7p#u2ebT8221yCzsA!995
z3gm(w7SPpJwag`Kkee|<6UE5ubTpa#s!V)AyIJ$n71W`<VJmfoj8xD?nV?Z+{rn<@
z>RRw}J=iWqD~0M>P4=SOpxg*5K5p@Vug8E!)h#(N57zz%trE+KPs=X?wf+in5-V?U
z1bDm0gDwp&0!0CMq!c#C25v`!*Q<breIaEhIPgIwJ-7@g0|hf^%m-Eufd-Lyn3(=E
zF|qw)Vdi2&Ylc7_g%Y};k_jHVpo31(LRSkBx}XqU2-;Q15D&eJ0@QE_1}(3vgJ)q!
z_~2YcNl_vwQG+JVK;v(qVFnGzNfMe0(D8fFAPQtb8Ym@$7DIvtHBoj*f>w)xR*Qmi
zJ!q5yv{Fz3JbsMGnVKxO#Nv@tReXF(YC(K%Vga~Fzr_dYi<hJpL5J9H@x?<nu)q{y
zDMoK`z>H`Gg)+FbXM>dXVi>I~s5vMB3o1oH<4)j`v<N(C3SObW0GcRsVTg?bCDmHc
zDgI2L14(O{YoME@z>BXz1E;L{E}(&*X2t@S64n~lW=0+c(1xWVzjOw0B4%o4EQm;9
z1e?KL!vtDJy?_IBi4P+~As?vmt;t-q1RgQap(0T96oA4qKMfL!;ECgu)PmGJ(6;2v
zRPY6fMVX)h)-<^0)V#9HqWnBibSdN}7G<XvK`!}9%gh0tga@A3%L5$^i!cVR7j(-=
zE@<l#$W~AcLJdGfpC5R5Mw1gV%?Ap&BJdKZ>!3_k11iUAK|~dZ5CD~9po<DL*>5qW
z<Q92>#_TvjOX$IAq6j<_2p*yF0m<;BC1&On$3v_{&qLpt7#JpkVi&aJl7U@_5j0Z*
z+D6X7$nlSf1=OJDVG?0Pt36TE5=xwd;u}=!g5w-C&<DD<0DOCc5$J+m(AoB&`x}};
z!{c%>pe6P!HJ}w@%;2~KtyN(Gty*PdD3mJXr~xg+0N>=m1I;bq8yl*)A&~{<XtEZ8
zhNy4xq7*Yl@IWdm29@TJ+Xsq%fr1k}Ed>fRNJxPT6fglURemrrFf0d!2sphng1R$e
zj8YgOfSP+i+ELnppkM%<L<bHA&`}(qa-x<Alx%C5L04ETU;>SRE@T4lv;zf(T`fzM
z7(}iFG!MWCy6K0JA)KL50enhA45Sn)VNGEM?G6B~ZUN2fM=}&D7%&tnK<5V>d@_qm
zK*bDnSp_J$7DKn&f#&KUD=R=-ii`3=!<z}<BvYIKo>43<PEGLxr;sXn)nf1-(!6|y
z;?m>{NIp?WOHC{(ElO2TEz)Ew`Uwh4P%?xpQ3oeY@M+PY*=yLb$Dk=MaH!v6Nl7gz
zhIGk6p#`=EGLjCO=w1g3aqvL~pu;5?g%~*)nHa?wc|fZ^|MM`T_32=V0VT*mjZ1hj
z4jL1v5&#7{bV`{ioFPvHbZJnf3M3#S!J8-y7-~SftC%ovYyo9c@aj;=W-|rIdQn(4
z2Ce|X1H_52qqGs3xk@NH8NBKjl<!kgOHz|dVl|nI?tlVpBPjD$gNRKa0xc-MFflOf
z0R;s(@v$(m2(a)laxhhCBbV%YC@CGILd6IaP{4pz$rXcUDnKLBpu)CD0h|>X!KWK?
zff}^nUGgHJMk%!OT?9V#?;|MtKrcf9=N!;<8zlC?jt6I&zf24aXF=`;Wqr`y7krFp
zgC;0$Mkz5s&I4g^RsmJzU?+kPX|DxM2{1x7*Fw9Gn#@HY%Zk2&0uwZh3|k-qo^}E^
z7{JZ~6JWP}W@2Etgm4=;JS8#16WTIxLz(si^#wo}>^9IODrmPzDMJw-s80Y{Tvo$a
z13tM5w0#F8TFOuq1nDV&7K4B;l>;3z2|hJ~xdya0pRJ6c$f|@Lv?h;{q0kD{N!4Vj
zvV-m+0cXw3q*BnTa?su#$PNg|dcZsd@M)R}3K}V?X^EvdCAP3_YnpyVGK>rizr;XO
z_27*@@z8A+kTQ}3vU(QWl#&IdJJ7}u$N&#GG(pR1!8>PQEibT2Pz(7Mb3t}GT6Evy
zNK7utEK4j&y#WeW@X#g`Xb&nMcuy*bM9Z)+^(YY!>b=4P7qp%XvZf6*00bTgVgmID
zvzQB{N?6jE#X$X5hAh@16VQYhXw4IJ6(6XIV6Jk2Zu~0;ZE(kEK&cliKrV(TN&%ln
z0nWXkpi(H#0B6*s)G993VqMi@-GWNhV({T}nrubYpxPGP7Y3&*@K9JbDD*&sv9NW1
z6F~yt)CMNNNe*<O-(yhFfQQAHK$~tj{;{#Lfz~CVj!uD&q6RqxC15}eQh1I4triEB
zW1x-YHK2u!44|Svm;uyj25o-?Wmr(N9kf_cL$z2FI*EsW;om!u;~;sJjggNDEw<u8
zNBS3`tw03D7QA=`O;%P3fMO|yF@>R-8NB;Vj0JRC5p)Y{3PUX;WZzp2V}Ty%gdR}6
zmBmy8UY7|v8qg2ifUgpaE`^NI!;YYgtzuOz2HpM1Tm)Ve2A+Ec#R4qE!I1$DY%n1M
ziY3q#?-!7#ctC^ZjGzz)&F_N_P)5z_@sPEZAm4ygf-r~;4{ng*pi{v>UHKxR5=PLB
zeiNt|V#or`?n5dIN0(GkZx6JkDJMsvG_NQ%IX^uQbj`6sL1|J>X0ifkB@8GRr-Iv-
zdhlukHlt7kYM*JcfTv)=4RnZKK~)6In}<Lp9N33o0_4qG-0`4t6l8dO{2!2a!Ep$_
z9iU1A&7<j%b@OP^2ufQZO&||L&v^kIeg-PBnwdb$Gn*MfZFKNvZ-y*ZkO*j-cr&9D
z11Pm=GGm^42g<{sMpiM%i8Y}8V2t1pWLU^pj5za-F&MPD8su$1O-8W4p(m~sVex1Y
z=)@IPZrCw*;8sADI+_PlGK=El5tE*X<L=lXt!NEU>zB2-v>>$zJY#i>Jw6_+2T~J*
zdpsHN+zWDi5i2tT0~5$vaK;5EBMwH6|7`!6{-bpyVMc*;U{o2P)*q;hC<e_hfHE&6
z9YHrTF)n1RVM=4pgszK)Rcx$~qm4kjUXbQXK+_zWERcB*a8ZMp@&G3bFadTu=-@tn
zklVp+2PPIqq5rrhFF>=!7^MzMHURDC0A=qi@Wqr_EX_<sO5jNZ(6zPTEL_W&Cy)YK
z28kq60zP;hv>ri|xyl||Bqu5)Bp|g$6B0lpLnR8}{tzg8WMmej^maj~T_>01R93O6
z7TemY7K4^y+kzOH9FUP)(C8l0D33fS|AWd0#HuT37P`d(UR?zaA}|3CCo4t<1~E`L
zfl4z5CILnvCIKe24o+fmJhY7oYCvPeFDS)>n*^W(8o<pJ(4}<XZKL2bI@F+RrkK*0
z(ikBZ9@j8~#%4h4#Hwte0Rw7bCV-+L0eKx1sPUcvUXYUjT60j8m|2{v06Fm-e1w=E
zbp01(eUE}_kpifd2|j6Dles7o6d2&ev!Lb2u-Y87a0)zQS9BJ$P$>#$U|^6(1PJJO
z2_eQRS(Mxco`wU@<;H^-1Y<NZL4gSl5|CY0psPq3YC&yoEf!FvU;=4#gBC2;Ff3pJ
z6|OZ53z=9z8^sVqDU2yhrHn;hHB1XwYZx;bK$q)+Tj$J0Z$M+)0!a3Qn>Bu*b%pUr
zqa5HRHjpJd;ARbI?<}l+2y)jgHmG87Y5)^5pa266si}cN0K7tsiHVU5a*N@A0cOxC
zVQ5WR(7h)Rr{pFUprj2@p$fv_fB-d%AZcSEBdEs*$`(a$L9J<~B9MiUZj(5?075ti
z6p2P4=YX;#1A5v-SP!~H1ZB-1DCff?!ibT9p@yjdJR<;V-xmvknwlk`4I<!`wOOF!
zds!AT*0O>It6RXk&znIPU$TPs^13j@*2FM@rk86tYCzX~$JH<wg)uS|zA4<n2<|!+
z+SG7>cl_FbF8eNF&t@vJsbMbessYW+vqNqnEMovIp$FMp!&t(R#azlzGzWGA1Ng>T
zcF=evBSQ__0<Ic%(244xgi`pX&<3vl3|u{P(LIo!6z~`(BSRin4dViC&|m_@Jyjw#
zYzug5SZdf)Sj9p6lsUs0@}yW8N_ZzQR!V`)Wn_qCn7~-57s*ig#(<%Qt%lPUv|kZK
za@MjJz5%&YlP&QH69WUZH4eTB2sYIVYL0_;$0n9!AQtL+rYS%#^|1w?LkVx2qn-bx
ztKgXizm^MR66{o@Owe$8NrpmVUS)YkYEi0=LQ1{@^q6o&ml8BKsH@<bQ=DoAA5{X0
zDJXyq&MZ*}jYfg?{(%N*6+i=y1&KwVvz1a{ClP`yg*qQ~J^*A+W?pe>QHeqpXw`2b
zXtWnp41o$Lh$*NJ0a*%mib7&a3TS*2q%buv1*8YmWk#q*3LVf5sHkoSyBs-iVL<|Q
zB|JzJG(bfh=p1|0Jz)x<0x}~rJtMV9p`a);zbLb$5>&Z>)`As-CMiJv2VLt@jIM7G
z1~F!wfLGgrMhp}4Diw0_%Rv|2z<dcRe=<|ira@5SB@=w|B`9jrit_VHFe3+hOAfqt
z4OA+EkIE4N4bc{ffM!*j84JW}kk8o0e>6w{H|(q&EtHxBlG5Vy^N?C@ps{h#{&PFf
z><mK@=+qTWK1lZztvLibsqYqNYF=q>Drm+CvSgtFREC2Nr?@4SoRONG4Vy!WPtMOv
z%gIbGDN+EHvPVJ6rh+O!P?rLBDKe<1dy6?IKe^~CXweT#UQT}UEtaH|%%WSYd7#u>
zG#R7?bX>qKrabgT#zmmsv>B+Z290$xh=9&kU;%HT1YL6sI%<)Pg@aLu8MMs{v;`Hk
z&5{k=UT0zCW8z|DVPRqv0WCvj;$dQAsuIH<R4BbeP~#HRf(KVJperCj4a^kAY^EYU
zP+t&q^cZNG0(6K8_)t&q1|jem3Un2z3qx!HXn|!3TNZm6W3dtF%Jnh^5M9Di#!wVg
zXau?n1GFT$(5QqHqzbfWH-#14(POD$De8k90I`4zRQMJf)v$oC9%o(1SkzZ&RKlGC
znp^_g3hK6lMnMXVKrYi{_q)Ya3_qQ}=s)OaU*3}Zf_U&2A<zZAn#{L&Q7%L&5@2Rv
zxW!ToIu~~dBLhQ~C*%Y#1=V7Oa?sQ#<cvE7$S_H23S`ZvYB6L}glaLU(1T2uCZ<3q
z8{uOnJm8sZ@YOg)pye}=fhExHbV$+zr6|Y|V&H=~z@1UhYRy}`nZ?DWso+_=%)E5y
zQ0Fb?yyAi)Zjf`?bMsR`?Ydh`X?bWvCq-P$3=CDE^a2{8WMJfCVqp>hFGLq&Wcv@=
z9|juu6k-%&<O1`+*Jp!zAIc~xBN=NlM@c52jvl-%0A3paZj^yWl=D<rK#el!>HyGQ
zCvf+VQJeu3S&`slO$->o8&_HUssuvwK!e>S;K~IwKjjvp$pY@XgXijsgqax_ie`ZF
z7Pv<RZpMHK8IV{!BLl+(kbhwvb5PStfRTd{t-lJoJP|qshvE%TQyb(BaCZuHC<%DB
zhY7T-7QEXUG-t$E13RjWshJrxvtGzk!?*x+a1=upm=Br+1<k<MFoI^^L4yxf4$k=n
zpvnTR^PvMemZZ2Ov!oPs11D(r3#jl-&PdElPfbzCPOU7@FG^7WZTG9PL7t?C4PGb|
z!0)+GD1hD~kEr$$N8kE^ml0~Rg15RrCM&?{3p4;w1X`K`Yr2DyNfG#jek|Q&@MZ9M
zsWU*~3u^m;wu$gCih+iigizB9=tfkOa0Mj~Q1cR8ih!D`py`Mf@c0s_zYprDVAc<y
zwk^1R08MOz>jxfi{lJ1+FMwiS6LOUOEoRU@OppL1BY@Kc=qR;C@ah4zTMwC!z*aYC
zGD4;tu%$B4G{XW=D1f}gz=XC=2Vy38s{q&)noNFfV4feCWsG&_0C<2IJlY4YUO>B)
zi@+NMK#K>9K&$p3_wRz25P_PEMbAO?#0wDd5=6WL5wAhS8xR3rR|oF8egbhp<4h3$
zfUoTZ&BGOerk;vGvmr&Gc>qXp1RA|AVgzL|(4Zn@7XxUptB46C1{!?;pILZ|4Z2$#
zGzw4z>f(aCb&!q*s6PR&sKBL95hzO*iG#F*g6$S>d_4G)t>o04ocMTf06_@w*a$en
zvKbf{7(v5LpnXlCN{xjXw0@Q8FBdNpBaZ+FGZP~h7xackW)5Z!HV$?sMlKL$<B(!v
z<l<vu<l<&x<Pzmz=i=iK<Y47s<KpJv=3wLC;9%q7<Y598d^~I%oE+?2JRB@sE*xSU
z92^`>jNow_(A))RoDPmbkqoMC!B@^B7K($$tfH79#nvrh*YtGHyfpA>?64KKC>a1`
z2nd5S0BGh3)K>%T<Edc;T`ph45YGsnKxRz*h`c^00CJHd=m4kUlEj>x)D-ZEESbfi
z5+kQrK_gW!T~8seG`FA<)H*Fr&Mc_ZM6~T7_x+X@gO10{Q^?OrQ2?Kn2QB#^r>+*~
z!<+ae8K6@Rp|T)TlR(qX$%%QOQ*9J-6Z6tR4k*t^g&e60YRM<(=Yb9rfGn(m4fH_W
zrK4b|XK1KrpqG+bW}t0kY-E|52wHUmw+~4=9xAP=rx22nT8wsPGi1>Zs9BzbSfB%4
zkp#OY6>e%uetBMTNl|KIE-0*!3np-91vLbaeV>>OJ~RrPe-(;LQbEhjQxr;yDnXr&
z^wbj2ws3gKn+LwR2;2aG+YD;`!pB}gfdT3nrRJo8?`TU+1ov1#YCuw;8XM7b(PSzD
zXFbrW7T9nSS1x=p8YG8+%QbKg0hI^KKm`z}u43Q;<q<Z<DrGE*5Oi)Lcr*nXtA3g+
z=;aT{FeD2Qwn#HGFf0Yx0!p|Xj71<mM(zL=(%{?y8l*?$jwt37rYM$F&?+_Ng^-OC
zEGewurTv_#9N;Y!ptCHvpj#-oQ@DZ|G`VkqSMj1}q^dA*2ot{n0IVFb2|z~yap9Ok
zaY<zkbTiE@4qw+0M;FHs$0})!=ok&1SnxjMm=rxN@K$7vXq_0%SWS$43<`8`J_a=q
z&{pr*L3;i*;M?u9m?2H#EY<~V3mHJSL@osFF#uP4Yz&bM!3@x|^_Z$8pgZmIQWTOC
zlQUA`mwNhXa@^vK2enc`<1diGd(dUZ;3>&ltf{$)nK`#0Td0a|v4Kq~y2Sy`8^t9>
z(6j`u{*mGsl!$H#z*aoM3_k#hYjDGf8M5w%2XqCnDkuk`M~NP~UX(xr)%Nf}G5`&x
zfro{lM+PufA}w)R2wo%#>Qlf21ina=`Ia1bjS;%#Xlso`<3XLd(vnor`XTtD8f*)=
z!8PD1kS`(47l<#ppreoI*64xE11)Jn@f&Ed45&{8O83Q}P4S=u7BfM|BZH$houLyH
zy^IT(Ks}-Yg>=v<Jwmlipkqcs=lwxfn<#;|)i9^9w15u2Wd$9=3_4!47PQxn5w!mf
za$_`Tz2^cZ(4~L{SzwbiYFSIzYFI(5KEZ=$9N<#}SwVVhSR@#l89`fTZ5Rr3z-w99
zs<eYrp@D<66azF<l$oEWUaSCF*pix;4C>tbRq;Xx&Wm+HagO3`P!Ry~Hu(H|P%E(m
z<T3CuMOh3*a-hZRpj!`X7%~|bG8VBw4<cd#cf^?dz>9{8yg~Z_m>_J>9^{pbNK0bC
zNs_N9wXhhxTn}6b-v&h$sPhS0)hNbT<pgpTW;8*42#PLv^dp*ds76-t1r+6j?td-T
zbp@@L)8s5t1+`67z&$C@U}s`ZP7!#W322h(7H3*fepPB-acW5sc*zN9zZ!VHN0S}A
zViUaD1hS)A17rjn=y0X{Jg_Hku@^(uzd>@II>;W7H;dGm85k~s{03?WFfj2ku`r1+
z3NZ1og3cEeVdP<yVyXfUV-V+8KTRI=G99$O3S2@UHl5yLaSe10gtQ_-z6ECnuu~w;
z1DE??0_;XvW(I~GAUA?q>l}<MEG&#%prL9`P*bZ2B&*3>v>w#9Oac+0dxTKx23SuD
zH26^r8h{4%q)Hf?8EToU<iMi_ObZ#am}@|Tv}&Nk%*`2UnF@Kr8S;d{3y`cJ1u0}w
z7jp1;3KK}3I722Qq-O;``~p0LQ*;TGyx5CC%T6Hc4<3PfgpWZ4$PtLex0)<Ppp#UJ
zK*_jhKgji<G72dazySd2XnuqR00ScnBO4<VvjAxD1ax5|NEXGvpynbdlYr|&5tOr_
zP+E$j&^!j3=>eD4;As|=yap;hLB$KWjsca&psVIVMFD6`A9QpXc<C_{_`ouVPq1}T
zK+X35Aoqh@#lTo4i`8Pic*qnrmUaQi0Hi=cBn>@g28MqylQ|fRKztMrfE*86js^;#
zVo-mk1iF5pnGw{1b76?h0xc1)0Ue902U^ck!vtEOwvZ9D#~3tu0NsCF0Fp~#0f~ZU
zhHIIs1ZtQd7i5`3=6gVk0N5(?U}=RBI+y@CLKnQm2z&{vCTmp}<Rmoo$w5dz267A#
z__9FI9A0KxW^y8ANlczX0_apT=&2kKHhhyi?A$c)cHKk;4cMiqx{$k2H4&SHLA!WU
z^V1*=zA7dKWxrpHF)#o9|Nmc;qX@Jy7IFr`CQxDppZf<cXF%I#Z}A3~<QI6BfCeBl
z^Ye;8eIiZfqRpUW3tohTZGjZ1=wjw!U?>I`Fl;>F>&t|gxEKY%lgyyC3gCr`pa=pb
zTsQ{B9Eej4+Fu82&4KGG#uTO&4p4t5g{6fdiX{bfXgfm`YYKY`M+-v~TMB0iR|`WF
zJNRTXhA56yPRQA2&5Ti8;H{k8!3>)GVArEe=7EX{P-P6VxcD5XsUQMPEKH!YU_t8@
z!x{2SSQtu}vskiND?Q++4Y5HY8MG=9eA*CWE#$NzFbz6wsD>d6ygRc5G!n(p%m^BU
ztYKcjy^w(k)ac-;VTk92&P6d~@qvaRY8c}AO9V;;ON43|vV=j)hHDt&g=-kHcxxE4
zL~0na_)0{<GN2tKVny3PcM@fZHG|H8VN3%ZaVB0OQNxfW4q8bRFA1LCVX3ln@mKKk
z4^eP-^zl&$@$d{*2=#OEcMkP+^$T%zQSfyQ@$h%CRsdbhfs{ibhlOZpDq;?cfPxG>
zECO1+1|Aj>0Ocz11>}rrOh~89YcdrjfQF($y?^KkNf8^U76RvGFaa*=KqDl|pyUE7
zD%cpSG>{z<AD@|*S%R|k0X~4PDOJP*G7pp}!JAJZ6Xp7#r4X>QIFQT&mlTktLZG#M
zx4295z`Ze0UkI{e7Q71xJi87Wz_`T;&5fx=MJGWCeg}vEH3%S;F?c|MxwI&!NDJf&
z@cLtR(EdB;+=8OVpxxv`@krLk$AjdcLtVFokfz*0WngArI`|GO$lgxyXapjJK;tn|
zpb!GpE}+H#B8)<eO5j6!g&5fwS^je{fv$N1Enwzg6#C7^UL}HLF=DSRD1brv3xq*z
zP_hRX^Pr3hn)U!4@{tcpYD_hZ&~0R(ZF8_~WZ-}{19=w9rmiB;@Q*&om7pMEVB%ur
z`d1}{>JI8{Au9rnGns;H19^mj5#1*6_A#&&$g>O#;G2CwX&3BYP>l=oZ;=AXub^#X
z*~~>!plnman8gfU@5ll=Yz&l1dqGQ~Sp3{VG#PJk7ZjyJPYN&AWP_~I0F4<z2G~J~
zy~qUA7UO_k0aFa?1%YN&kZLq=+81JEV6XuBf(ztK$W%NN8*7zB5agsdP(7^|51QL4
z0iETGWqlK<x(53R6zZU!3~Y%FW05&1rm$7cpb<P5kgebVVnk0Zpmd7GCU|OrGzv->
zKs&r(NAe*zETE-_YLRBq9#EFS<^<4*eD1iN06CHmrCJBM6@<Z_1ua>EI3NaGsUtiM
zs(dt=ioholf|~j0Ar3n7#0z9GC^3LiX_X*yScAK+m@QgR4g@D~aJnl3MOzUl6d_}j
z;89JG!9`M_AO~k$FagfT;D`og9Z8V2kOnP}C<hw{GY1c79Fd6;QZa#I5|j!+7{rEq
z7MeR5%0Pp43?&R{jN%N?Q&1SIyuiZ^&?$UKdjfvOFZ6z~+@gH&!OLKkph=DVoD^N~
zNQ44-Fcdbms>xU+$;`l@$#{z$DvlO-xA@`{bIKDdi{l{{1%NyRN_U`RbGaCcY?v7s
zFzQ!$R~)j;3e@-pogI|ISOPljjIo&+bn70d*#({AV6I^(1NG?`KofCH42%rH425#g
z17(e%tBJtJh$a?*_M$+qQw6X0PsmS70FQ|&Bow8lXBL+fRVIKZ82mI@!H&Ddo|y+K
z)Jtx$rKgtU7Ue@$BEAH*-C00qeM2-Aft*^@2`a)FOVGlg2y|CY6v*Qsk1;SwfluZK
zi(({KP!a<tS5T<{S}(nTsRn$`4X8N*T3rpg1(*>!`BY^HjYQ~C*q~D)(H1r2r@<CQ
zr&eSZmlT7FBMvY#K0h1e#{-}i9B7gka>F1ft=;0tP0UVB$t(huLkKBw@&ps$<Ow=#
zAqnIukdqmhco>U7A}AgLWq**D!5#uF4=-UT<^e6A1hs)cx92o7#xT_~f)7Fts$l{z
z3}<X+EDnOiGb2M4AE@!1!qm(Jo|gl4wAd;GV2$TICfF=om40wyUP@Aag>F)1L1HoJ
z)H?XMCukQF_%bHY;>J|)J;EBARa#2<#d^8fDVaq|pw%P_pldGkK^H!Qjz$MBkcLf9
z>1BepMT3qOmIjqfG9Us}mK1?6W2^!-S2#g4<NTo8<Xpjl4DKOmG8ZAj4!krG9Cly=
z9DpFL8K3}!tf~U-qyg;{22F7CG4e1Lf#gww6BN)O3~B@ygDwzFVXS3LXMpS*0`C|K
z12q{JFoH&Mief-Z>OgDjivnsGiw$a+imX6u@zcP!F@k2WQ&_?M6lTz%KFE~9v=SE3
z+%)Jo!9oG>Dl=wKbGA?bp$}BoX|g94Gcqs)7vyA?fG)8rDFQ9R$S=a^JSb%5mE<dE
z6sIPGx+Xf{<K<KHN;DM;5;KdSSGc(*CTA!lBtX?9B!DKQA-$A>g47h`NCb^TLzThy
zTWTmpLq%ehAWK+42LXb6MF|O@x->Pf1ZE_t2?$!_0Xn%5Y&7_|9);8j*v`SEoW#6r
z=uMM}d9Z7hzz0w3f-ZN1Na-nn7Ak>zN8mj{py^NW4j_neNvUc1;A_8971A<`ic1ur
z?gN*jpmjr_v+Y6G#;F&jLT|i-96AQN;Q^!`IVeDRH^DDIFBN`S+b_oGUyQMk(F4$J
z4^`rx(DUP<_JBhMH0jO;>7Rk-<H0u~L-zE7hZR8UJTzIr)g9>caB$?@VuuD7<oqIV
zA_WuRlnUBFRtid~pawhx2dL2q>XCsKY=C-bY)m{%Jj~#2W}u`As*J!Gmi<At7K1j9
zg37a6rYgA-rV@sDMsSJ7kjVfU8wm%Udd?6JI;#sTYrp^+ii2#mVTCOC1vMgWvF8`Z
z=NF{r-Qob<UJII-xW%5E4Z0WubO0KBnB*2meohKlA$nmf$Hc(U5AqBs6ElDYNkA8-
zFthz-VlD#76*Ys7aAUf~0Xl&%J-?{32ozu_84=_$P(}oM43v98rx;{1)G&dj&lwp&
z^I~9!gRRzNE&|;}3K{p<3o1Rp0ShKTp?ixv9(*ftVsU0l>LQTCKt?k#@-Y_qf+|N)
zy$%je&?F-R0|RJK6XXEs>hxxYPKFMK8io``8wSvpC2-%DDTTR(ql5``Ln)}62+GAN
zkgI=fgHuZsN(&UybMliCbHGOimlh?bg67H+(^HE;%ky$FlR$m<)SOC4$ykzDlB!#r
zSeBZid5a@HH!%;S5G6c7%?^;Wz+<gy;QOj#<v?A$1q><BRqiE>9Sk*$%}kKur;rI$
zkQ6b4nhs3h#qLGm>3z^t;!4J%Z=gB}9zaE)#qMiB0Rw6`fbMkX`d1|f?&M{H@9RJe
zox<0+`)M*4fi80^QUw_$35rq1B2W_^93@5mpf(pY@IjqLh&jtac7R*e%xsJtjC@RN
z|B3=YQ2+~m5Dj(%0|NuNP6O>ch1{D|%K%y@QUf~kmI;&sVBG=G*4r%BTF|)-Y_%*k
zEVZm9?4V<XKuZZgQ3G00Qo{@xoB$0?^fECrfV#->93`CKaRBZTo-AHa&z_N?gs+)l
z0e^`=GXpq6!8gbyy255(1By~XixI(dez}RopoR|UN)AxjT%1}0o=F5%>tOkW1ZZDU
zLo*=(TsAodcq$-m)dP!#fR>(vk0Q>@2i=ERtdLp(I+-%FL?JaTEj78M7*biL!ctQ)
zD5-$8f^Ia-PLBs2EDTCs#h^nDKt+3IUI}Q#8@wtq33PgDS$=kEib8%~a;ici<QN1{
zIS-E$$e>m}=myQqV(9VfdXUwno_S^Y&_S=HO31Nu3b0LGAgfCA5Oq4JT1d&ygG|LH
zg6Bmuixl$9^Aw6Qi?bnvT+oJW5$H%^jMNRvlAvxvF=(8+h9Oo6l)AGRQW#Pgdl|vQ
zc1)1=rW<&pncqrA@S+6R7zXGJNJz><P1R>XDGp>d_|jZMq%<85iNbhj6oRf{#FETW
z+zBcuKm`MMs0CD3g1UB~Wh=elJz#zzV5b!Yg3|sgP__WO1x$dlLXi^#1H&aA*s4SW
zq8*cyn46T6Xy>NMSmeeCx`9ZrC=+Bn7pQ5Z4Pt>@R0KMuyT~0R76K9jkBs~Uu~a}}
zplnsd2x5Vkm4RDMprH#$23`zW7S0Ba8puiGV8cL_O%d3zsUUN}J^>RT@7zKzA+Utz
zW>C<B_Mb5Daxn5Rf!1rVF|skSuyQal{o`O^0#ywE*jU(@gcys0&<g=jK>!MF@Yp%1
z$qXBLOko7gBZF24fsaM6S`E$(PKm{-kbV=m&rzOOln2U|iAkVc@t_4jsgQ&WS~a17
zc5!P0bR-v?8Nq!lP~rxyEJ#T$$}EE|=}Sm(fgb3dnV%O9u^=G<vS1>y7_vz@6LOA1
zS!Qu&QV#T{9PmC#NCxmL0`(e^k|{ha!G5^~3NTPf&%p@hLstkfx@jVipXTi%P!74p
z6(65g3fc=DA72F01DW3d_cd05B3T$z56%X$KwYMyFCdl&NDO?ed@G210MwUaFUU?W
zEy>J*3=4u5xq&XwVkkNSYH{;`=aL~q2Sr5+pmd!NGQ$(ZDg>Dk1mfC)xYt44D<A@t
zMT)?eh=KNj++xnmEhusZjlOV#E`$R&-HY--c5@eG7U;#7rRJsN7Zrgr=`B$t5xwHf
z3O&$qpT&@~L%|6cG}l@L>hTnDf>I=?E-3<?P*()*I)L(Ikq5{scIfp<kUj*cA#zI?
zvP3f{Gf6KuF*zeMFSV%h7AKrp^aA8|ageEdKm;h!6$ye^p!P=*`0RL4pA@uQ3ACaE
zoKoWBZ}C8vQN)8L<8Sc<mFAUX=B7e?xdmio4k(CnK?FFLf=a(4P{z6?057~jgN><)
zxkaE;$Zzq$ghAb@BGCCiMX4ZXB!Gx$5CP7caUfPKh=>Ofwjc|@x5a|iir(Ubx&xX}
z!6(WTfe$VMwH}JVg$Ag>SOi*_Sp?eqT4W0{2DD_O$Q~5;T=B)AxzD`(ywqD<@x{fd
zCGjA3Q4mOyJw84WyjTmokvtEiGap1O1rY@x0<;IeXf22ZK2!y<j;#?S)&wG&K|~9P
zm;@q1L4+@e01f&Vxr12Xqj5pEY82fBaY0?OqH+)mQ7D0Wz35BLT0u%cx356TN$^?1
zs-U>Y07*;(5unpRAPtyw5EpznBj{X4$S^W^<1MJ|Q3O8qq6ee|Gz?SJ3u5(wh&Lef
zx<IUM5b++w{RtxaL0nHzbhLw59U!6;L`(n?praUy+(EK_AR-(@B!Y+t5RnQZVn76F
z$Odw8JNPDbZqM8T$R4cJBJg^<qB@W&(B;sOyZJ!ZPl7j4gRj*CUl9kswGDjH8TeW)
z$PIO%o1(y1DS_`Hg7jg)ClrFtzP`mC<{ISWAMARI%hTP@KgiYDG1#@}0mvrM^)ZlB
z`9OQ#!OP;ntAD`rzD4&zN<b5!kQKS0=|AvnQW0p}A3Tx<9_j&)$bd&Nz<qCUhX&jw
zxWxxK#ROV#7lRw-ka=5B`w(0|++v3%X7GI&;Ib1zfNLZUn_Tc2^`NV^8H&#^GBB_R
zfKF8eoykKy=3!!D1Wmj1fln6WW8`AuVH9Boodh8QZnT2<0w6Wu!(>4`(4u;%`OGZL
za*P~I984_W335<R4i9D)VCP_GVdh}v;NW2AVBuipVBuilVdjwFFcM%FP!Ql1kQQKJ
zVFDlD1Ue0pk%gIqi-VU(fP;lYf(x{Go0&t8gNuckgPVhui<N_wPh3ETubu$}Sp`J+
z>KQ~>m<0s*>KRNqcsMvXcsM|3MDua+^VKsraxn{t2}pA=3kb3?3rGuy2-Gv^@-Pc%
z2}la?^DuL8aj|nr^DuL<a4~a8aVc;J@(FT?a`1C-bMWyn@i2lhGlvj|Jckm85*H5#
zFI)_ygO!7u2jnL%4h{}Jko%c9xxTUS@zpc1a&U6+Lfxn?AS_@ET4K)hmyMl+SAdm6
cOvIc6q=$`zmqUt!Ux0;!m5EURw02Vs0M_$d9{>OV

diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/pkg_resources/__pycache__/py31compat.cpython-39.pyc
deleted file mode 100644
index ab37be8e77928bd336e09a63cdc0f0c8da407f7e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 678
zcmYe~<>g{vU|^UdaWK`0iGkrUh=Yuo85kHG7#J9e6Brm6QW#Pga~Pr^G-DJan9mf&
zl){k0l*63M62-#EkiwC|lET`;7{!{(lEqfwlfstDl*P`%z|4@%nD3Fop3RWQ!o<MH
z5XF(oQ52TSn#YpLki{9rnZg*%pvn0XWVfFt<1Oam%nG+;CJ+~jK`sHg)fwa(F9rsN
zD!vki1&lQe3mF+1!Wr_+SQtu}DqR>EYMB@rs^n@Ii}Y%kvY1Plvskj3iwv3=!WkkN
zQW$EP>X`DlAhZF40YeHyFoPzepC;=qru^bt9Jz_vsVSL7#kbh~gI$Y?@{4Y<rWO_D
z<=<j+b&c>04$)-3#Zr)1l5vY8wIZ{)BtAd;7ISJv@=AsxZUzR1Umea?F`>n&Ma40x
zIVqV%G5&d}E=8GTsS3IZp?;oWu0g?`A&$Wco_;R=ey+iujxoWmzOKO`u0aZBF#!QS
zF^ML+Ir-_C#U+{9F{ycFF+Q0|F~ylBsk#M;$=QkNsl_n`nFadsWvO{7`9=B#+3E2`
zsm1xFMaikf`URE7hRON41&Jkk1(mmW;$dEiH#Xz|g&8RD7#Nut`55^a1sIEX85kHe
znO=f|^(704&0NICz`#(%&%nU&k`W}p=%&e41d=aeV_;yo#avuje2cpvvp^4Oe-S8p
zz~<ay4u~|m#Z#7ARGgWg7oVAzmVb*cFEur#819N9kR9MaLLzuT=5pBN=BJeAq}qWj
aEf!#4VBlcnVB}!pVdmmtW0d&E!~y_b$D>XF

diff --git a/env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py b/env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py
deleted file mode 100644
index a2d3007c..00000000
--- a/env/Lib/site-packages/pip/_vendor/pkg_resources/py31compat.py
+++ /dev/null
@@ -1,23 +0,0 @@
-import os
-import errno
-import sys
-
-from pip._vendor import six
-
-
-def _makedirs_31(path, exist_ok=False):
-    try:
-        os.makedirs(path)
-    except OSError as exc:
-        if not exist_ok or exc.errno != errno.EEXIST:
-            raise
-
-
-# rely on compatibility behavior until mode considerations
-#  and exists_ok considerations are disentangled.
-# See https://github.com/pypa/setuptools/pull/1083#issuecomment-315168663
-needs_makedirs = (
-    six.PY2 or
-    (3, 4) <= sys.version_info < (3, 4, 1)
-)
-makedirs = _makedirs_31 if needs_makedirs else os.makedirs
diff --git a/env/Lib/site-packages/pip/_vendor/progress/__init__.py b/env/Lib/site-packages/pip/_vendor/progress/__init__.py
deleted file mode 100644
index e434c257..00000000
--- a/env/Lib/site-packages/pip/_vendor/progress/__init__.py
+++ /dev/null
@@ -1,177 +0,0 @@
-# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com>
-#
-# Permission to use, copy, modify, and distribute this software for any
-# purpose with or without fee is hereby granted, provided that the above
-# copyright notice and this permission notice appear in all copies.
-#
-# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-
-from __future__ import division, print_function
-
-from collections import deque
-from datetime import timedelta
-from math import ceil
-from sys import stderr
-try:
-    from time import monotonic
-except ImportError:
-    from time import time as monotonic
-
-
-__version__ = '1.5'
-
-HIDE_CURSOR = '\x1b[?25l'
-SHOW_CURSOR = '\x1b[?25h'
-
-
-class Infinite(object):
-    file = stderr
-    sma_window = 10         # Simple Moving Average window
-    check_tty = True
-    hide_cursor = True
-
-    def __init__(self, message='', **kwargs):
-        self.index = 0
-        self.start_ts = monotonic()
-        self.avg = 0
-        self._avg_update_ts = self.start_ts
-        self._ts = self.start_ts
-        self._xput = deque(maxlen=self.sma_window)
-        for key, val in kwargs.items():
-            setattr(self, key, val)
-
-        self._width = 0
-        self.message = message
-
-        if self.file and self.is_tty():
-            if self.hide_cursor:
-                print(HIDE_CURSOR, end='', file=self.file)
-            print(self.message, end='', file=self.file)
-            self.file.flush()
-
-    def __getitem__(self, key):
-        if key.startswith('_'):
-            return None
-        return getattr(self, key, None)
-
-    @property
-    def elapsed(self):
-        return int(monotonic() - self.start_ts)
-
-    @property
-    def elapsed_td(self):
-        return timedelta(seconds=self.elapsed)
-
-    def update_avg(self, n, dt):
-        if n > 0:
-            xput_len = len(self._xput)
-            self._xput.append(dt / n)
-            now = monotonic()
-            # update when we're still filling _xput, then after every second
-            if (xput_len < self.sma_window or
-                    now - self._avg_update_ts > 1):
-                self.avg = sum(self._xput) / len(self._xput)
-                self._avg_update_ts = now
-
-    def update(self):
-        pass
-
-    def start(self):
-        pass
-
-    def clearln(self):
-        if self.file and self.is_tty():
-            print('\r\x1b[K', end='', file=self.file)
-
-    def write(self, s):
-        if self.file and self.is_tty():
-            line = self.message + s.ljust(self._width)
-            print('\r' + line, end='', file=self.file)
-            self._width = max(self._width, len(s))
-            self.file.flush()
-
-    def writeln(self, line):
-        if self.file and self.is_tty():
-            self.clearln()
-            print(line, end='', file=self.file)
-            self.file.flush()
-
-    def finish(self):
-        if self.file and self.is_tty():
-            print(file=self.file)
-            if self.hide_cursor:
-                print(SHOW_CURSOR, end='', file=self.file)
-
-    def is_tty(self):
-        return self.file.isatty() if self.check_tty else True
-
-    def next(self, n=1):
-        now = monotonic()
-        dt = now - self._ts
-        self.update_avg(n, dt)
-        self._ts = now
-        self.index = self.index + n
-        self.update()
-
-    def iter(self, it):
-        with self:
-            for x in it:
-                yield x
-                self.next()
-
-    def __enter__(self):
-        self.start()
-        return self
-
-    def __exit__(self, exc_type, exc_val, exc_tb):
-        self.finish()
-
-
-class Progress(Infinite):
-    def __init__(self, *args, **kwargs):
-        super(Progress, self).__init__(*args, **kwargs)
-        self.max = kwargs.get('max', 100)
-
-    @property
-    def eta(self):
-        return int(ceil(self.avg * self.remaining))
-
-    @property
-    def eta_td(self):
-        return timedelta(seconds=self.eta)
-
-    @property
-    def percent(self):
-        return self.progress * 100
-
-    @property
-    def progress(self):
-        return min(1, self.index / self.max)
-
-    @property
-    def remaining(self):
-        return max(self.max - self.index, 0)
-
-    def start(self):
-        self.update()
-
-    def goto(self, index):
-        incr = index - self.index
-        self.next(incr)
-
-    def iter(self, it):
-        try:
-            self.max = len(it)
-        except TypeError:
-            pass
-
-        with self:
-            for x in it:
-                yield x
-                self.next()
diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 59331d34d3f0a9b879d94dabfe954b129ee10bb6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5685
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
OA!ZgP7Dg6kfph@0L1cIU

diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/bar.cpython-39.pyc
deleted file mode 100644
index 4444a268fe93d187e8fe4761ddd5b1d14c129255..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/counter.cpython-39.pyc
deleted file mode 100644
index 801c1561f9475b6ca748f056260878c085e13375..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1501
zcmYe~<>g{vU|^UdaWFN8m4V?gh=Yt-7#J8F7#J9e6Brm6QW#Pga~N_NqZk<(QkYVh
zbC`0OqnLA9qF5Li+!<0>QdnCUQdm=&o0+3n-5FBYQrKG<QrJ^jnwg{6+!<0hQaD=}
zQaHhUc6Wvpt`zPTh7|5p_GacNjuf6?22I|VAiFggZwZv<WhUpRq{ioDmZTOX<`lnV
zWME*>WV*%SnU|KCmsyf}izA>YKfNfmxHuW42N^TL+$_Stz>vxi#hAhn#gxLB!qmbL
z#hk(%%%I6~i`_ZDG_NGJC>dlfOf!fL@~|_=!ywHy3=0@a7;6}^n3@?Ef;`O-%&?Nt
zPm}o;Yk3jK5zNIUMYmWp^HNePRx;jVDNfBvTggzw%fP_!tHIeSCbT%Us5mAyCnd8e
z#y>CBr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6*EKlAHAulMCLq8kCecJU
zCqF&2xFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_$-EHy7Bzev9T8W{S?5P#_v
zRNi7MEl5c$NfiV61{5X?j8%M4Z|gy%{8qBu;)svWOUzA;kH5tgAD^3_Qknx|^Tfv&
zmL}#vWQzD17$Cj^dksSHfyCGt7#Kuh=5sI>f%s&_2PfEJDf#7jq{m1RJ1A{17jb}G
z#L2+GaEr4jH8(LcFEcN_h#MpbiV!4MgS;aRb2S5Fl>ppwShy4kplSmf0QNB`SxCY3
zaxfNw__%#6fsz8Fm_fOwg&~S1g(a9lll2yBa7kivwkGE<Muk#l1_p*l(;A_46O?X-
z(k)QB6-u{3>2@gHff8&Wvsf7z7{CeHjDdlngrSBZi?Nxpma&AXhB1Xvf}w=Dh9Qfk
zhEar}nX#FvmZ^qe0V_yN4U;4TEU9ZU`4xeT(qy~EoRgY&i>)9du{gE(7ISW9-Yw?L
zypmfSuyh9wd`;#e9#HVJ=Rp-RW<o+85qzMaR{{keD5WqkaxqFUR`GyC0T%R{tVM#L
zz!w4$!XQEtM1V9R8HO+sl)U9ZCW3M<2O|qp5l93hN<euVT#$ic7EvgGq9m9>llc~N
zKxV2YD<m|hcSGqZP<kSio(iS={WMvyx)SUx1OZMlAjfHd90<yT9E?REzMm#1D7&SV
zmXsEy#>W?dq;4@3fxJ)zia2ma0;esoZ@_x6`TiD%4J6Cjfx@g9RF?BF3NQ<>3a|=r
F0suI8FOC2J

diff --git a/env/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/progress/__pycache__/spinner.cpython-39.pyc
deleted file mode 100644
index ba7ea893a261c2e9462a7a6c31be6a1b84b4a289..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1418
zcmYe~<>g{vU|^UdaWFN7m4V?gh=Yt-7#J8F7#J9ea~K#HQW#Pga~N_NqZk<(QkYVh
zbC`0OqnH^P+!<0>QdnCUQdm=&o0+3n+!<2XQrKG<QrJ^jnwg_m-5F9iQaD=}QaHhU
zHg|>;t`zPTh7@ivpWU4yg(ro#g&~C(%;!kq3ue&de+hDjCgUxE(!9*%{FK!AoXnEc
zqQsoymy8Sy44RC$I6U*xGV?M^Qj<X{kuej@)iMkW45<uJj42FJOeu^}%qdJ!EGf(>
zEG-OCtSPL)44Q1W*n<l)^YT)QG+BNz>i%Mk`NdfCi%~x$8Dt5}Optk?kZ=ZtgbD)#
zLk&X~LkVLILl#prqZmUiV-3RsW)QE2QIcUHD0CQt88jLFG+A!3X6B`&R@`FFNzJ>(
zR*;ccoLYQ~wY(^^Bvq5?7E5tzPTDQT%#{p90t^fczZ#saVnT~ki;81Xb5b&kV*K+`
zU5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(O
zi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9Bfit^KoQj3fAiy<MP
zS5SG2t+XH|u_RRz<WZ2185ji^tN5Tnqz94o(`38F5g(tIn420Oe~T+VJ~uz5GzY}y
ziH|QVP0WGF6!9=HFx=wK$V^F%PcAJg&MztwVqk#y6zp9HAqWy<Wnf?s1=-2Qz`(%4
z$im3NR0I;k9kU`xF`Lei!ng<=yTJ^a%(u7#GE<>0)?_JVW?*1=G<`di-Ug+&Lg_7j
zD_M$!K~4Y}SOjtd*xeAffg%OM0=rV2fq_8|<VsL_;9x8Q@yT)_w{L!a9=a1JLY*`T
zN>6~&ll_V$Kn_GW2FwDx2oz6BNG<~L$#aoUW*$7y*dR9d?fME1yuRH~dJj~5ZxJY8
z6-hHNFyL{U6axc;8j{;Ue6rle6OdVvnga_i4u~Tb?}O6Nm|eUc%AXIR7w(79i=g!4
z-4Ooby?C4~%fP^(h2&%q-%pbhl*ZFaOG=AU<Kv4!aes@U2$VU%Nfew4ia-Hh1oB}K
kNDm~<fTIaafa2;FhYcj3*nxP(pv=L;$ipnaDZm1P0KC*Jy#N3J

diff --git a/env/Lib/site-packages/pip/_vendor/progress/bar.py b/env/Lib/site-packages/pip/_vendor/progress/bar.py
deleted file mode 100644
index 8819efda..00000000
--- a/env/Lib/site-packages/pip/_vendor/progress/bar.py
+++ /dev/null
@@ -1,91 +0,0 @@
-# -*- coding: utf-8 -*-
-
-# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com>
-#
-# Permission to use, copy, modify, and distribute this software for any
-# purpose with or without fee is hereby granted, provided that the above
-# copyright notice and this permission notice appear in all copies.
-#
-# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-
-from __future__ import unicode_literals
-
-import sys
-
-from . import Progress
-
-
-class Bar(Progress):
-    width = 32
-    suffix = '%(index)d/%(max)d'
-    bar_prefix = ' |'
-    bar_suffix = '| '
-    empty_fill = ' '
-    fill = '#'
-
-    def update(self):
-        filled_length = int(self.width * self.progress)
-        empty_length = self.width - filled_length
-
-        message = self.message % self
-        bar = self.fill * filled_length
-        empty = self.empty_fill * empty_length
-        suffix = self.suffix % self
-        line = ''.join([message, self.bar_prefix, bar, empty, self.bar_suffix,
-                        suffix])
-        self.writeln(line)
-
-
-class ChargingBar(Bar):
-    suffix = '%(percent)d%%'
-    bar_prefix = ' '
-    bar_suffix = ' '
-    empty_fill = '∙'
-    fill = '█'
-
-
-class FillingSquaresBar(ChargingBar):
-    empty_fill = '▢'
-    fill = '▣'
-
-
-class FillingCirclesBar(ChargingBar):
-    empty_fill = '◯'
-    fill = '◉'
-
-
-class IncrementalBar(Bar):
-    if sys.platform.startswith('win'):
-        phases = (u' ', u'▌', u'█')
-    else:
-        phases = (' ', '▏', '▎', '▍', '▌', '▋', '▊', '▉', '█')
-
-    def update(self):
-        nphases = len(self.phases)
-        filled_len = self.width * self.progress
-        nfull = int(filled_len)                      # Number of full chars
-        phase = int((filled_len - nfull) * nphases)  # Phase of last char
-        nempty = self.width - nfull                  # Number of empty chars
-
-        message = self.message % self
-        bar = self.phases[-1] * nfull
-        current = self.phases[phase] if phase > 0 else ''
-        empty = self.empty_fill * max(0, nempty - len(current))
-        suffix = self.suffix % self
-        line = ''.join([message, self.bar_prefix, bar, current, empty,
-                        self.bar_suffix, suffix])
-        self.writeln(line)
-
-
-class PixelBar(IncrementalBar):
-    phases = ('⡀', '⡄', '⡆', '⡇', '⣇', '⣧', '⣷', '⣿')
-
-
-class ShadyBar(IncrementalBar):
-    phases = (' ', '░', '▒', '▓', '█')
diff --git a/env/Lib/site-packages/pip/_vendor/progress/counter.py b/env/Lib/site-packages/pip/_vendor/progress/counter.py
deleted file mode 100644
index d955ca47..00000000
--- a/env/Lib/site-packages/pip/_vendor/progress/counter.py
+++ /dev/null
@@ -1,41 +0,0 @@
-# -*- coding: utf-8 -*-
-
-# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com>
-#
-# Permission to use, copy, modify, and distribute this software for any
-# purpose with or without fee is hereby granted, provided that the above
-# copyright notice and this permission notice appear in all copies.
-#
-# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-
-from __future__ import unicode_literals
-from . import Infinite, Progress
-
-
-class Counter(Infinite):
-    def update(self):
-        self.write(str(self.index))
-
-
-class Countdown(Progress):
-    def update(self):
-        self.write(str(self.remaining))
-
-
-class Stack(Progress):
-    phases = (' ', '▁', '▂', '▃', '▄', '▅', '▆', '▇', '█')
-
-    def update(self):
-        nphases = len(self.phases)
-        i = min(nphases - 1, int(self.progress * nphases))
-        self.write(self.phases[i])
-
-
-class Pie(Stack):
-    phases = ('○', '◔', '◑', '◕', '●')
diff --git a/env/Lib/site-packages/pip/_vendor/progress/spinner.py b/env/Lib/site-packages/pip/_vendor/progress/spinner.py
deleted file mode 100644
index 4e100cab..00000000
--- a/env/Lib/site-packages/pip/_vendor/progress/spinner.py
+++ /dev/null
@@ -1,43 +0,0 @@
-# -*- coding: utf-8 -*-
-
-# Copyright (c) 2012 Giorgos Verigakis <verigak@gmail.com>
-#
-# Permission to use, copy, modify, and distribute this software for any
-# purpose with or without fee is hereby granted, provided that the above
-# copyright notice and this permission notice appear in all copies.
-#
-# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
-# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
-# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
-# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
-# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
-# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-
-from __future__ import unicode_literals
-from . import Infinite
-
-
-class Spinner(Infinite):
-    phases = ('-', '\\', '|', '/')
-    hide_cursor = True
-
-    def update(self):
-        i = self.index % len(self.phases)
-        self.write(self.phases[i])
-
-
-class PieSpinner(Spinner):
-    phases = ['◷', '◶', '◵', '◴']
-
-
-class MoonSpinner(Spinner):
-    phases = ['◑', '◒', '◐', '◓']
-
-
-class LineSpinner(Spinner):
-    phases = ['⎺', '⎻', '⎼', '⎽', '⎼', '⎻']
-
-
-class PixelSpinner(Spinner):
-    phases = ['⣾', '⣷', '⣯', '⣟', '⡿', '⢿', '⣻', '⣽']
diff --git a/env/Lib/site-packages/pip/_vendor/pyparsing.py b/env/Lib/site-packages/pip/_vendor/pyparsing.py
deleted file mode 100644
index 7ebc7eb9..00000000
--- a/env/Lib/site-packages/pip/_vendor/pyparsing.py
+++ /dev/null
@@ -1,7107 +0,0 @@
-# -*- coding: utf-8 -*-
-# module pyparsing.py
-#
-# Copyright (c) 2003-2019  Paul T. McGuire
-#
-# Permission is hereby granted, free of charge, to any person obtaining
-# a copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish,
-# distribute, sublicense, and/or sell copies of the Software, and to
-# permit persons to whom the Software is furnished to do so, subject to
-# the following conditions:
-#
-# The above copyright notice and this permission notice shall be
-# included in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
-# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
-# IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
-# CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
-# TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
-# SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
-#
-
-__doc__ = \
-"""
-pyparsing module - Classes and methods to define and execute parsing grammars
-=============================================================================
-
-The pyparsing module is an alternative approach to creating and
-executing simple grammars, vs. the traditional lex/yacc approach, or the
-use of regular expressions.  With pyparsing, you don't need to learn
-a new syntax for defining grammars or matching expressions - the parsing
-module provides a library of classes that you use to construct the
-grammar directly in Python.
-
-Here is a program to parse "Hello, World!" (or any greeting of the form
-``"<salutation>, <addressee>!"``), built up using :class:`Word`,
-:class:`Literal`, and :class:`And` elements
-(the :class:`'+'<ParserElement.__add__>` operators create :class:`And` expressions,
-and the strings are auto-converted to :class:`Literal` expressions)::
-
-    from pip._vendor.pyparsing import Word, alphas
-
-    # define grammar of a greeting
-    greet = Word(alphas) + "," + Word(alphas) + "!"
-
-    hello = "Hello, World!"
-    print (hello, "->", greet.parseString(hello))
-
-The program outputs the following::
-
-    Hello, World! -> ['Hello', ',', 'World', '!']
-
-The Python representation of the grammar is quite readable, owing to the
-self-explanatory class names, and the use of '+', '|' and '^' operators.
-
-The :class:`ParseResults` object returned from
-:class:`ParserElement.parseString` can be
-accessed as a nested list, a dictionary, or an object with named
-attributes.
-
-The pyparsing module handles some of the problems that are typically
-vexing when writing text parsers:
-
-  - extra or missing whitespace (the above program will also handle
-    "Hello,World!", "Hello  ,  World  !", etc.)
-  - quoted strings
-  - embedded comments
-
-
-Getting Started -
------------------
-Visit the classes :class:`ParserElement` and :class:`ParseResults` to
-see the base classes that most other pyparsing
-classes inherit from. Use the docstrings for examples of how to:
-
- - construct literal match expressions from :class:`Literal` and
-   :class:`CaselessLiteral` classes
- - construct character word-group expressions using the :class:`Word`
-   class
- - see how to create repetitive expressions using :class:`ZeroOrMore`
-   and :class:`OneOrMore` classes
- - use :class:`'+'<And>`, :class:`'|'<MatchFirst>`, :class:`'^'<Or>`,
-   and :class:`'&'<Each>` operators to combine simple expressions into
-   more complex ones
- - associate names with your parsed results using
-   :class:`ParserElement.setResultsName`
- - access the parsed data, which is returned as a :class:`ParseResults`
-   object
- - find some helpful expression short-cuts like :class:`delimitedList`
-   and :class:`oneOf`
- - find more useful common expressions in the :class:`pyparsing_common`
-   namespace class
-"""
-
-__version__ = "2.4.7"
-__versionTime__ = "30 Mar 2020 00:43 UTC"
-__author__ = "Paul McGuire <ptmcg@users.sourceforge.net>"
-
-import string
-from weakref import ref as wkref
-import copy
-import sys
-import warnings
-import re
-import sre_constants
-import collections
-import pprint
-import traceback
-import types
-from datetime import datetime
-from operator import itemgetter
-import itertools
-from functools import wraps
-from contextlib import contextmanager
-
-try:
-    # Python 3
-    from itertools import filterfalse
-except ImportError:
-    from itertools import ifilterfalse as filterfalse
-
-try:
-    from _thread import RLock
-except ImportError:
-    from threading import RLock
-
-try:
-    # Python 3
-    from collections.abc import Iterable
-    from collections.abc import MutableMapping, Mapping
-except ImportError:
-    # Python 2.7
-    from collections import Iterable
-    from collections import MutableMapping, Mapping
-
-try:
-    from collections import OrderedDict as _OrderedDict
-except ImportError:
-    try:
-        from ordereddict import OrderedDict as _OrderedDict
-    except ImportError:
-        _OrderedDict = None
-
-try:
-    from types import SimpleNamespace
-except ImportError:
-    class SimpleNamespace: pass
-
-# version compatibility configuration
-__compat__ = SimpleNamespace()
-__compat__.__doc__ = """
-    A cross-version compatibility configuration for pyparsing features that will be
-    released in a future version. By setting values in this configuration to True,
-    those features can be enabled in prior versions for compatibility development
-    and testing.
-
-     - collect_all_And_tokens - flag to enable fix for Issue #63 that fixes erroneous grouping
-       of results names when an And expression is nested within an Or or MatchFirst; set to
-       True to enable bugfix released in pyparsing 2.3.0, or False to preserve
-       pre-2.3.0 handling of named results
-"""
-__compat__.collect_all_And_tokens = True
-
-__diag__ = SimpleNamespace()
-__diag__.__doc__ = """
-Diagnostic configuration (all default to False)
-     - warn_multiple_tokens_in_named_alternation - flag to enable warnings when a results
-       name is defined on a MatchFirst or Or expression with one or more And subexpressions
-       (only warns if __compat__.collect_all_And_tokens is False)
-     - warn_ungrouped_named_tokens_in_collection - flag to enable warnings when a results
-       name is defined on a containing expression with ungrouped subexpressions that also
-       have results names
-     - warn_name_set_on_empty_Forward - flag to enable warnings whan a Forward is defined
-       with a results name, but has no contents defined
-     - warn_on_multiple_string_args_to_oneof - flag to enable warnings whan oneOf is
-       incorrectly called with multiple str arguments
-     - enable_debug_on_named_expressions - flag to auto-enable debug on all subsequent
-       calls to ParserElement.setName()
-"""
-__diag__.warn_multiple_tokens_in_named_alternation = False
-__diag__.warn_ungrouped_named_tokens_in_collection = False
-__diag__.warn_name_set_on_empty_Forward = False
-__diag__.warn_on_multiple_string_args_to_oneof = False
-__diag__.enable_debug_on_named_expressions = False
-__diag__._all_names = [nm for nm in vars(__diag__) if nm.startswith("enable_") or nm.startswith("warn_")]
-
-def _enable_all_warnings():
-    __diag__.warn_multiple_tokens_in_named_alternation = True
-    __diag__.warn_ungrouped_named_tokens_in_collection = True
-    __diag__.warn_name_set_on_empty_Forward = True
-    __diag__.warn_on_multiple_string_args_to_oneof = True
-__diag__.enable_all_warnings = _enable_all_warnings
-
-
-__all__ = ['__version__', '__versionTime__', '__author__', '__compat__', '__diag__',
-           'And', 'CaselessKeyword', 'CaselessLiteral', 'CharsNotIn', 'Combine', 'Dict', 'Each', 'Empty',
-           'FollowedBy', 'Forward', 'GoToColumn', 'Group', 'Keyword', 'LineEnd', 'LineStart', 'Literal',
-           'PrecededBy', 'MatchFirst', 'NoMatch', 'NotAny', 'OneOrMore', 'OnlyOnce', 'Optional', 'Or',
-           'ParseBaseException', 'ParseElementEnhance', 'ParseException', 'ParseExpression', 'ParseFatalException',
-           'ParseResults', 'ParseSyntaxException', 'ParserElement', 'QuotedString', 'RecursiveGrammarException',
-           'Regex', 'SkipTo', 'StringEnd', 'StringStart', 'Suppress', 'Token', 'TokenConverter',
-           'White', 'Word', 'WordEnd', 'WordStart', 'ZeroOrMore', 'Char',
-           'alphanums', 'alphas', 'alphas8bit', 'anyCloseTag', 'anyOpenTag', 'cStyleComment', 'col',
-           'commaSeparatedList', 'commonHTMLEntity', 'countedArray', 'cppStyleComment', 'dblQuotedString',
-           'dblSlashComment', 'delimitedList', 'dictOf', 'downcaseTokens', 'empty', 'hexnums',
-           'htmlComment', 'javaStyleComment', 'line', 'lineEnd', 'lineStart', 'lineno',
-           'makeHTMLTags', 'makeXMLTags', 'matchOnlyAtCol', 'matchPreviousExpr', 'matchPreviousLiteral',
-           'nestedExpr', 'nullDebugAction', 'nums', 'oneOf', 'opAssoc', 'operatorPrecedence', 'printables',
-           'punc8bit', 'pythonStyleComment', 'quotedString', 'removeQuotes', 'replaceHTMLEntity',
-           'replaceWith', 'restOfLine', 'sglQuotedString', 'srange', 'stringEnd',
-           'stringStart', 'traceParseAction', 'unicodeString', 'upcaseTokens', 'withAttribute',
-           'indentedBlock', 'originalTextFor', 'ungroup', 'infixNotation', 'locatedExpr', 'withClass',
-           'CloseMatch', 'tokenMap', 'pyparsing_common', 'pyparsing_unicode', 'unicode_set',
-           'conditionAsParseAction', 're',
-           ]
-
-system_version = tuple(sys.version_info)[:3]
-PY_3 = system_version[0] == 3
-if PY_3:
-    _MAX_INT = sys.maxsize
-    basestring = str
-    unichr = chr
-    unicode = str
-    _ustr = str
-
-    # build list of single arg builtins, that can be used as parse actions
-    singleArgBuiltins = [sum, len, sorted, reversed, list, tuple, set, any, all, min, max]
-
-else:
-    _MAX_INT = sys.maxint
-    range = xrange
-
-    def _ustr(obj):
-        """Drop-in replacement for str(obj) that tries to be Unicode
-        friendly. It first tries str(obj). If that fails with
-        a UnicodeEncodeError, then it tries unicode(obj). It then
-        < returns the unicode object | encodes it with the default
-        encoding | ... >.
-        """
-        if isinstance(obj, unicode):
-            return obj
-
-        try:
-            # If this works, then _ustr(obj) has the same behaviour as str(obj), so
-            # it won't break any existing code.
-            return str(obj)
-
-        except UnicodeEncodeError:
-            # Else encode it
-            ret = unicode(obj).encode(sys.getdefaultencoding(), 'xmlcharrefreplace')
-            xmlcharref = Regex(r'&#\d+;')
-            xmlcharref.setParseAction(lambda t: '\\u' + hex(int(t[0][2:-1]))[2:])
-            return xmlcharref.transformString(ret)
-
-    # build list of single arg builtins, tolerant of Python version, that can be used as parse actions
-    singleArgBuiltins = []
-    import __builtin__
-
-    for fname in "sum len sorted reversed list tuple set any all min max".split():
-        try:
-            singleArgBuiltins.append(getattr(__builtin__, fname))
-        except AttributeError:
-            continue
-
-_generatorType = type((y for y in range(1)))
-
-def _xml_escape(data):
-    """Escape &, <, >, ", ', etc. in a string of data."""
-
-    # ampersand must be replaced first
-    from_symbols = '&><"\''
-    to_symbols = ('&' + s + ';' for s in "amp gt lt quot apos".split())
-    for from_, to_ in zip(from_symbols, to_symbols):
-        data = data.replace(from_, to_)
-    return data
-
-alphas = string.ascii_uppercase + string.ascii_lowercase
-nums = "0123456789"
-hexnums = nums + "ABCDEFabcdef"
-alphanums = alphas + nums
-_bslash = chr(92)
-printables = "".join(c for c in string.printable if c not in string.whitespace)
-
-
-def conditionAsParseAction(fn, message=None, fatal=False):
-    msg = message if message is not None else "failed user-defined condition"
-    exc_type = ParseFatalException if fatal else ParseException
-    fn = _trim_arity(fn)
-
-    @wraps(fn)
-    def pa(s, l, t):
-        if not bool(fn(s, l, t)):
-            raise exc_type(s, l, msg)
-
-    return pa
-
-class ParseBaseException(Exception):
-    """base exception class for all parsing runtime exceptions"""
-    # Performance tuning: we construct a *lot* of these, so keep this
-    # constructor as small and fast as possible
-    def __init__(self, pstr, loc=0, msg=None, elem=None):
-        self.loc = loc
-        if msg is None:
-            self.msg = pstr
-            self.pstr = ""
-        else:
-            self.msg = msg
-            self.pstr = pstr
-        self.parserElement = elem
-        self.args = (pstr, loc, msg)
-
-    @classmethod
-    def _from_exception(cls, pe):
-        """
-        internal factory method to simplify creating one type of ParseException
-        from another - avoids having __init__ signature conflicts among subclasses
-        """
-        return cls(pe.pstr, pe.loc, pe.msg, pe.parserElement)
-
-    def __getattr__(self, aname):
-        """supported attributes by name are:
-           - lineno - returns the line number of the exception text
-           - col - returns the column number of the exception text
-           - line - returns the line containing the exception text
-        """
-        if aname == "lineno":
-            return lineno(self.loc, self.pstr)
-        elif aname in ("col", "column"):
-            return col(self.loc, self.pstr)
-        elif aname == "line":
-            return line(self.loc, self.pstr)
-        else:
-            raise AttributeError(aname)
-
-    def __str__(self):
-        if self.pstr:
-            if self.loc >= len(self.pstr):
-                foundstr = ', found end of text'
-            else:
-                foundstr = (', found %r' % self.pstr[self.loc:self.loc + 1]).replace(r'\\', '\\')
-        else:
-            foundstr = ''
-        return ("%s%s  (at char %d), (line:%d, col:%d)" %
-                   (self.msg, foundstr, self.loc, self.lineno, self.column))
-    def __repr__(self):
-        return _ustr(self)
-    def markInputline(self, markerString=">!<"):
-        """Extracts the exception line from the input string, and marks
-           the location of the exception with a special symbol.
-        """
-        line_str = self.line
-        line_column = self.column - 1
-        if markerString:
-            line_str = "".join((line_str[:line_column],
-                                markerString, line_str[line_column:]))
-        return line_str.strip()
-    def __dir__(self):
-        return "lineno col line".split() + dir(type(self))
-
-class ParseException(ParseBaseException):
-    """
-    Exception thrown when parse expressions don't match class;
-    supported attributes by name are:
-    - lineno - returns the line number of the exception text
-    - col - returns the column number of the exception text
-    - line - returns the line containing the exception text
-
-    Example::
-
-        try:
-            Word(nums).setName("integer").parseString("ABC")
-        except ParseException as pe:
-            print(pe)
-            print("column: {}".format(pe.col))
-
-    prints::
-
-       Expected integer (at char 0), (line:1, col:1)
-        column: 1
-
-    """
-
-    @staticmethod
-    def explain(exc, depth=16):
-        """
-        Method to take an exception and translate the Python internal traceback into a list
-        of the pyparsing expressions that caused the exception to be raised.
-
-        Parameters:
-
-         - exc - exception raised during parsing (need not be a ParseException, in support
-           of Python exceptions that might be raised in a parse action)
-         - depth (default=16) - number of levels back in the stack trace to list expression
-           and function names; if None, the full stack trace names will be listed; if 0, only
-           the failing input line, marker, and exception string will be shown
-
-        Returns a multi-line string listing the ParserElements and/or function names in the
-        exception's stack trace.
-
-        Note: the diagnostic output will include string representations of the expressions
-        that failed to parse. These representations will be more helpful if you use `setName` to
-        give identifiable names to your expressions. Otherwise they will use the default string
-        forms, which may be cryptic to read.
-
-        explain() is only supported under Python 3.
-        """
-        import inspect
-
-        if depth is None:
-            depth = sys.getrecursionlimit()
-        ret = []
-        if isinstance(exc, ParseBaseException):
-            ret.append(exc.line)
-            ret.append(' ' * (exc.col - 1) + '^')
-        ret.append("{0}: {1}".format(type(exc).__name__, exc))
-
-        if depth > 0:
-            callers = inspect.getinnerframes(exc.__traceback__, context=depth)
-            seen = set()
-            for i, ff in enumerate(callers[-depth:]):
-                frm = ff[0]
-
-                f_self = frm.f_locals.get('self', None)
-                if isinstance(f_self, ParserElement):
-                    if frm.f_code.co_name not in ('parseImpl', '_parseNoCache'):
-                        continue
-                    if f_self in seen:
-                        continue
-                    seen.add(f_self)
-
-                    self_type = type(f_self)
-                    ret.append("{0}.{1} - {2}".format(self_type.__module__,
-                                                      self_type.__name__,
-                                                      f_self))
-                elif f_self is not None:
-                    self_type = type(f_self)
-                    ret.append("{0}.{1}".format(self_type.__module__,
-                                                self_type.__name__))
-                else:
-                    code = frm.f_code
-                    if code.co_name in ('wrapper', '<module>'):
-                        continue
-
-                    ret.append("{0}".format(code.co_name))
-
-                depth -= 1
-                if not depth:
-                    break
-
-        return '\n'.join(ret)
-
-
-class ParseFatalException(ParseBaseException):
-    """user-throwable exception thrown when inconsistent parse content
-       is found; stops all parsing immediately"""
-    pass
-
-class ParseSyntaxException(ParseFatalException):
-    """just like :class:`ParseFatalException`, but thrown internally
-    when an :class:`ErrorStop<And._ErrorStop>` ('-' operator) indicates
-    that parsing is to stop immediately because an unbacktrackable
-    syntax error has been found.
-    """
-    pass
-
-#~ class ReparseException(ParseBaseException):
-    #~ """Experimental class - parse actions can raise this exception to cause
-       #~ pyparsing to reparse the input string:
-        #~ - with a modified input string, and/or
-        #~ - with a modified start location
-       #~ Set the values of the ReparseException in the constructor, and raise the
-       #~ exception in a parse action to cause pyparsing to use the new string/location.
-       #~ Setting the values as None causes no change to be made.
-       #~ """
-    #~ def __init_( self, newstring, restartLoc ):
-        #~ self.newParseText = newstring
-        #~ self.reparseLoc = restartLoc
-
-class RecursiveGrammarException(Exception):
-    """exception thrown by :class:`ParserElement.validate` if the
-    grammar could be improperly recursive
-    """
-    def __init__(self, parseElementList):
-        self.parseElementTrace = parseElementList
-
-    def __str__(self):
-        return "RecursiveGrammarException: %s" % self.parseElementTrace
-
-class _ParseResultsWithOffset(object):
-    def __init__(self, p1, p2):
-        self.tup = (p1, p2)
-    def __getitem__(self, i):
-        return self.tup[i]
-    def __repr__(self):
-        return repr(self.tup[0])
-    def setOffset(self, i):
-        self.tup = (self.tup[0], i)
-
-class ParseResults(object):
-    """Structured parse results, to provide multiple means of access to
-    the parsed data:
-
-       - as a list (``len(results)``)
-       - by list index (``results[0], results[1]``, etc.)
-       - by attribute (``results.<resultsName>`` - see :class:`ParserElement.setResultsName`)
-
-    Example::
-
-        integer = Word(nums)
-        date_str = (integer.setResultsName("year") + '/'
-                        + integer.setResultsName("month") + '/'
-                        + integer.setResultsName("day"))
-        # equivalent form:
-        # date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-
-        # parseString returns a ParseResults object
-        result = date_str.parseString("1999/12/31")
-
-        def test(s, fn=repr):
-            print("%s -> %s" % (s, fn(eval(s))))
-        test("list(result)")
-        test("result[0]")
-        test("result['month']")
-        test("result.day")
-        test("'month' in result")
-        test("'minutes' in result")
-        test("result.dump()", str)
-
-    prints::
-
-        list(result) -> ['1999', '/', '12', '/', '31']
-        result[0] -> '1999'
-        result['month'] -> '12'
-        result.day -> '31'
-        'month' in result -> True
-        'minutes' in result -> False
-        result.dump() -> ['1999', '/', '12', '/', '31']
-        - day: 31
-        - month: 12
-        - year: 1999
-    """
-    def __new__(cls, toklist=None, name=None, asList=True, modal=True):
-        if isinstance(toklist, cls):
-            return toklist
-        retobj = object.__new__(cls)
-        retobj.__doinit = True
-        return retobj
-
-    # Performance tuning: we construct a *lot* of these, so keep this
-    # constructor as small and fast as possible
-    def __init__(self, toklist=None, name=None, asList=True, modal=True, isinstance=isinstance):
-        if self.__doinit:
-            self.__doinit = False
-            self.__name = None
-            self.__parent = None
-            self.__accumNames = {}
-            self.__asList = asList
-            self.__modal = modal
-            if toklist is None:
-                toklist = []
-            if isinstance(toklist, list):
-                self.__toklist = toklist[:]
-            elif isinstance(toklist, _generatorType):
-                self.__toklist = list(toklist)
-            else:
-                self.__toklist = [toklist]
-            self.__tokdict = dict()
-
-        if name is not None and name:
-            if not modal:
-                self.__accumNames[name] = 0
-            if isinstance(name, int):
-                name = _ustr(name)  # will always return a str, but use _ustr for consistency
-            self.__name = name
-            if not (isinstance(toklist, (type(None), basestring, list)) and toklist in (None, '', [])):
-                if isinstance(toklist, basestring):
-                    toklist = [toklist]
-                if asList:
-                    if isinstance(toklist, ParseResults):
-                        self[name] = _ParseResultsWithOffset(ParseResults(toklist.__toklist), 0)
-                    else:
-                        self[name] = _ParseResultsWithOffset(ParseResults(toklist[0]), 0)
-                    self[name].__name = name
-                else:
-                    try:
-                        self[name] = toklist[0]
-                    except (KeyError, TypeError, IndexError):
-                        self[name] = toklist
-
-    def __getitem__(self, i):
-        if isinstance(i, (int, slice)):
-            return self.__toklist[i]
-        else:
-            if i not in self.__accumNames:
-                return self.__tokdict[i][-1][0]
-            else:
-                return ParseResults([v[0] for v in self.__tokdict[i]])
-
-    def __setitem__(self, k, v, isinstance=isinstance):
-        if isinstance(v, _ParseResultsWithOffset):
-            self.__tokdict[k] = self.__tokdict.get(k, list()) + [v]
-            sub = v[0]
-        elif isinstance(k, (int, slice)):
-            self.__toklist[k] = v
-            sub = v
-        else:
-            self.__tokdict[k] = self.__tokdict.get(k, list()) + [_ParseResultsWithOffset(v, 0)]
-            sub = v
-        if isinstance(sub, ParseResults):
-            sub.__parent = wkref(self)
-
-    def __delitem__(self, i):
-        if isinstance(i, (int, slice)):
-            mylen = len(self.__toklist)
-            del self.__toklist[i]
-
-            # convert int to slice
-            if isinstance(i, int):
-                if i < 0:
-                    i += mylen
-                i = slice(i, i + 1)
-            # get removed indices
-            removed = list(range(*i.indices(mylen)))
-            removed.reverse()
-            # fixup indices in token dictionary
-            for name, occurrences in self.__tokdict.items():
-                for j in removed:
-                    for k, (value, position) in enumerate(occurrences):
-                        occurrences[k] = _ParseResultsWithOffset(value, position - (position > j))
-        else:
-            del self.__tokdict[i]
-
-    def __contains__(self, k):
-        return k in self.__tokdict
-
-    def __len__(self):
-        return len(self.__toklist)
-
-    def __bool__(self):
-        return (not not self.__toklist)
-    __nonzero__ = __bool__
-
-    def __iter__(self):
-        return iter(self.__toklist)
-
-    def __reversed__(self):
-        return iter(self.__toklist[::-1])
-
-    def _iterkeys(self):
-        if hasattr(self.__tokdict, "iterkeys"):
-            return self.__tokdict.iterkeys()
-        else:
-            return iter(self.__tokdict)
-
-    def _itervalues(self):
-        return (self[k] for k in self._iterkeys())
-
-    def _iteritems(self):
-        return ((k, self[k]) for k in self._iterkeys())
-
-    if PY_3:
-        keys = _iterkeys
-        """Returns an iterator of all named result keys."""
-
-        values = _itervalues
-        """Returns an iterator of all named result values."""
-
-        items = _iteritems
-        """Returns an iterator of all named result key-value tuples."""
-
-    else:
-        iterkeys = _iterkeys
-        """Returns an iterator of all named result keys (Python 2.x only)."""
-
-        itervalues = _itervalues
-        """Returns an iterator of all named result values (Python 2.x only)."""
-
-        iteritems = _iteritems
-        """Returns an iterator of all named result key-value tuples (Python 2.x only)."""
-
-        def keys(self):
-            """Returns all named result keys (as a list in Python 2.x, as an iterator in Python 3.x)."""
-            return list(self.iterkeys())
-
-        def values(self):
-            """Returns all named result values (as a list in Python 2.x, as an iterator in Python 3.x)."""
-            return list(self.itervalues())
-
-        def items(self):
-            """Returns all named result key-values (as a list of tuples in Python 2.x, as an iterator in Python 3.x)."""
-            return list(self.iteritems())
-
-    def haskeys(self):
-        """Since keys() returns an iterator, this method is helpful in bypassing
-           code that looks for the existence of any defined results names."""
-        return bool(self.__tokdict)
-
-    def pop(self, *args, **kwargs):
-        """
-        Removes and returns item at specified index (default= ``last``).
-        Supports both ``list`` and ``dict`` semantics for ``pop()``. If
-        passed no argument or an integer argument, it will use ``list``
-        semantics and pop tokens from the list of parsed tokens. If passed
-        a non-integer argument (most likely a string), it will use ``dict``
-        semantics and pop the corresponding value from any defined results
-        names. A second default return value argument is supported, just as in
-        ``dict.pop()``.
-
-        Example::
-
-            def remove_first(tokens):
-                tokens.pop(0)
-            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
-            print(OneOrMore(Word(nums)).addParseAction(remove_first).parseString("0 123 321")) # -> ['123', '321']
-
-            label = Word(alphas)
-            patt = label("LABEL") + OneOrMore(Word(nums))
-            print(patt.parseString("AAB 123 321").dump())
-
-            # Use pop() in a parse action to remove named result (note that corresponding value is not
-            # removed from list form of results)
-            def remove_LABEL(tokens):
-                tokens.pop("LABEL")
-                return tokens
-            patt.addParseAction(remove_LABEL)
-            print(patt.parseString("AAB 123 321").dump())
-
-        prints::
-
-            ['AAB', '123', '321']
-            - LABEL: AAB
-
-            ['AAB', '123', '321']
-        """
-        if not args:
-            args = [-1]
-        for k, v in kwargs.items():
-            if k == 'default':
-                args = (args[0], v)
-            else:
-                raise TypeError("pop() got an unexpected keyword argument '%s'" % k)
-        if (isinstance(args[0], int)
-                or len(args) == 1
-                or args[0] in self):
-            index = args[0]
-            ret = self[index]
-            del self[index]
-            return ret
-        else:
-            defaultvalue = args[1]
-            return defaultvalue
-
-    def get(self, key, defaultValue=None):
-        """
-        Returns named result matching the given key, or if there is no
-        such name, then returns the given ``defaultValue`` or ``None`` if no
-        ``defaultValue`` is specified.
-
-        Similar to ``dict.get()``.
-
-        Example::
-
-            integer = Word(nums)
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-
-            result = date_str.parseString("1999/12/31")
-            print(result.get("year")) # -> '1999'
-            print(result.get("hour", "not specified")) # -> 'not specified'
-            print(result.get("hour")) # -> None
-        """
-        if key in self:
-            return self[key]
-        else:
-            return defaultValue
-
-    def insert(self, index, insStr):
-        """
-        Inserts new element at location index in the list of parsed tokens.
-
-        Similar to ``list.insert()``.
-
-        Example::
-
-            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
-
-            # use a parse action to insert the parse location in the front of the parsed results
-            def insert_locn(locn, tokens):
-                tokens.insert(0, locn)
-            print(OneOrMore(Word(nums)).addParseAction(insert_locn).parseString("0 123 321")) # -> [0, '0', '123', '321']
-        """
-        self.__toklist.insert(index, insStr)
-        # fixup indices in token dictionary
-        for name, occurrences in self.__tokdict.items():
-            for k, (value, position) in enumerate(occurrences):
-                occurrences[k] = _ParseResultsWithOffset(value, position + (position > index))
-
-    def append(self, item):
-        """
-        Add single element to end of ParseResults list of elements.
-
-        Example::
-
-            print(OneOrMore(Word(nums)).parseString("0 123 321")) # -> ['0', '123', '321']
-
-            # use a parse action to compute the sum of the parsed integers, and add it to the end
-            def append_sum(tokens):
-                tokens.append(sum(map(int, tokens)))
-            print(OneOrMore(Word(nums)).addParseAction(append_sum).parseString("0 123 321")) # -> ['0', '123', '321', 444]
-        """
-        self.__toklist.append(item)
-
-    def extend(self, itemseq):
-        """
-        Add sequence of elements to end of ParseResults list of elements.
-
-        Example::
-
-            patt = OneOrMore(Word(alphas))
-
-            # use a parse action to append the reverse of the matched strings, to make a palindrome
-            def make_palindrome(tokens):
-                tokens.extend(reversed([t[::-1] for t in tokens]))
-                return ''.join(tokens)
-            print(patt.addParseAction(make_palindrome).parseString("lskdj sdlkjf lksd")) # -> 'lskdjsdlkjflksddsklfjkldsjdksl'
-        """
-        if isinstance(itemseq, ParseResults):
-            self.__iadd__(itemseq)
-        else:
-            self.__toklist.extend(itemseq)
-
-    def clear(self):
-        """
-        Clear all elements and results names.
-        """
-        del self.__toklist[:]
-        self.__tokdict.clear()
-
-    def __getattr__(self, name):
-        try:
-            return self[name]
-        except KeyError:
-            return ""
-
-    def __add__(self, other):
-        ret = self.copy()
-        ret += other
-        return ret
-
-    def __iadd__(self, other):
-        if other.__tokdict:
-            offset = len(self.__toklist)
-            addoffset = lambda a: offset if a < 0 else a + offset
-            otheritems = other.__tokdict.items()
-            otherdictitems = [(k, _ParseResultsWithOffset(v[0], addoffset(v[1])))
-                              for k, vlist in otheritems for v in vlist]
-            for k, v in otherdictitems:
-                self[k] = v
-                if isinstance(v[0], ParseResults):
-                    v[0].__parent = wkref(self)
-
-        self.__toklist += other.__toklist
-        self.__accumNames.update(other.__accumNames)
-        return self
-
-    def __radd__(self, other):
-        if isinstance(other, int) and other == 0:
-            # useful for merging many ParseResults using sum() builtin
-            return self.copy()
-        else:
-            # this may raise a TypeError - so be it
-            return other + self
-
-    def __repr__(self):
-        return "(%s, %s)" % (repr(self.__toklist), repr(self.__tokdict))
-
-    def __str__(self):
-        return '[' + ', '.join(_ustr(i) if isinstance(i, ParseResults) else repr(i) for i in self.__toklist) + ']'
-
-    def _asStringList(self, sep=''):
-        out = []
-        for item in self.__toklist:
-            if out and sep:
-                out.append(sep)
-            if isinstance(item, ParseResults):
-                out += item._asStringList()
-            else:
-                out.append(_ustr(item))
-        return out
-
-    def asList(self):
-        """
-        Returns the parse results as a nested list of matching tokens, all converted to strings.
-
-        Example::
-
-            patt = OneOrMore(Word(alphas))
-            result = patt.parseString("sldkj lsdkj sldkj")
-            # even though the result prints in string-like form, it is actually a pyparsing ParseResults
-            print(type(result), result) # -> <class 'pyparsing.ParseResults'> ['sldkj', 'lsdkj', 'sldkj']
-
-            # Use asList() to create an actual list
-            result_list = result.asList()
-            print(type(result_list), result_list) # -> <class 'list'> ['sldkj', 'lsdkj', 'sldkj']
-        """
-        return [res.asList() if isinstance(res, ParseResults) else res for res in self.__toklist]
-
-    def asDict(self):
-        """
-        Returns the named parse results as a nested dictionary.
-
-        Example::
-
-            integer = Word(nums)
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-
-            result = date_str.parseString('12/31/1999')
-            print(type(result), repr(result)) # -> <class 'pyparsing.ParseResults'> (['12', '/', '31', '/', '1999'], {'day': [('1999', 4)], 'year': [('12', 0)], 'month': [('31', 2)]})
-
-            result_dict = result.asDict()
-            print(type(result_dict), repr(result_dict)) # -> <class 'dict'> {'day': '1999', 'year': '12', 'month': '31'}
-
-            # even though a ParseResults supports dict-like access, sometime you just need to have a dict
-            import json
-            print(json.dumps(result)) # -> Exception: TypeError: ... is not JSON serializable
-            print(json.dumps(result.asDict())) # -> {"month": "31", "day": "1999", "year": "12"}
-        """
-        if PY_3:
-            item_fn = self.items
-        else:
-            item_fn = self.iteritems
-
-        def toItem(obj):
-            if isinstance(obj, ParseResults):
-                if obj.haskeys():
-                    return obj.asDict()
-                else:
-                    return [toItem(v) for v in obj]
-            else:
-                return obj
-
-        return dict((k, toItem(v)) for k, v in item_fn())
-
-    def copy(self):
-        """
-        Returns a new copy of a :class:`ParseResults` object.
-        """
-        ret = ParseResults(self.__toklist)
-        ret.__tokdict = dict(self.__tokdict.items())
-        ret.__parent = self.__parent
-        ret.__accumNames.update(self.__accumNames)
-        ret.__name = self.__name
-        return ret
-
-    def asXML(self, doctag=None, namedItemsOnly=False, indent="", formatted=True):
-        """
-        (Deprecated) Returns the parse results as XML. Tags are created for tokens and lists that have defined results names.
-        """
-        nl = "\n"
-        out = []
-        namedItems = dict((v[1], k) for (k, vlist) in self.__tokdict.items()
-                          for v in vlist)
-        nextLevelIndent = indent + "  "
-
-        # collapse out indents if formatting is not desired
-        if not formatted:
-            indent = ""
-            nextLevelIndent = ""
-            nl = ""
-
-        selfTag = None
-        if doctag is not None:
-            selfTag = doctag
-        else:
-            if self.__name:
-                selfTag = self.__name
-
-        if not selfTag:
-            if namedItemsOnly:
-                return ""
-            else:
-                selfTag = "ITEM"
-
-        out += [nl, indent, "<", selfTag, ">"]
-
-        for i, res in enumerate(self.__toklist):
-            if isinstance(res, ParseResults):
-                if i in namedItems:
-                    out += [res.asXML(namedItems[i],
-                                      namedItemsOnly and doctag is None,
-                                      nextLevelIndent,
-                                      formatted)]
-                else:
-                    out += [res.asXML(None,
-                                      namedItemsOnly and doctag is None,
-                                      nextLevelIndent,
-                                      formatted)]
-            else:
-                # individual token, see if there is a name for it
-                resTag = None
-                if i in namedItems:
-                    resTag = namedItems[i]
-                if not resTag:
-                    if namedItemsOnly:
-                        continue
-                    else:
-                        resTag = "ITEM"
-                xmlBodyText = _xml_escape(_ustr(res))
-                out += [nl, nextLevelIndent, "<", resTag, ">",
-                        xmlBodyText,
-                                                "</", resTag, ">"]
-
-        out += [nl, indent, "</", selfTag, ">"]
-        return "".join(out)
-
-    def __lookup(self, sub):
-        for k, vlist in self.__tokdict.items():
-            for v, loc in vlist:
-                if sub is v:
-                    return k
-        return None
-
-    def getName(self):
-        r"""
-        Returns the results name for this token expression. Useful when several
-        different expressions might match at a particular location.
-
-        Example::
-
-            integer = Word(nums)
-            ssn_expr = Regex(r"\d\d\d-\d\d-\d\d\d\d")
-            house_number_expr = Suppress('#') + Word(nums, alphanums)
-            user_data = (Group(house_number_expr)("house_number")
-                        | Group(ssn_expr)("ssn")
-                        | Group(integer)("age"))
-            user_info = OneOrMore(user_data)
-
-            result = user_info.parseString("22 111-22-3333 #221B")
-            for item in result:
-                print(item.getName(), ':', item[0])
-
-        prints::
-
-            age : 22
-            ssn : 111-22-3333
-            house_number : 221B
-        """
-        if self.__name:
-            return self.__name
-        elif self.__parent:
-            par = self.__parent()
-            if par:
-                return par.__lookup(self)
-            else:
-                return None
-        elif (len(self) == 1
-              and len(self.__tokdict) == 1
-              and next(iter(self.__tokdict.values()))[0][1] in (0, -1)):
-            return next(iter(self.__tokdict.keys()))
-        else:
-            return None
-
-    def dump(self, indent='', full=True, include_list=True, _depth=0):
-        """
-        Diagnostic method for listing out the contents of
-        a :class:`ParseResults`. Accepts an optional ``indent`` argument so
-        that this string can be embedded in a nested display of other data.
-
-        Example::
-
-            integer = Word(nums)
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-
-            result = date_str.parseString('12/31/1999')
-            print(result.dump())
-
-        prints::
-
-            ['12', '/', '31', '/', '1999']
-            - day: 1999
-            - month: 31
-            - year: 12
-        """
-        out = []
-        NL = '\n'
-        if include_list:
-            out.append(indent + _ustr(self.asList()))
-        else:
-            out.append('')
-
-        if full:
-            if self.haskeys():
-                items = sorted((str(k), v) for k, v in self.items())
-                for k, v in items:
-                    if out:
-                        out.append(NL)
-                    out.append("%s%s- %s: " % (indent, ('  ' * _depth), k))
-                    if isinstance(v, ParseResults):
-                        if v:
-                            out.append(v.dump(indent=indent, full=full, include_list=include_list, _depth=_depth + 1))
-                        else:
-                            out.append(_ustr(v))
-                    else:
-                        out.append(repr(v))
-            elif any(isinstance(vv, ParseResults) for vv in self):
-                v = self
-                for i, vv in enumerate(v):
-                    if isinstance(vv, ParseResults):
-                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,
-                                                            ('  ' * (_depth)),
-                                                            i,
-                                                            indent,
-                                                            ('  ' * (_depth + 1)),
-                                                            vv.dump(indent=indent,
-                                                                    full=full,
-                                                                    include_list=include_list,
-                                                                    _depth=_depth + 1)))
-                    else:
-                        out.append("\n%s%s[%d]:\n%s%s%s" % (indent,
-                                                            ('  ' * (_depth)),
-                                                            i,
-                                                            indent,
-                                                            ('  ' * (_depth + 1)),
-                                                            _ustr(vv)))
-
-        return "".join(out)
-
-    def pprint(self, *args, **kwargs):
-        """
-        Pretty-printer for parsed results as a list, using the
-        `pprint <https://docs.python.org/3/library/pprint.html>`_ module.
-        Accepts additional positional or keyword args as defined for
-        `pprint.pprint <https://docs.python.org/3/library/pprint.html#pprint.pprint>`_ .
-
-        Example::
-
-            ident = Word(alphas, alphanums)
-            num = Word(nums)
-            func = Forward()
-            term = ident | num | Group('(' + func + ')')
-            func <<= ident + Group(Optional(delimitedList(term)))
-            result = func.parseString("fna a,b,(fnb c,d,200),100")
-            result.pprint(width=40)
-
-        prints::
-
-            ['fna',
-             ['a',
-              'b',
-              ['(', 'fnb', ['c', 'd', '200'], ')'],
-              '100']]
-        """
-        pprint.pprint(self.asList(), *args, **kwargs)
-
-    # add support for pickle protocol
-    def __getstate__(self):
-        return (self.__toklist,
-                (self.__tokdict.copy(),
-                 self.__parent is not None and self.__parent() or None,
-                 self.__accumNames,
-                 self.__name))
-
-    def __setstate__(self, state):
-        self.__toklist = state[0]
-        self.__tokdict, par, inAccumNames, self.__name = state[1]
-        self.__accumNames = {}
-        self.__accumNames.update(inAccumNames)
-        if par is not None:
-            self.__parent = wkref(par)
-        else:
-            self.__parent = None
-
-    def __getnewargs__(self):
-        return self.__toklist, self.__name, self.__asList, self.__modal
-
-    def __dir__(self):
-        return dir(type(self)) + list(self.keys())
-
-    @classmethod
-    def from_dict(cls, other, name=None):
-        """
-        Helper classmethod to construct a ParseResults from a dict, preserving the
-        name-value relations as results names. If an optional 'name' argument is
-        given, a nested ParseResults will be returned
-        """
-        def is_iterable(obj):
-            try:
-                iter(obj)
-            except Exception:
-                return False
-            else:
-                if PY_3:
-                    return not isinstance(obj, (str, bytes))
-                else:
-                    return not isinstance(obj, basestring)
-
-        ret = cls([])
-        for k, v in other.items():
-            if isinstance(v, Mapping):
-                ret += cls.from_dict(v, name=k)
-            else:
-                ret += cls([v], name=k, asList=is_iterable(v))
-        if name is not None:
-            ret = cls([ret], name=name)
-        return ret
-
-MutableMapping.register(ParseResults)
-
-def col (loc, strg):
-    """Returns current column within a string, counting newlines as line separators.
-   The first column is number 1.
-
-   Note: the default parsing behavior is to expand tabs in the input string
-   before starting the parsing process.  See
-   :class:`ParserElement.parseString` for more
-   information on parsing strings containing ``<TAB>`` s, and suggested
-   methods to maintain a consistent view of the parsed string, the parse
-   location, and line and column positions within the parsed string.
-   """
-    s = strg
-    return 1 if 0 < loc < len(s) and s[loc-1] == '\n' else loc - s.rfind("\n", 0, loc)
-
-def lineno(loc, strg):
-    """Returns current line number within a string, counting newlines as line separators.
-    The first line is number 1.
-
-    Note - the default parsing behavior is to expand tabs in the input string
-    before starting the parsing process.  See :class:`ParserElement.parseString`
-    for more information on parsing strings containing ``<TAB>`` s, and
-    suggested methods to maintain a consistent view of the parsed string, the
-    parse location, and line and column positions within the parsed string.
-    """
-    return strg.count("\n", 0, loc) + 1
-
-def line(loc, strg):
-    """Returns the line of text containing loc within a string, counting newlines as line separators.
-       """
-    lastCR = strg.rfind("\n", 0, loc)
-    nextCR = strg.find("\n", loc)
-    if nextCR >= 0:
-        return strg[lastCR + 1:nextCR]
-    else:
-        return strg[lastCR + 1:]
-
-def _defaultStartDebugAction(instring, loc, expr):
-    print(("Match " + _ustr(expr) + " at loc " + _ustr(loc) + "(%d,%d)" % (lineno(loc, instring), col(loc, instring))))
-
-def _defaultSuccessDebugAction(instring, startloc, endloc, expr, toks):
-    print("Matched " + _ustr(expr) + " -> " + str(toks.asList()))
-
-def _defaultExceptionDebugAction(instring, loc, expr, exc):
-    print("Exception raised:" + _ustr(exc))
-
-def nullDebugAction(*args):
-    """'Do-nothing' debug action, to suppress debugging output during parsing."""
-    pass
-
-# Only works on Python 3.x - nonlocal is toxic to Python 2 installs
-#~ 'decorator to trim function calls to match the arity of the target'
-#~ def _trim_arity(func, maxargs=3):
-    #~ if func in singleArgBuiltins:
-        #~ return lambda s,l,t: func(t)
-    #~ limit = 0
-    #~ foundArity = False
-    #~ def wrapper(*args):
-        #~ nonlocal limit,foundArity
-        #~ while 1:
-            #~ try:
-                #~ ret = func(*args[limit:])
-                #~ foundArity = True
-                #~ return ret
-            #~ except TypeError:
-                #~ if limit == maxargs or foundArity:
-                    #~ raise
-                #~ limit += 1
-                #~ continue
-    #~ return wrapper
-
-# this version is Python 2.x-3.x cross-compatible
-'decorator to trim function calls to match the arity of the target'
-def _trim_arity(func, maxargs=2):
-    if func in singleArgBuiltins:
-        return lambda s, l, t: func(t)
-    limit = [0]
-    foundArity = [False]
-
-    # traceback return data structure changed in Py3.5 - normalize back to plain tuples
-    if system_version[:2] >= (3, 5):
-        def extract_stack(limit=0):
-            # special handling for Python 3.5.0 - extra deep call stack by 1
-            offset = -3 if system_version == (3, 5, 0) else -2
-            frame_summary = traceback.extract_stack(limit=-offset + limit - 1)[offset]
-            return [frame_summary[:2]]
-        def extract_tb(tb, limit=0):
-            frames = traceback.extract_tb(tb, limit=limit)
-            frame_summary = frames[-1]
-            return [frame_summary[:2]]
-    else:
-        extract_stack = traceback.extract_stack
-        extract_tb = traceback.extract_tb
-
-    # synthesize what would be returned by traceback.extract_stack at the call to
-    # user's parse action 'func', so that we don't incur call penalty at parse time
-
-    LINE_DIFF = 6
-    # IF ANY CODE CHANGES, EVEN JUST COMMENTS OR BLANK LINES, BETWEEN THE NEXT LINE AND
-    # THE CALL TO FUNC INSIDE WRAPPER, LINE_DIFF MUST BE MODIFIED!!!!
-    this_line = extract_stack(limit=2)[-1]
-    pa_call_line_synth = (this_line[0], this_line[1] + LINE_DIFF)
-
-    def wrapper(*args):
-        while 1:
-            try:
-                ret = func(*args[limit[0]:])
-                foundArity[0] = True
-                return ret
-            except TypeError:
-                # re-raise TypeErrors if they did not come from our arity testing
-                if foundArity[0]:
-                    raise
-                else:
-                    try:
-                        tb = sys.exc_info()[-1]
-                        if not extract_tb(tb, limit=2)[-1][:2] == pa_call_line_synth:
-                            raise
-                    finally:
-                        try:
-                            del tb
-                        except NameError:
-                            pass
-
-                if limit[0] <= maxargs:
-                    limit[0] += 1
-                    continue
-                raise
-
-    # copy func name to wrapper for sensible debug output
-    func_name = "<parse action>"
-    try:
-        func_name = getattr(func, '__name__',
-                            getattr(func, '__class__').__name__)
-    except Exception:
-        func_name = str(func)
-    wrapper.__name__ = func_name
-
-    return wrapper
-
-
-class ParserElement(object):
-    """Abstract base level parser element class."""
-    DEFAULT_WHITE_CHARS = " \n\t\r"
-    verbose_stacktrace = False
-
-    @staticmethod
-    def setDefaultWhitespaceChars(chars):
-        r"""
-        Overrides the default whitespace chars
-
-        Example::
-
-            # default whitespace chars are space, <TAB> and newline
-            OneOrMore(Word(alphas)).parseString("abc def\nghi jkl")  # -> ['abc', 'def', 'ghi', 'jkl']
-
-            # change to just treat newline as significant
-            ParserElement.setDefaultWhitespaceChars(" \t")
-            OneOrMore(Word(alphas)).parseString("abc def\nghi jkl")  # -> ['abc', 'def']
-        """
-        ParserElement.DEFAULT_WHITE_CHARS = chars
-
-    @staticmethod
-    def inlineLiteralsUsing(cls):
-        """
-        Set class to be used for inclusion of string literals into a parser.
-
-        Example::
-
-            # default literal class used is Literal
-            integer = Word(nums)
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-
-            date_str.parseString("1999/12/31")  # -> ['1999', '/', '12', '/', '31']
-
-
-            # change to Suppress
-            ParserElement.inlineLiteralsUsing(Suppress)
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-
-            date_str.parseString("1999/12/31")  # -> ['1999', '12', '31']
-        """
-        ParserElement._literalStringClass = cls
-
-    @classmethod
-    def _trim_traceback(cls, tb):
-        while tb.tb_next:
-            tb = tb.tb_next
-        return tb
-
-    def __init__(self, savelist=False):
-        self.parseAction = list()
-        self.failAction = None
-        # ~ self.name = "<unknown>"  # don't define self.name, let subclasses try/except upcall
-        self.strRepr = None
-        self.resultsName = None
-        self.saveAsList = savelist
-        self.skipWhitespace = True
-        self.whiteChars = set(ParserElement.DEFAULT_WHITE_CHARS)
-        self.copyDefaultWhiteChars = True
-        self.mayReturnEmpty = False # used when checking for left-recursion
-        self.keepTabs = False
-        self.ignoreExprs = list()
-        self.debug = False
-        self.streamlined = False
-        self.mayIndexError = True # used to optimize exception handling for subclasses that don't advance parse index
-        self.errmsg = ""
-        self.modalResults = True # used to mark results names as modal (report only last) or cumulative (list all)
-        self.debugActions = (None, None, None)  # custom debug actions
-        self.re = None
-        self.callPreparse = True # used to avoid redundant calls to preParse
-        self.callDuringTry = False
-
-    def copy(self):
-        """
-        Make a copy of this :class:`ParserElement`.  Useful for defining
-        different parse actions for the same parsing pattern, using copies of
-        the original parse element.
-
-        Example::
-
-            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
-            integerK = integer.copy().addParseAction(lambda toks: toks[0] * 1024) + Suppress("K")
-            integerM = integer.copy().addParseAction(lambda toks: toks[0] * 1024 * 1024) + Suppress("M")
-
-            print(OneOrMore(integerK | integerM | integer).parseString("5K 100 640K 256M"))
-
-        prints::
-
-            [5120, 100, 655360, 268435456]
-
-        Equivalent form of ``expr.copy()`` is just ``expr()``::
-
-            integerM = integer().addParseAction(lambda toks: toks[0] * 1024 * 1024) + Suppress("M")
-        """
-        cpy = copy.copy(self)
-        cpy.parseAction = self.parseAction[:]
-        cpy.ignoreExprs = self.ignoreExprs[:]
-        if self.copyDefaultWhiteChars:
-            cpy.whiteChars = ParserElement.DEFAULT_WHITE_CHARS
-        return cpy
-
-    def setName(self, name):
-        """
-        Define name for this expression, makes debugging and exception messages clearer.
-
-        Example::
-
-            Word(nums).parseString("ABC")  # -> Exception: Expected W:(0123...) (at char 0), (line:1, col:1)
-            Word(nums).setName("integer").parseString("ABC")  # -> Exception: Expected integer (at char 0), (line:1, col:1)
-        """
-        self.name = name
-        self.errmsg = "Expected " + self.name
-        if __diag__.enable_debug_on_named_expressions:
-            self.setDebug()
-        return self
-
-    def setResultsName(self, name, listAllMatches=False):
-        """
-        Define name for referencing matching tokens as a nested attribute
-        of the returned parse results.
-        NOTE: this returns a *copy* of the original :class:`ParserElement` object;
-        this is so that the client can define a basic element, such as an
-        integer, and reference it in multiple places with different names.
-
-        You can also set results names using the abbreviated syntax,
-        ``expr("name")`` in place of ``expr.setResultsName("name")``
-        - see :class:`__call__`.
-
-        Example::
-
-            date_str = (integer.setResultsName("year") + '/'
-                        + integer.setResultsName("month") + '/'
-                        + integer.setResultsName("day"))
-
-            # equivalent form:
-            date_str = integer("year") + '/' + integer("month") + '/' + integer("day")
-        """
-        return self._setResultsName(name, listAllMatches)
-
-    def _setResultsName(self, name, listAllMatches=False):
-        newself = self.copy()
-        if name.endswith("*"):
-            name = name[:-1]
-            listAllMatches = True
-        newself.resultsName = name
-        newself.modalResults = not listAllMatches
-        return newself
-
-    def setBreak(self, breakFlag=True):
-        """Method to invoke the Python pdb debugger when this element is
-           about to be parsed. Set ``breakFlag`` to True to enable, False to
-           disable.
-        """
-        if breakFlag:
-            _parseMethod = self._parse
-            def breaker(instring, loc, doActions=True, callPreParse=True):
-                import pdb
-                # this call to pdb.set_trace() is intentional, not a checkin error
-                pdb.set_trace()
-                return _parseMethod(instring, loc, doActions, callPreParse)
-            breaker._originalParseMethod = _parseMethod
-            self._parse = breaker
-        else:
-            if hasattr(self._parse, "_originalParseMethod"):
-                self._parse = self._parse._originalParseMethod
-        return self
-
-    def setParseAction(self, *fns, **kwargs):
-        """
-        Define one or more actions to perform when successfully matching parse element definition.
-        Parse action fn is a callable method with 0-3 arguments, called as ``fn(s, loc, toks)`` ,
-        ``fn(loc, toks)`` , ``fn(toks)`` , or just ``fn()`` , where:
-
-        - s   = the original string being parsed (see note below)
-        - loc = the location of the matching substring
-        - toks = a list of the matched tokens, packaged as a :class:`ParseResults` object
-
-        If the functions in fns modify the tokens, they can return them as the return
-        value from fn, and the modified list of tokens will replace the original.
-        Otherwise, fn does not need to return any value.
-
-        If None is passed as the parse action, all previously added parse actions for this
-        expression are cleared.
-
-        Optional keyword arguments:
-        - callDuringTry = (default= ``False``) indicate if parse action should be run during lookaheads and alternate testing
-
-        Note: the default parsing behavior is to expand tabs in the input string
-        before starting the parsing process.  See :class:`parseString for more
-        information on parsing strings containing ``<TAB>`` s, and suggested
-        methods to maintain a consistent view of the parsed string, the parse
-        location, and line and column positions within the parsed string.
-
-        Example::
-
-            integer = Word(nums)
-            date_str = integer + '/' + integer + '/' + integer
-
-            date_str.parseString("1999/12/31")  # -> ['1999', '/', '12', '/', '31']
-
-            # use parse action to convert to ints at parse time
-            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
-            date_str = integer + '/' + integer + '/' + integer
-
-            # note that integer fields are now ints, not strings
-            date_str.parseString("1999/12/31")  # -> [1999, '/', 12, '/', 31]
-        """
-        if list(fns) == [None,]:
-            self.parseAction = []
-        else:
-            if not all(callable(fn) for fn in fns):
-                raise TypeError("parse actions must be callable")
-            self.parseAction = list(map(_trim_arity, list(fns)))
-            self.callDuringTry = kwargs.get("callDuringTry", False)
-        return self
-
-    def addParseAction(self, *fns, **kwargs):
-        """
-        Add one or more parse actions to expression's list of parse actions. See :class:`setParseAction`.
-
-        See examples in :class:`copy`.
-        """
-        self.parseAction += list(map(_trim_arity, list(fns)))
-        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
-        return self
-
-    def addCondition(self, *fns, **kwargs):
-        """Add a boolean predicate function to expression's list of parse actions. See
-        :class:`setParseAction` for function call signatures. Unlike ``setParseAction``,
-        functions passed to ``addCondition`` need to return boolean success/fail of the condition.
-
-        Optional keyword arguments:
-        - message = define a custom message to be used in the raised exception
-        - fatal   = if True, will raise ParseFatalException to stop parsing immediately; otherwise will raise ParseException
-
-        Example::
-
-            integer = Word(nums).setParseAction(lambda toks: int(toks[0]))
-            year_int = integer.copy()
-            year_int.addCondition(lambda toks: toks[0] >= 2000, message="Only support years 2000 and later")
-            date_str = year_int + '/' + integer + '/' + integer
-
-            result = date_str.parseString("1999/12/31")  # -> Exception: Only support years 2000 and later (at char 0), (line:1, col:1)
-        """
-        for fn in fns:
-            self.parseAction.append(conditionAsParseAction(fn, message=kwargs.get('message'),
-                                                           fatal=kwargs.get('fatal', False)))
-
-        self.callDuringTry = self.callDuringTry or kwargs.get("callDuringTry", False)
-        return self
-
-    def setFailAction(self, fn):
-        """Define action to perform if parsing fails at this expression.
-           Fail acton fn is a callable function that takes the arguments
-           ``fn(s, loc, expr, err)`` where:
-           - s = string being parsed
-           - loc = location where expression match was attempted and failed
-           - expr = the parse expression that failed
-           - err = the exception thrown
-           The function returns no value.  It may throw :class:`ParseFatalException`
-           if it is desired to stop parsing immediately."""
-        self.failAction = fn
-        return self
-
-    def _skipIgnorables(self, instring, loc):
-        exprsFound = True
-        while exprsFound:
-            exprsFound = False
-            for e in self.ignoreExprs:
-                try:
-                    while 1:
-                        loc, dummy = e._parse(instring, loc)
-                        exprsFound = True
-                except ParseException:
-                    pass
-        return loc
-
-    def preParse(self, instring, loc):
-        if self.ignoreExprs:
-            loc = self._skipIgnorables(instring, loc)
-
-        if self.skipWhitespace:
-            wt = self.whiteChars
-            instrlen = len(instring)
-            while loc < instrlen and instring[loc] in wt:
-                loc += 1
-
-        return loc
-
-    def parseImpl(self, instring, loc, doActions=True):
-        return loc, []
-
-    def postParse(self, instring, loc, tokenlist):
-        return tokenlist
-
-    # ~ @profile
-    def _parseNoCache(self, instring, loc, doActions=True, callPreParse=True):
-        TRY, MATCH, FAIL = 0, 1, 2
-        debugging = (self.debug)  # and doActions)
-
-        if debugging or self.failAction:
-            # ~ print ("Match", self, "at loc", loc, "(%d, %d)" % (lineno(loc, instring), col(loc, instring)))
-            if self.debugActions[TRY]:
-                self.debugActions[TRY](instring, loc, self)
-            try:
-                if callPreParse and self.callPreparse:
-                    preloc = self.preParse(instring, loc)
-                else:
-                    preloc = loc
-                tokensStart = preloc
-                if self.mayIndexError or preloc >= len(instring):
-                    try:
-                        loc, tokens = self.parseImpl(instring, preloc, doActions)
-                    except IndexError:
-                        raise ParseException(instring, len(instring), self.errmsg, self)
-                else:
-                    loc, tokens = self.parseImpl(instring, preloc, doActions)
-            except Exception as err:
-                # ~ print ("Exception raised:", err)
-                if self.debugActions[FAIL]:
-                    self.debugActions[FAIL](instring, tokensStart, self, err)
-                if self.failAction:
-                    self.failAction(instring, tokensStart, self, err)
-                raise
-        else:
-            if callPreParse and self.callPreparse:
-                preloc = self.preParse(instring, loc)
-            else:
-                preloc = loc
-            tokensStart = preloc
-            if self.mayIndexError or preloc >= len(instring):
-                try:
-                    loc, tokens = self.parseImpl(instring, preloc, doActions)
-                except IndexError:
-                    raise ParseException(instring, len(instring), self.errmsg, self)
-            else:
-                loc, tokens = self.parseImpl(instring, preloc, doActions)
-
-        tokens = self.postParse(instring, loc, tokens)
-
-        retTokens = ParseResults(tokens, self.resultsName, asList=self.saveAsList, modal=self.modalResults)
-        if self.parseAction and (doActions or self.callDuringTry):
-            if debugging:
-                try:
-                    for fn in self.parseAction:
-                        try:
-                            tokens = fn(instring, tokensStart, retTokens)
-                        except IndexError as parse_action_exc:
-                            exc = ParseException("exception raised in parse action")
-                            exc.__cause__ = parse_action_exc
-                            raise exc
-
-                        if tokens is not None and tokens is not retTokens:
-                            retTokens = ParseResults(tokens,
-                                                      self.resultsName,
-                                                      asList=self.saveAsList and isinstance(tokens, (ParseResults, list)),
-                                                      modal=self.modalResults)
-                except Exception as err:
-                    # ~ print "Exception raised in user parse action:", err
-                    if self.debugActions[FAIL]:
-                        self.debugActions[FAIL](instring, tokensStart, self, err)
-                    raise
-            else:
-                for fn in self.parseAction:
-                    try:
-                        tokens = fn(instring, tokensStart, retTokens)
-                    except IndexError as parse_action_exc:
-                        exc = ParseException("exception raised in parse action")
-                        exc.__cause__ = parse_action_exc
-                        raise exc
-
-                    if tokens is not None and tokens is not retTokens:
-                        retTokens = ParseResults(tokens,
-                                                  self.resultsName,
-                                                  asList=self.saveAsList and isinstance(tokens, (ParseResults, list)),
-                                                  modal=self.modalResults)
-        if debugging:
-            # ~ print ("Matched", self, "->", retTokens.asList())
-            if self.debugActions[MATCH]:
-                self.debugActions[MATCH](instring, tokensStart, loc, self, retTokens)
-
-        return loc, retTokens
-
-    def tryParse(self, instring, loc):
-        try:
-            return self._parse(instring, loc, doActions=False)[0]
-        except ParseFatalException:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-    def canParseNext(self, instring, loc):
-        try:
-            self.tryParse(instring, loc)
-        except (ParseException, IndexError):
-            return False
-        else:
-            return True
-
-    class _UnboundedCache(object):
-        def __init__(self):
-            cache = {}
-            self.not_in_cache = not_in_cache = object()
-
-            def get(self, key):
-                return cache.get(key, not_in_cache)
-
-            def set(self, key, value):
-                cache[key] = value
-
-            def clear(self):
-                cache.clear()
-
-            def cache_len(self):
-                return len(cache)
-
-            self.get = types.MethodType(get, self)
-            self.set = types.MethodType(set, self)
-            self.clear = types.MethodType(clear, self)
-            self.__len__ = types.MethodType(cache_len, self)
-
-    if _OrderedDict is not None:
-        class _FifoCache(object):
-            def __init__(self, size):
-                self.not_in_cache = not_in_cache = object()
-
-                cache = _OrderedDict()
-
-                def get(self, key):
-                    return cache.get(key, not_in_cache)
-
-                def set(self, key, value):
-                    cache[key] = value
-                    while len(cache) > size:
-                        try:
-                            cache.popitem(False)
-                        except KeyError:
-                            pass
-
-                def clear(self):
-                    cache.clear()
-
-                def cache_len(self):
-                    return len(cache)
-
-                self.get = types.MethodType(get, self)
-                self.set = types.MethodType(set, self)
-                self.clear = types.MethodType(clear, self)
-                self.__len__ = types.MethodType(cache_len, self)
-
-    else:
-        class _FifoCache(object):
-            def __init__(self, size):
-                self.not_in_cache = not_in_cache = object()
-
-                cache = {}
-                key_fifo = collections.deque([], size)
-
-                def get(self, key):
-                    return cache.get(key, not_in_cache)
-
-                def set(self, key, value):
-                    cache[key] = value
-                    while len(key_fifo) > size:
-                        cache.pop(key_fifo.popleft(), None)
-                    key_fifo.append(key)
-
-                def clear(self):
-                    cache.clear()
-                    key_fifo.clear()
-
-                def cache_len(self):
-                    return len(cache)
-
-                self.get = types.MethodType(get, self)
-                self.set = types.MethodType(set, self)
-                self.clear = types.MethodType(clear, self)
-                self.__len__ = types.MethodType(cache_len, self)
-
-    # argument cache for optimizing repeated calls when backtracking through recursive expressions
-    packrat_cache = {} # this is set later by enabledPackrat(); this is here so that resetCache() doesn't fail
-    packrat_cache_lock = RLock()
-    packrat_cache_stats = [0, 0]
-
-    # this method gets repeatedly called during backtracking with the same arguments -
-    # we can cache these arguments and save ourselves the trouble of re-parsing the contained expression
-    def _parseCache(self, instring, loc, doActions=True, callPreParse=True):
-        HIT, MISS = 0, 1
-        lookup = (self, instring, loc, callPreParse, doActions)
-        with ParserElement.packrat_cache_lock:
-            cache = ParserElement.packrat_cache
-            value = cache.get(lookup)
-            if value is cache.not_in_cache:
-                ParserElement.packrat_cache_stats[MISS] += 1
-                try:
-                    value = self._parseNoCache(instring, loc, doActions, callPreParse)
-                except ParseBaseException as pe:
-                    # cache a copy of the exception, without the traceback
-                    cache.set(lookup, pe.__class__(*pe.args))
-                    raise
-                else:
-                    cache.set(lookup, (value[0], value[1].copy()))
-                    return value
-            else:
-                ParserElement.packrat_cache_stats[HIT] += 1
-                if isinstance(value, Exception):
-                    raise value
-                return value[0], value[1].copy()
-
-    _parse = _parseNoCache
-
-    @staticmethod
-    def resetCache():
-        ParserElement.packrat_cache.clear()
-        ParserElement.packrat_cache_stats[:] = [0] * len(ParserElement.packrat_cache_stats)
-
-    _packratEnabled = False
-    @staticmethod
-    def enablePackrat(cache_size_limit=128):
-        """Enables "packrat" parsing, which adds memoizing to the parsing logic.
-           Repeated parse attempts at the same string location (which happens
-           often in many complex grammars) can immediately return a cached value,
-           instead of re-executing parsing/validating code.  Memoizing is done of
-           both valid results and parsing exceptions.
-
-           Parameters:
-
-           - cache_size_limit - (default= ``128``) - if an integer value is provided
-             will limit the size of the packrat cache; if None is passed, then
-             the cache size will be unbounded; if 0 is passed, the cache will
-             be effectively disabled.
-
-           This speedup may break existing programs that use parse actions that
-           have side-effects.  For this reason, packrat parsing is disabled when
-           you first import pyparsing.  To activate the packrat feature, your
-           program must call the class method :class:`ParserElement.enablePackrat`.
-           For best results, call ``enablePackrat()`` immediately after
-           importing pyparsing.
-
-           Example::
-
-               from pip._vendor import pyparsing
-               pyparsing.ParserElement.enablePackrat()
-        """
-        if not ParserElement._packratEnabled:
-            ParserElement._packratEnabled = True
-            if cache_size_limit is None:
-                ParserElement.packrat_cache = ParserElement._UnboundedCache()
-            else:
-                ParserElement.packrat_cache = ParserElement._FifoCache(cache_size_limit)
-            ParserElement._parse = ParserElement._parseCache
-
-    def parseString(self, instring, parseAll=False):
-        """
-        Execute the parse expression with the given string.
-        This is the main interface to the client code, once the complete
-        expression has been built.
-
-        Returns the parsed data as a :class:`ParseResults` object, which may be
-        accessed as a list, or as a dict or object with attributes if the given parser
-        includes results names.
-
-        If you want the grammar to require that the entire input string be
-        successfully parsed, then set ``parseAll`` to True (equivalent to ending
-        the grammar with ``StringEnd()``).
-
-        Note: ``parseString`` implicitly calls ``expandtabs()`` on the input string,
-        in order to report proper column numbers in parse actions.
-        If the input string contains tabs and
-        the grammar uses parse actions that use the ``loc`` argument to index into the
-        string being parsed, you can ensure you have a consistent view of the input
-        string by:
-
-        - calling ``parseWithTabs`` on your grammar before calling ``parseString``
-          (see :class:`parseWithTabs`)
-        - define your parse action using the full ``(s, loc, toks)`` signature, and
-          reference the input string using the parse action's ``s`` argument
-        - explictly expand the tabs in your input string before calling
-          ``parseString``
-
-        Example::
-
-            Word('a').parseString('aaaaabaaa')  # -> ['aaaaa']
-            Word('a').parseString('aaaaabaaa', parseAll=True)  # -> Exception: Expected end of text
-        """
-        ParserElement.resetCache()
-        if not self.streamlined:
-            self.streamline()
-            # ~ self.saveAsList = True
-        for e in self.ignoreExprs:
-            e.streamline()
-        if not self.keepTabs:
-            instring = instring.expandtabs()
-        try:
-            loc, tokens = self._parse(instring, 0)
-            if parseAll:
-                loc = self.preParse(instring, loc)
-                se = Empty() + StringEnd()
-                se._parse(instring, loc)
-        except ParseBaseException as exc:
-            if ParserElement.verbose_stacktrace:
-                raise
-            else:
-                # catch and re-raise exception from here, clearing out pyparsing internal stack trace
-                if getattr(exc, '__traceback__', None) is not None:
-                    exc.__traceback__ = self._trim_traceback(exc.__traceback__)
-                raise exc
-        else:
-            return tokens
-
-    def scanString(self, instring, maxMatches=_MAX_INT, overlap=False):
-        """
-        Scan the input string for expression matches.  Each match will return the
-        matching tokens, start location, and end location.  May be called with optional
-        ``maxMatches`` argument, to clip scanning after 'n' matches are found.  If
-        ``overlap`` is specified, then overlapping matches will be reported.
-
-        Note that the start and end locations are reported relative to the string
-        being parsed.  See :class:`parseString` for more information on parsing
-        strings with embedded tabs.
-
-        Example::
-
-            source = "sldjf123lsdjjkf345sldkjf879lkjsfd987"
-            print(source)
-            for tokens, start, end in Word(alphas).scanString(source):
-                print(' '*start + '^'*(end-start))
-                print(' '*start + tokens[0])
-
-        prints::
-
-            sldjf123lsdjjkf345sldkjf879lkjsfd987
-            ^^^^^
-            sldjf
-                    ^^^^^^^
-                    lsdjjkf
-                              ^^^^^^
-                              sldkjf
-                                       ^^^^^^
-                                       lkjsfd
-        """
-        if not self.streamlined:
-            self.streamline()
-        for e in self.ignoreExprs:
-            e.streamline()
-
-        if not self.keepTabs:
-            instring = _ustr(instring).expandtabs()
-        instrlen = len(instring)
-        loc = 0
-        preparseFn = self.preParse
-        parseFn = self._parse
-        ParserElement.resetCache()
-        matches = 0
-        try:
-            while loc <= instrlen and matches < maxMatches:
-                try:
-                    preloc = preparseFn(instring, loc)
-                    nextLoc, tokens = parseFn(instring, preloc, callPreParse=False)
-                except ParseException:
-                    loc = preloc + 1
-                else:
-                    if nextLoc > loc:
-                        matches += 1
-                        yield tokens, preloc, nextLoc
-                        if overlap:
-                            nextloc = preparseFn(instring, loc)
-                            if nextloc > loc:
-                                loc = nextLoc
-                            else:
-                                loc += 1
-                        else:
-                            loc = nextLoc
-                    else:
-                        loc = preloc + 1
-        except ParseBaseException as exc:
-            if ParserElement.verbose_stacktrace:
-                raise
-            else:
-                # catch and re-raise exception from here, clearing out pyparsing internal stack trace
-                if getattr(exc, '__traceback__', None) is not None:
-                    exc.__traceback__ = self._trim_traceback(exc.__traceback__)
-                raise exc
-
-    def transformString(self, instring):
-        """
-        Extension to :class:`scanString`, to modify matching text with modified tokens that may
-        be returned from a parse action.  To use ``transformString``, define a grammar and
-        attach a parse action to it that modifies the returned token list.
-        Invoking ``transformString()`` on a target string will then scan for matches,
-        and replace the matched text patterns according to the logic in the parse
-        action.  ``transformString()`` returns the resulting transformed string.
-
-        Example::
-
-            wd = Word(alphas)
-            wd.setParseAction(lambda toks: toks[0].title())
-
-            print(wd.transformString("now is the winter of our discontent made glorious summer by this sun of york."))
-
-        prints::
-
-            Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York.
-        """
-        out = []
-        lastE = 0
-        # force preservation of <TAB>s, to minimize unwanted transformation of string, and to
-        # keep string locs straight between transformString and scanString
-        self.keepTabs = True
-        try:
-            for t, s, e in self.scanString(instring):
-                out.append(instring[lastE:s])
-                if t:
-                    if isinstance(t, ParseResults):
-                        out += t.asList()
-                    elif isinstance(t, list):
-                        out += t
-                    else:
-                        out.append(t)
-                lastE = e
-            out.append(instring[lastE:])
-            out = [o for o in out if o]
-            return "".join(map(_ustr, _flatten(out)))
-        except ParseBaseException as exc:
-            if ParserElement.verbose_stacktrace:
-                raise
-            else:
-                # catch and re-raise exception from here, clearing out pyparsing internal stack trace
-                if getattr(exc, '__traceback__', None) is not None:
-                    exc.__traceback__ = self._trim_traceback(exc.__traceback__)
-                raise exc
-
-    def searchString(self, instring, maxMatches=_MAX_INT):
-        """
-        Another extension to :class:`scanString`, simplifying the access to the tokens found
-        to match the given parse expression.  May be called with optional
-        ``maxMatches`` argument, to clip searching after 'n' matches are found.
-
-        Example::
-
-            # a capitalized word starts with an uppercase letter, followed by zero or more lowercase letters
-            cap_word = Word(alphas.upper(), alphas.lower())
-
-            print(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity"))
-
-            # the sum() builtin can be used to merge results into a single ParseResults object
-            print(sum(cap_word.searchString("More than Iron, more than Lead, more than Gold I need Electricity")))
-
-        prints::
-
-            [['More'], ['Iron'], ['Lead'], ['Gold'], ['I'], ['Electricity']]
-            ['More', 'Iron', 'Lead', 'Gold', 'I', 'Electricity']
-        """
-        try:
-            return ParseResults([t for t, s, e in self.scanString(instring, maxMatches)])
-        except ParseBaseException as exc:
-            if ParserElement.verbose_stacktrace:
-                raise
-            else:
-                # catch and re-raise exception from here, clearing out pyparsing internal stack trace
-                if getattr(exc, '__traceback__', None) is not None:
-                    exc.__traceback__ = self._trim_traceback(exc.__traceback__)
-                raise exc
-
-    def split(self, instring, maxsplit=_MAX_INT, includeSeparators=False):
-        """
-        Generator method to split a string using the given expression as a separator.
-        May be called with optional ``maxsplit`` argument, to limit the number of splits;
-        and the optional ``includeSeparators`` argument (default= ``False``), if the separating
-        matching text should be included in the split results.
-
-        Example::
-
-            punc = oneOf(list(".,;:/-!?"))
-            print(list(punc.split("This, this?, this sentence, is badly punctuated!")))
-
-        prints::
-
-            ['This', ' this', '', ' this sentence', ' is badly punctuated', '']
-        """
-        splits = 0
-        last = 0
-        for t, s, e in self.scanString(instring, maxMatches=maxsplit):
-            yield instring[last:s]
-            if includeSeparators:
-                yield t[0]
-            last = e
-        yield instring[last:]
-
-    def __add__(self, other):
-        """
-        Implementation of + operator - returns :class:`And`. Adding strings to a ParserElement
-        converts them to :class:`Literal`s by default.
-
-        Example::
-
-            greet = Word(alphas) + "," + Word(alphas) + "!"
-            hello = "Hello, World!"
-            print (hello, "->", greet.parseString(hello))
-
-        prints::
-
-            Hello, World! -> ['Hello', ',', 'World', '!']
-
-        ``...`` may be used as a parse expression as a short form of :class:`SkipTo`.
-
-            Literal('start') + ... + Literal('end')
-
-        is equivalent to:
-
-            Literal('start') + SkipTo('end')("_skipped*") + Literal('end')
-
-        Note that the skipped text is returned with '_skipped' as a results name,
-        and to support having multiple skips in the same parser, the value returned is
-        a list of all skipped text.
-        """
-        if other is Ellipsis:
-            return _PendingSkip(self)
-
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return And([self, other])
-
-    def __radd__(self, other):
-        """
-        Implementation of + operator when left operand is not a :class:`ParserElement`
-        """
-        if other is Ellipsis:
-            return SkipTo(self)("_skipped*") + self
-
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return other + self
-
-    def __sub__(self, other):
-        """
-        Implementation of - operator, returns :class:`And` with error stop
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return self + And._ErrorStop() + other
-
-    def __rsub__(self, other):
-        """
-        Implementation of - operator when left operand is not a :class:`ParserElement`
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return other - self
-
-    def __mul__(self, other):
-        """
-        Implementation of * operator, allows use of ``expr * 3`` in place of
-        ``expr + expr + expr``.  Expressions may also me multiplied by a 2-integer
-        tuple, similar to ``{min, max}`` multipliers in regular expressions.  Tuples
-        may also include ``None`` as in:
-         - ``expr*(n, None)`` or ``expr*(n, )`` is equivalent
-              to ``expr*n + ZeroOrMore(expr)``
-              (read as "at least n instances of ``expr``")
-         - ``expr*(None, n)`` is equivalent to ``expr*(0, n)``
-              (read as "0 to n instances of ``expr``")
-         - ``expr*(None, None)`` is equivalent to ``ZeroOrMore(expr)``
-         - ``expr*(1, None)`` is equivalent to ``OneOrMore(expr)``
-
-        Note that ``expr*(None, n)`` does not raise an exception if
-        more than n exprs exist in the input stream; that is,
-        ``expr*(None, n)`` does not enforce a maximum number of expr
-        occurrences.  If this behavior is desired, then write
-        ``expr*(None, n) + ~expr``
-        """
-        if other is Ellipsis:
-            other = (0, None)
-        elif isinstance(other, tuple) and other[:1] == (Ellipsis,):
-            other = ((0, ) + other[1:] + (None,))[:2]
-
-        if isinstance(other, int):
-            minElements, optElements = other, 0
-        elif isinstance(other, tuple):
-            other = tuple(o if o is not Ellipsis else None for o in other)
-            other = (other + (None, None))[:2]
-            if other[0] is None:
-                other = (0, other[1])
-            if isinstance(other[0], int) and other[1] is None:
-                if other[0] == 0:
-                    return ZeroOrMore(self)
-                if other[0] == 1:
-                    return OneOrMore(self)
-                else:
-                    return self * other[0] + ZeroOrMore(self)
-            elif isinstance(other[0], int) and isinstance(other[1], int):
-                minElements, optElements = other
-                optElements -= minElements
-            else:
-                raise TypeError("cannot multiply 'ParserElement' and ('%s', '%s') objects", type(other[0]), type(other[1]))
-        else:
-            raise TypeError("cannot multiply 'ParserElement' and '%s' objects", type(other))
-
-        if minElements < 0:
-            raise ValueError("cannot multiply ParserElement by negative value")
-        if optElements < 0:
-            raise ValueError("second tuple value must be greater or equal to first tuple value")
-        if minElements == optElements == 0:
-            raise ValueError("cannot multiply ParserElement by 0 or (0, 0)")
-
-        if optElements:
-            def makeOptionalList(n):
-                if n > 1:
-                    return Optional(self + makeOptionalList(n - 1))
-                else:
-                    return Optional(self)
-            if minElements:
-                if minElements == 1:
-                    ret = self + makeOptionalList(optElements)
-                else:
-                    ret = And([self] * minElements) + makeOptionalList(optElements)
-            else:
-                ret = makeOptionalList(optElements)
-        else:
-            if minElements == 1:
-                ret = self
-            else:
-                ret = And([self] * minElements)
-        return ret
-
-    def __rmul__(self, other):
-        return self.__mul__(other)
-
-    def __or__(self, other):
-        """
-        Implementation of | operator - returns :class:`MatchFirst`
-        """
-        if other is Ellipsis:
-            return _PendingSkip(self, must_skip=True)
-
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return MatchFirst([self, other])
-
-    def __ror__(self, other):
-        """
-        Implementation of | operator when left operand is not a :class:`ParserElement`
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return other | self
-
-    def __xor__(self, other):
-        """
-        Implementation of ^ operator - returns :class:`Or`
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return Or([self, other])
-
-    def __rxor__(self, other):
-        """
-        Implementation of ^ operator when left operand is not a :class:`ParserElement`
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return other ^ self
-
-    def __and__(self, other):
-        """
-        Implementation of & operator - returns :class:`Each`
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return Each([self, other])
-
-    def __rand__(self, other):
-        """
-        Implementation of & operator when left operand is not a :class:`ParserElement`
-        """
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        if not isinstance(other, ParserElement):
-            warnings.warn("Cannot combine element of type %s with ParserElement" % type(other),
-                          SyntaxWarning, stacklevel=2)
-            return None
-        return other & self
-
-    def __invert__(self):
-        """
-        Implementation of ~ operator - returns :class:`NotAny`
-        """
-        return NotAny(self)
-
-    def __iter__(self):
-        # must implement __iter__ to override legacy use of sequential access to __getitem__ to
-        # iterate over a sequence
-        raise TypeError('%r object is not iterable' % self.__class__.__name__)
-
-    def __getitem__(self, key):
-        """
-        use ``[]`` indexing notation as a short form for expression repetition:
-         - ``expr[n]`` is equivalent to ``expr*n``
-         - ``expr[m, n]`` is equivalent to ``expr*(m, n)``
-         - ``expr[n, ...]`` or ``expr[n,]`` is equivalent
-              to ``expr*n + ZeroOrMore(expr)``
-              (read as "at least n instances of ``expr``")
-         - ``expr[..., n]`` is equivalent to ``expr*(0, n)``
-              (read as "0 to n instances of ``expr``")
-         - ``expr[...]`` and ``expr[0, ...]`` are equivalent to ``ZeroOrMore(expr)``
-         - ``expr[1, ...]`` is equivalent to ``OneOrMore(expr)``
-         ``None`` may be used in place of ``...``.
-
-        Note that ``expr[..., n]`` and ``expr[m, n]``do not raise an exception
-        if more than ``n`` ``expr``s exist in the input stream.  If this behavior is
-        desired, then write ``expr[..., n] + ~expr``.
-       """
-
-        # convert single arg keys to tuples
-        try:
-            if isinstance(key, str):
-                key = (key,)
-            iter(key)
-        except TypeError:
-            key = (key, key)
-
-        if len(key) > 2:
-            warnings.warn("only 1 or 2 index arguments supported ({0}{1})".format(key[:5],
-                                                                                '... [{0}]'.format(len(key))
-                                                                                if len(key) > 5 else ''))
-
-        # clip to 2 elements
-        ret = self * tuple(key[:2])
-        return ret
-
-    def __call__(self, name=None):
-        """
-        Shortcut for :class:`setResultsName`, with ``listAllMatches=False``.
-
-        If ``name`` is given with a trailing ``'*'`` character, then ``listAllMatches`` will be
-        passed as ``True``.
-
-        If ``name` is omitted, same as calling :class:`copy`.
-
-        Example::
-
-            # these are equivalent
-            userdata = Word(alphas).setResultsName("name") + Word(nums + "-").setResultsName("socsecno")
-            userdata = Word(alphas)("name") + Word(nums + "-")("socsecno")
-        """
-        if name is not None:
-            return self._setResultsName(name)
-        else:
-            return self.copy()
-
-    def suppress(self):
-        """
-        Suppresses the output of this :class:`ParserElement`; useful to keep punctuation from
-        cluttering up returned output.
-        """
-        return Suppress(self)
-
-    def leaveWhitespace(self):
-        """
-        Disables the skipping of whitespace before matching the characters in the
-        :class:`ParserElement`'s defined pattern.  This is normally only used internally by
-        the pyparsing module, but may be needed in some whitespace-sensitive grammars.
-        """
-        self.skipWhitespace = False
-        return self
-
-    def setWhitespaceChars(self, chars):
-        """
-        Overrides the default whitespace chars
-        """
-        self.skipWhitespace = True
-        self.whiteChars = chars
-        self.copyDefaultWhiteChars = False
-        return self
-
-    def parseWithTabs(self):
-        """
-        Overrides default behavior to expand ``<TAB>``s to spaces before parsing the input string.
-        Must be called before ``parseString`` when the input grammar contains elements that
-        match ``<TAB>`` characters.
-        """
-        self.keepTabs = True
-        return self
-
-    def ignore(self, other):
-        """
-        Define expression to be ignored (e.g., comments) while doing pattern
-        matching; may be called repeatedly, to define multiple comment or other
-        ignorable patterns.
-
-        Example::
-
-            patt = OneOrMore(Word(alphas))
-            patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj']
-
-            patt.ignore(cStyleComment)
-            patt.parseString('ablaj /* comment */ lskjd') # -> ['ablaj', 'lskjd']
-        """
-        if isinstance(other, basestring):
-            other = Suppress(other)
-
-        if isinstance(other, Suppress):
-            if other not in self.ignoreExprs:
-                self.ignoreExprs.append(other)
-        else:
-            self.ignoreExprs.append(Suppress(other.copy()))
-        return self
-
-    def setDebugActions(self, startAction, successAction, exceptionAction):
-        """
-        Enable display of debugging messages while doing pattern matching.
-        """
-        self.debugActions = (startAction or _defaultStartDebugAction,
-                             successAction or _defaultSuccessDebugAction,
-                             exceptionAction or _defaultExceptionDebugAction)
-        self.debug = True
-        return self
-
-    def setDebug(self, flag=True):
-        """
-        Enable display of debugging messages while doing pattern matching.
-        Set ``flag`` to True to enable, False to disable.
-
-        Example::
-
-            wd = Word(alphas).setName("alphaword")
-            integer = Word(nums).setName("numword")
-            term = wd | integer
-
-            # turn on debugging for wd
-            wd.setDebug()
-
-            OneOrMore(term).parseString("abc 123 xyz 890")
-
-        prints::
-
-            Match alphaword at loc 0(1,1)
-            Matched alphaword -> ['abc']
-            Match alphaword at loc 3(1,4)
-            Exception raised:Expected alphaword (at char 4), (line:1, col:5)
-            Match alphaword at loc 7(1,8)
-            Matched alphaword -> ['xyz']
-            Match alphaword at loc 11(1,12)
-            Exception raised:Expected alphaword (at char 12), (line:1, col:13)
-            Match alphaword at loc 15(1,16)
-            Exception raised:Expected alphaword (at char 15), (line:1, col:16)
-
-        The output shown is that produced by the default debug actions - custom debug actions can be
-        specified using :class:`setDebugActions`. Prior to attempting
-        to match the ``wd`` expression, the debugging message ``"Match <exprname> at loc <n>(<line>,<col>)"``
-        is shown. Then if the parse succeeds, a ``"Matched"`` message is shown, or an ``"Exception raised"``
-        message is shown. Also note the use of :class:`setName` to assign a human-readable name to the expression,
-        which makes debugging and exception messages easier to understand - for instance, the default
-        name created for the :class:`Word` expression without calling ``setName`` is ``"W:(ABCD...)"``.
-        """
-        if flag:
-            self.setDebugActions(_defaultStartDebugAction, _defaultSuccessDebugAction, _defaultExceptionDebugAction)
-        else:
-            self.debug = False
-        return self
-
-    def __str__(self):
-        return self.name
-
-    def __repr__(self):
-        return _ustr(self)
-
-    def streamline(self):
-        self.streamlined = True
-        self.strRepr = None
-        return self
-
-    def checkRecursion(self, parseElementList):
-        pass
-
-    def validate(self, validateTrace=None):
-        """
-        Check defined expressions for valid structure, check for infinite recursive definitions.
-        """
-        self.checkRecursion([])
-
-    def parseFile(self, file_or_filename, parseAll=False):
-        """
-        Execute the parse expression on the given file or filename.
-        If a filename is specified (instead of a file object),
-        the entire file is opened, read, and closed before parsing.
-        """
-        try:
-            file_contents = file_or_filename.read()
-        except AttributeError:
-            with open(file_or_filename, "r") as f:
-                file_contents = f.read()
-        try:
-            return self.parseString(file_contents, parseAll)
-        except ParseBaseException as exc:
-            if ParserElement.verbose_stacktrace:
-                raise
-            else:
-                # catch and re-raise exception from here, clearing out pyparsing internal stack trace
-                if getattr(exc, '__traceback__', None) is not None:
-                    exc.__traceback__ = self._trim_traceback(exc.__traceback__)
-                raise exc
-
-    def __eq__(self, other):
-        if self is other:
-            return True
-        elif isinstance(other, basestring):
-            return self.matches(other)
-        elif isinstance(other, ParserElement):
-            return vars(self) == vars(other)
-        return False
-
-    def __ne__(self, other):
-        return not (self == other)
-
-    def __hash__(self):
-        return id(self)
-
-    def __req__(self, other):
-        return self == other
-
-    def __rne__(self, other):
-        return not (self == other)
-
-    def matches(self, testString, parseAll=True):
-        """
-        Method for quick testing of a parser against a test string. Good for simple
-        inline microtests of sub expressions while building up larger parser.
-
-        Parameters:
-         - testString - to test against this expression for a match
-         - parseAll - (default= ``True``) - flag to pass to :class:`parseString` when running tests
-
-        Example::
-
-            expr = Word(nums)
-            assert expr.matches("100")
-        """
-        try:
-            self.parseString(_ustr(testString), parseAll=parseAll)
-            return True
-        except ParseBaseException:
-            return False
-
-    def runTests(self, tests, parseAll=True, comment='#',
-                 fullDump=True, printResults=True, failureTests=False, postParse=None,
-                 file=None):
-        """
-        Execute the parse expression on a series of test strings, showing each
-        test, the parsed results or where the parse failed. Quick and easy way to
-        run a parse expression against a list of sample strings.
-
-        Parameters:
-         - tests - a list of separate test strings, or a multiline string of test strings
-         - parseAll - (default= ``True``) - flag to pass to :class:`parseString` when running tests
-         - comment - (default= ``'#'``) - expression for indicating embedded comments in the test
-              string; pass None to disable comment filtering
-         - fullDump - (default= ``True``) - dump results as list followed by results names in nested outline;
-              if False, only dump nested list
-         - printResults - (default= ``True``) prints test output to stdout
-         - failureTests - (default= ``False``) indicates if these tests are expected to fail parsing
-         - postParse - (default= ``None``) optional callback for successful parse results; called as
-              `fn(test_string, parse_results)` and returns a string to be added to the test output
-         - file - (default=``None``) optional file-like object to which test output will be written;
-              if None, will default to ``sys.stdout``
-
-        Returns: a (success, results) tuple, where success indicates that all tests succeeded
-        (or failed if ``failureTests`` is True), and the results contain a list of lines of each
-        test's output
-
-        Example::
-
-            number_expr = pyparsing_common.number.copy()
-
-            result = number_expr.runTests('''
-                # unsigned integer
-                100
-                # negative integer
-                -100
-                # float with scientific notation
-                6.02e23
-                # integer with scientific notation
-                1e-12
-                ''')
-            print("Success" if result[0] else "Failed!")
-
-            result = number_expr.runTests('''
-                # stray character
-                100Z
-                # missing leading digit before '.'
-                -.100
-                # too many '.'
-                3.14.159
-                ''', failureTests=True)
-            print("Success" if result[0] else "Failed!")
-
-        prints::
-
-            # unsigned integer
-            100
-            [100]
-
-            # negative integer
-            -100
-            [-100]
-
-            # float with scientific notation
-            6.02e23
-            [6.02e+23]
-
-            # integer with scientific notation
-            1e-12
-            [1e-12]
-
-            Success
-
-            # stray character
-            100Z
-               ^
-            FAIL: Expected end of text (at char 3), (line:1, col:4)
-
-            # missing leading digit before '.'
-            -.100
-            ^
-            FAIL: Expected {real number with scientific notation | real number | signed integer} (at char 0), (line:1, col:1)
-
-            # too many '.'
-            3.14.159
-                ^
-            FAIL: Expected end of text (at char 4), (line:1, col:5)
-
-            Success
-
-        Each test string must be on a single line. If you want to test a string that spans multiple
-        lines, create a test like this::
-
-            expr.runTest(r"this is a test\\n of strings that spans \\n 3 lines")
-
-        (Note that this is a raw string literal, you must include the leading 'r'.)
-        """
-        if isinstance(tests, basestring):
-            tests = list(map(str.strip, tests.rstrip().splitlines()))
-        if isinstance(comment, basestring):
-            comment = Literal(comment)
-        if file is None:
-            file = sys.stdout
-        print_ = file.write
-
-        allResults = []
-        comments = []
-        success = True
-        NL = Literal(r'\n').addParseAction(replaceWith('\n')).ignore(quotedString)
-        BOM = u'\ufeff'
-        for t in tests:
-            if comment is not None and comment.matches(t, False) or comments and not t:
-                comments.append(t)
-                continue
-            if not t:
-                continue
-            out = ['\n' + '\n'.join(comments) if comments else '', t]
-            comments = []
-            try:
-                # convert newline marks to actual newlines, and strip leading BOM if present
-                t = NL.transformString(t.lstrip(BOM))
-                result = self.parseString(t, parseAll=parseAll)
-            except ParseBaseException as pe:
-                fatal = "(FATAL)" if isinstance(pe, ParseFatalException) else ""
-                if '\n' in t:
-                    out.append(line(pe.loc, t))
-                    out.append(' ' * (col(pe.loc, t) - 1) + '^' + fatal)
-                else:
-                    out.append(' ' * pe.loc + '^' + fatal)
-                out.append("FAIL: " + str(pe))
-                success = success and failureTests
-                result = pe
-            except Exception as exc:
-                out.append("FAIL-EXCEPTION: " + str(exc))
-                success = success and failureTests
-                result = exc
-            else:
-                success = success and not failureTests
-                if postParse is not None:
-                    try:
-                        pp_value = postParse(t, result)
-                        if pp_value is not None:
-                            if isinstance(pp_value, ParseResults):
-                                out.append(pp_value.dump())
-                            else:
-                                out.append(str(pp_value))
-                        else:
-                            out.append(result.dump())
-                    except Exception as e:
-                        out.append(result.dump(full=fullDump))
-                        out.append("{0} failed: {1}: {2}".format(postParse.__name__, type(e).__name__, e))
-                else:
-                    out.append(result.dump(full=fullDump))
-
-            if printResults:
-                if fullDump:
-                    out.append('')
-                print_('\n'.join(out))
-
-            allResults.append((t, result))
-
-        return success, allResults
-
-
-class _PendingSkip(ParserElement):
-    # internal placeholder class to hold a place were '...' is added to a parser element,
-    # once another ParserElement is added, this placeholder will be replaced with a SkipTo
-    def __init__(self, expr, must_skip=False):
-        super(_PendingSkip, self).__init__()
-        self.strRepr = str(expr + Empty()).replace('Empty', '...')
-        self.name = self.strRepr
-        self.anchor = expr
-        self.must_skip = must_skip
-
-    def __add__(self, other):
-        skipper = SkipTo(other).setName("...")("_skipped*")
-        if self.must_skip:
-            def must_skip(t):
-                if not t._skipped or t._skipped.asList() == ['']:
-                    del t[0]
-                    t.pop("_skipped", None)
-            def show_skip(t):
-                if t._skipped.asList()[-1:] == ['']:
-                    skipped = t.pop('_skipped')
-                    t['_skipped'] = 'missing <' + repr(self.anchor) + '>'
-            return (self.anchor + skipper().addParseAction(must_skip)
-                    | skipper().addParseAction(show_skip)) + other
-
-        return self.anchor + skipper + other
-
-    def __repr__(self):
-        return self.strRepr
-
-    def parseImpl(self, *args):
-        raise Exception("use of `...` expression without following SkipTo target expression")
-
-
-class Token(ParserElement):
-    """Abstract :class:`ParserElement` subclass, for defining atomic
-    matching patterns.
-    """
-    def __init__(self):
-        super(Token, self).__init__(savelist=False)
-
-
-class Empty(Token):
-    """An empty token, will always match.
-    """
-    def __init__(self):
-        super(Empty, self).__init__()
-        self.name = "Empty"
-        self.mayReturnEmpty = True
-        self.mayIndexError = False
-
-
-class NoMatch(Token):
-    """A token that will never match.
-    """
-    def __init__(self):
-        super(NoMatch, self).__init__()
-        self.name = "NoMatch"
-        self.mayReturnEmpty = True
-        self.mayIndexError = False
-        self.errmsg = "Unmatchable token"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        raise ParseException(instring, loc, self.errmsg, self)
-
-
-class Literal(Token):
-    """Token to exactly match a specified string.
-
-    Example::
-
-        Literal('blah').parseString('blah')  # -> ['blah']
-        Literal('blah').parseString('blahfooblah')  # -> ['blah']
-        Literal('blah').parseString('bla')  # -> Exception: Expected "blah"
-
-    For case-insensitive matching, use :class:`CaselessLiteral`.
-
-    For keyword matching (force word break before and after the matched string),
-    use :class:`Keyword` or :class:`CaselessKeyword`.
-    """
-    def __init__(self, matchString):
-        super(Literal, self).__init__()
-        self.match = matchString
-        self.matchLen = len(matchString)
-        try:
-            self.firstMatchChar = matchString[0]
-        except IndexError:
-            warnings.warn("null string passed to Literal; use Empty() instead",
-                            SyntaxWarning, stacklevel=2)
-            self.__class__ = Empty
-        self.name = '"%s"' % _ustr(self.match)
-        self.errmsg = "Expected " + self.name
-        self.mayReturnEmpty = False
-        self.mayIndexError = False
-
-        # Performance tuning: modify __class__ to select
-        # a parseImpl optimized for single-character check
-        if self.matchLen == 1 and type(self) is Literal:
-            self.__class__ = _SingleCharLiteral
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if instring[loc] == self.firstMatchChar and instring.startswith(self.match, loc):
-            return loc + self.matchLen, self.match
-        raise ParseException(instring, loc, self.errmsg, self)
-
-class _SingleCharLiteral(Literal):
-    def parseImpl(self, instring, loc, doActions=True):
-        if instring[loc] == self.firstMatchChar:
-            return loc + 1, self.match
-        raise ParseException(instring, loc, self.errmsg, self)
-
-_L = Literal
-ParserElement._literalStringClass = Literal
-
-class Keyword(Token):
-    """Token to exactly match a specified string as a keyword, that is,
-    it must be immediately followed by a non-keyword character.  Compare
-    with :class:`Literal`:
-
-     - ``Literal("if")`` will match the leading ``'if'`` in
-       ``'ifAndOnlyIf'``.
-     - ``Keyword("if")`` will not; it will only match the leading
-       ``'if'`` in ``'if x=1'``, or ``'if(y==2)'``
-
-    Accepts two optional constructor arguments in addition to the
-    keyword string:
-
-     - ``identChars`` is a string of characters that would be valid
-       identifier characters, defaulting to all alphanumerics + "_" and
-       "$"
-     - ``caseless`` allows case-insensitive matching, default is ``False``.
-
-    Example::
-
-        Keyword("start").parseString("start")  # -> ['start']
-        Keyword("start").parseString("starting")  # -> Exception
-
-    For case-insensitive matching, use :class:`CaselessKeyword`.
-    """
-    DEFAULT_KEYWORD_CHARS = alphanums + "_$"
-
-    def __init__(self, matchString, identChars=None, caseless=False):
-        super(Keyword, self).__init__()
-        if identChars is None:
-            identChars = Keyword.DEFAULT_KEYWORD_CHARS
-        self.match = matchString
-        self.matchLen = len(matchString)
-        try:
-            self.firstMatchChar = matchString[0]
-        except IndexError:
-            warnings.warn("null string passed to Keyword; use Empty() instead",
-                          SyntaxWarning, stacklevel=2)
-        self.name = '"%s"' % self.match
-        self.errmsg = "Expected " + self.name
-        self.mayReturnEmpty = False
-        self.mayIndexError = False
-        self.caseless = caseless
-        if caseless:
-            self.caselessmatch = matchString.upper()
-            identChars = identChars.upper()
-        self.identChars = set(identChars)
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if self.caseless:
-            if ((instring[loc:loc + self.matchLen].upper() == self.caselessmatch)
-                    and (loc >= len(instring) - self.matchLen
-                         or instring[loc + self.matchLen].upper() not in self.identChars)
-                    and (loc == 0
-                         or instring[loc - 1].upper() not in self.identChars)):
-                return loc + self.matchLen, self.match
-
-        else:
-            if instring[loc] == self.firstMatchChar:
-                if ((self.matchLen == 1 or instring.startswith(self.match, loc))
-                        and (loc >= len(instring) - self.matchLen
-                             or instring[loc + self.matchLen] not in self.identChars)
-                        and (loc == 0 or instring[loc - 1] not in self.identChars)):
-                    return loc + self.matchLen, self.match
-
-        raise ParseException(instring, loc, self.errmsg, self)
-
-    def copy(self):
-        c = super(Keyword, self).copy()
-        c.identChars = Keyword.DEFAULT_KEYWORD_CHARS
-        return c
-
-    @staticmethod
-    def setDefaultKeywordChars(chars):
-        """Overrides the default Keyword chars
-        """
-        Keyword.DEFAULT_KEYWORD_CHARS = chars
-
-class CaselessLiteral(Literal):
-    """Token to match a specified string, ignoring case of letters.
-    Note: the matched results will always be in the case of the given
-    match string, NOT the case of the input text.
-
-    Example::
-
-        OneOrMore(CaselessLiteral("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD', 'CMD']
-
-    (Contrast with example for :class:`CaselessKeyword`.)
-    """
-    def __init__(self, matchString):
-        super(CaselessLiteral, self).__init__(matchString.upper())
-        # Preserve the defining literal.
-        self.returnString = matchString
-        self.name = "'%s'" % self.returnString
-        self.errmsg = "Expected " + self.name
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if instring[loc:loc + self.matchLen].upper() == self.match:
-            return loc + self.matchLen, self.returnString
-        raise ParseException(instring, loc, self.errmsg, self)
-
-class CaselessKeyword(Keyword):
-    """
-    Caseless version of :class:`Keyword`.
-
-    Example::
-
-        OneOrMore(CaselessKeyword("CMD")).parseString("cmd CMD Cmd10") # -> ['CMD', 'CMD']
-
-    (Contrast with example for :class:`CaselessLiteral`.)
-    """
-    def __init__(self, matchString, identChars=None):
-        super(CaselessKeyword, self).__init__(matchString, identChars, caseless=True)
-
-class CloseMatch(Token):
-    """A variation on :class:`Literal` which matches "close" matches,
-    that is, strings with at most 'n' mismatching characters.
-    :class:`CloseMatch` takes parameters:
-
-     - ``match_string`` - string to be matched
-     - ``maxMismatches`` - (``default=1``) maximum number of
-       mismatches allowed to count as a match
-
-    The results from a successful parse will contain the matched text
-    from the input string and the following named results:
-
-     - ``mismatches`` - a list of the positions within the
-       match_string where mismatches were found
-     - ``original`` - the original match_string used to compare
-       against the input string
-
-    If ``mismatches`` is an empty list, then the match was an exact
-    match.
-
-    Example::
-
-        patt = CloseMatch("ATCATCGAATGGA")
-        patt.parseString("ATCATCGAAXGGA") # -> (['ATCATCGAAXGGA'], {'mismatches': [[9]], 'original': ['ATCATCGAATGGA']})
-        patt.parseString("ATCAXCGAAXGGA") # -> Exception: Expected 'ATCATCGAATGGA' (with up to 1 mismatches) (at char 0), (line:1, col:1)
-
-        # exact match
-        patt.parseString("ATCATCGAATGGA") # -> (['ATCATCGAATGGA'], {'mismatches': [[]], 'original': ['ATCATCGAATGGA']})
-
-        # close match allowing up to 2 mismatches
-        patt = CloseMatch("ATCATCGAATGGA", maxMismatches=2)
-        patt.parseString("ATCAXCGAAXGGA") # -> (['ATCAXCGAAXGGA'], {'mismatches': [[4, 9]], 'original': ['ATCATCGAATGGA']})
-    """
-    def __init__(self, match_string, maxMismatches=1):
-        super(CloseMatch, self).__init__()
-        self.name = match_string
-        self.match_string = match_string
-        self.maxMismatches = maxMismatches
-        self.errmsg = "Expected %r (with up to %d mismatches)" % (self.match_string, self.maxMismatches)
-        self.mayIndexError = False
-        self.mayReturnEmpty = False
-
-    def parseImpl(self, instring, loc, doActions=True):
-        start = loc
-        instrlen = len(instring)
-        maxloc = start + len(self.match_string)
-
-        if maxloc <= instrlen:
-            match_string = self.match_string
-            match_stringloc = 0
-            mismatches = []
-            maxMismatches = self.maxMismatches
-
-            for match_stringloc, s_m in enumerate(zip(instring[loc:maxloc], match_string)):
-                src, mat = s_m
-                if src != mat:
-                    mismatches.append(match_stringloc)
-                    if len(mismatches) > maxMismatches:
-                        break
-            else:
-                loc = match_stringloc + 1
-                results = ParseResults([instring[start:loc]])
-                results['original'] = match_string
-                results['mismatches'] = mismatches
-                return loc, results
-
-        raise ParseException(instring, loc, self.errmsg, self)
-
-
-class Word(Token):
-    """Token for matching words composed of allowed character sets.
-    Defined with string containing all allowed initial characters, an
-    optional string containing allowed body characters (if omitted,
-    defaults to the initial character set), and an optional minimum,
-    maximum, and/or exact length.  The default value for ``min`` is
-    1 (a minimum value < 1 is not valid); the default values for
-    ``max`` and ``exact`` are 0, meaning no maximum or exact
-    length restriction. An optional ``excludeChars`` parameter can
-    list characters that might be found in the input ``bodyChars``
-    string; useful to define a word of all printables except for one or
-    two characters, for instance.
-
-    :class:`srange` is useful for defining custom character set strings
-    for defining ``Word`` expressions, using range notation from
-    regular expression character sets.
-
-    A common mistake is to use :class:`Word` to match a specific literal
-    string, as in ``Word("Address")``. Remember that :class:`Word`
-    uses the string argument to define *sets* of matchable characters.
-    This expression would match "Add", "AAA", "dAred", or any other word
-    made up of the characters 'A', 'd', 'r', 'e', and 's'. To match an
-    exact literal string, use :class:`Literal` or :class:`Keyword`.
-
-    pyparsing includes helper strings for building Words:
-
-     - :class:`alphas`
-     - :class:`nums`
-     - :class:`alphanums`
-     - :class:`hexnums`
-     - :class:`alphas8bit` (alphabetic characters in ASCII range 128-255
-       - accented, tilded, umlauted, etc.)
-     - :class:`punc8bit` (non-alphabetic characters in ASCII range
-       128-255 - currency, symbols, superscripts, diacriticals, etc.)
-     - :class:`printables` (any non-whitespace character)
-
-    Example::
-
-        # a word composed of digits
-        integer = Word(nums) # equivalent to Word("0123456789") or Word(srange("0-9"))
-
-        # a word with a leading capital, and zero or more lowercase
-        capital_word = Word(alphas.upper(), alphas.lower())
-
-        # hostnames are alphanumeric, with leading alpha, and '-'
-        hostname = Word(alphas, alphanums + '-')
-
-        # roman numeral (not a strict parser, accepts invalid mix of characters)
-        roman = Word("IVXLCDM")
-
-        # any string of non-whitespace characters, except for ','
-        csv_value = Word(printables, excludeChars=",")
-    """
-    def __init__(self, initChars, bodyChars=None, min=1, max=0, exact=0, asKeyword=False, excludeChars=None):
-        super(Word, self).__init__()
-        if excludeChars:
-            excludeChars = set(excludeChars)
-            initChars = ''.join(c for c in initChars if c not in excludeChars)
-            if bodyChars:
-                bodyChars = ''.join(c for c in bodyChars if c not in excludeChars)
-        self.initCharsOrig = initChars
-        self.initChars = set(initChars)
-        if bodyChars:
-            self.bodyCharsOrig = bodyChars
-            self.bodyChars = set(bodyChars)
-        else:
-            self.bodyCharsOrig = initChars
-            self.bodyChars = set(initChars)
-
-        self.maxSpecified = max > 0
-
-        if min < 1:
-            raise ValueError("cannot specify a minimum length < 1; use Optional(Word()) if zero-length word is permitted")
-
-        self.minLen = min
-
-        if max > 0:
-            self.maxLen = max
-        else:
-            self.maxLen = _MAX_INT
-
-        if exact > 0:
-            self.maxLen = exact
-            self.minLen = exact
-
-        self.name = _ustr(self)
-        self.errmsg = "Expected " + self.name
-        self.mayIndexError = False
-        self.asKeyword = asKeyword
-
-        if ' ' not in self.initCharsOrig + self.bodyCharsOrig and (min == 1 and max == 0 and exact == 0):
-            if self.bodyCharsOrig == self.initCharsOrig:
-                self.reString = "[%s]+" % _escapeRegexRangeChars(self.initCharsOrig)
-            elif len(self.initCharsOrig) == 1:
-                self.reString = "%s[%s]*" % (re.escape(self.initCharsOrig),
-                                             _escapeRegexRangeChars(self.bodyCharsOrig),)
-            else:
-                self.reString = "[%s][%s]*" % (_escapeRegexRangeChars(self.initCharsOrig),
-                                               _escapeRegexRangeChars(self.bodyCharsOrig),)
-            if self.asKeyword:
-                self.reString = r"\b" + self.reString + r"\b"
-
-            try:
-                self.re = re.compile(self.reString)
-            except Exception:
-                self.re = None
-            else:
-                self.re_match = self.re.match
-                self.__class__ = _WordRegex
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if instring[loc] not in self.initChars:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        start = loc
-        loc += 1
-        instrlen = len(instring)
-        bodychars = self.bodyChars
-        maxloc = start + self.maxLen
-        maxloc = min(maxloc, instrlen)
-        while loc < maxloc and instring[loc] in bodychars:
-            loc += 1
-
-        throwException = False
-        if loc - start < self.minLen:
-            throwException = True
-        elif self.maxSpecified and loc < instrlen and instring[loc] in bodychars:
-            throwException = True
-        elif self.asKeyword:
-            if (start > 0 and instring[start - 1] in bodychars
-                    or loc < instrlen and instring[loc] in bodychars):
-                throwException = True
-
-        if throwException:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        return loc, instring[start:loc]
-
-    def __str__(self):
-        try:
-            return super(Word, self).__str__()
-        except Exception:
-            pass
-
-        if self.strRepr is None:
-
-            def charsAsStr(s):
-                if len(s) > 4:
-                    return s[:4] + "..."
-                else:
-                    return s
-
-            if self.initCharsOrig != self.bodyCharsOrig:
-                self.strRepr = "W:(%s, %s)" % (charsAsStr(self.initCharsOrig), charsAsStr(self.bodyCharsOrig))
-            else:
-                self.strRepr = "W:(%s)" % charsAsStr(self.initCharsOrig)
-
-        return self.strRepr
-
-class _WordRegex(Word):
-    def parseImpl(self, instring, loc, doActions=True):
-        result = self.re_match(instring, loc)
-        if not result:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        loc = result.end()
-        return loc, result.group()
-
-
-class Char(_WordRegex):
-    """A short-cut class for defining ``Word(characters, exact=1)``,
-    when defining a match of any single character in a string of
-    characters.
-    """
-    def __init__(self, charset, asKeyword=False, excludeChars=None):
-        super(Char, self).__init__(charset, exact=1, asKeyword=asKeyword, excludeChars=excludeChars)
-        self.reString = "[%s]" % _escapeRegexRangeChars(''.join(self.initChars))
-        if asKeyword:
-            self.reString = r"\b%s\b" % self.reString
-        self.re = re.compile(self.reString)
-        self.re_match = self.re.match
-
-
-class Regex(Token):
-    r"""Token for matching strings that match a given regular
-    expression. Defined with string specifying the regular expression in
-    a form recognized by the stdlib Python  `re module <https://docs.python.org/3/library/re.html>`_.
-    If the given regex contains named groups (defined using ``(?P<name>...)``),
-    these will be preserved as named parse results.
-
-    If instead of the Python stdlib re module you wish to use a different RE module
-    (such as the `regex` module), you can replace it by either building your
-    Regex object with a compiled RE that was compiled using regex:
-
-    Example::
-
-        realnum = Regex(r"[+-]?\d+\.\d*")
-        date = Regex(r'(?P<year>\d{4})-(?P<month>\d\d?)-(?P<day>\d\d?)')
-        # ref: https://stackoverflow.com/questions/267399/how-do-you-match-only-valid-roman-numerals-with-a-regular-expression
-        roman = Regex(r"M{0,4}(CM|CD|D?{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})")
-
-        # use regex module instead of stdlib re module to construct a Regex using
-        # a compiled regular expression
-        import regex
-        parser = pp.Regex(regex.compile(r'[0-9]'))
-
-    """
-    def __init__(self, pattern, flags=0, asGroupList=False, asMatch=False):
-        """The parameters ``pattern`` and ``flags`` are passed
-        to the ``re.compile()`` function as-is. See the Python
-        `re module <https://docs.python.org/3/library/re.html>`_ module for an
-        explanation of the acceptable patterns and flags.
-        """
-        super(Regex, self).__init__()
-
-        if isinstance(pattern, basestring):
-            if not pattern:
-                warnings.warn("null string passed to Regex; use Empty() instead",
-                              SyntaxWarning, stacklevel=2)
-
-            self.pattern = pattern
-            self.flags = flags
-
-            try:
-                self.re = re.compile(self.pattern, self.flags)
-                self.reString = self.pattern
-            except sre_constants.error:
-                warnings.warn("invalid pattern (%s) passed to Regex" % pattern,
-                              SyntaxWarning, stacklevel=2)
-                raise
-
-        elif hasattr(pattern, 'pattern') and hasattr(pattern, 'match'):
-            self.re = pattern
-            self.pattern = self.reString = pattern.pattern
-            self.flags = flags
-
-        else:
-            raise TypeError("Regex may only be constructed with a string or a compiled RE object")
-
-        self.re_match = self.re.match
-
-        self.name = _ustr(self)
-        self.errmsg = "Expected " + self.name
-        self.mayIndexError = False
-        self.mayReturnEmpty = self.re_match("") is not None
-        self.asGroupList = asGroupList
-        self.asMatch = asMatch
-        if self.asGroupList:
-            self.parseImpl = self.parseImplAsGroupList
-        if self.asMatch:
-            self.parseImpl = self.parseImplAsMatch
-
-    def parseImpl(self, instring, loc, doActions=True):
-        result = self.re_match(instring, loc)
-        if not result:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        loc = result.end()
-        ret = ParseResults(result.group())
-        d = result.groupdict()
-        if d:
-            for k, v in d.items():
-                ret[k] = v
-        return loc, ret
-
-    def parseImplAsGroupList(self, instring, loc, doActions=True):
-        result = self.re_match(instring, loc)
-        if not result:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        loc = result.end()
-        ret = result.groups()
-        return loc, ret
-
-    def parseImplAsMatch(self, instring, loc, doActions=True):
-        result = self.re_match(instring, loc)
-        if not result:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        loc = result.end()
-        ret = result
-        return loc, ret
-
-    def __str__(self):
-        try:
-            return super(Regex, self).__str__()
-        except Exception:
-            pass
-
-        if self.strRepr is None:
-            self.strRepr = "Re:(%s)" % repr(self.pattern)
-
-        return self.strRepr
-
-    def sub(self, repl):
-        r"""
-        Return Regex with an attached parse action to transform the parsed
-        result as if called using `re.sub(expr, repl, string) <https://docs.python.org/3/library/re.html#re.sub>`_.
-
-        Example::
-
-            make_html = Regex(r"(\w+):(.*?):").sub(r"<\1>\2</\1>")
-            print(make_html.transformString("h1:main title:"))
-            # prints "<h1>main title</h1>"
-        """
-        if self.asGroupList:
-            warnings.warn("cannot use sub() with Regex(asGroupList=True)",
-                          SyntaxWarning, stacklevel=2)
-            raise SyntaxError()
-
-        if self.asMatch and callable(repl):
-            warnings.warn("cannot use sub() with a callable with Regex(asMatch=True)",
-                          SyntaxWarning, stacklevel=2)
-            raise SyntaxError()
-
-        if self.asMatch:
-            def pa(tokens):
-                return tokens[0].expand(repl)
-        else:
-            def pa(tokens):
-                return self.re.sub(repl, tokens[0])
-        return self.addParseAction(pa)
-
-class QuotedString(Token):
-    r"""
-    Token for matching strings that are delimited by quoting characters.
-
-    Defined with the following parameters:
-
-        - quoteChar - string of one or more characters defining the
-          quote delimiting string
-        - escChar - character to escape quotes, typically backslash
-          (default= ``None``)
-        - escQuote - special quote sequence to escape an embedded quote
-          string (such as SQL's ``""`` to escape an embedded ``"``)
-          (default= ``None``)
-        - multiline - boolean indicating whether quotes can span
-          multiple lines (default= ``False``)
-        - unquoteResults - boolean indicating whether the matched text
-          should be unquoted (default= ``True``)
-        - endQuoteChar - string of one or more characters defining the
-          end of the quote delimited string (default= ``None``  => same as
-          quoteChar)
-        - convertWhitespaceEscapes - convert escaped whitespace
-          (``'\t'``, ``'\n'``, etc.) to actual whitespace
-          (default= ``True``)
-
-    Example::
-
-        qs = QuotedString('"')
-        print(qs.searchString('lsjdf "This is the quote" sldjf'))
-        complex_qs = QuotedString('{{', endQuoteChar='}}')
-        print(complex_qs.searchString('lsjdf {{This is the "quote"}} sldjf'))
-        sql_qs = QuotedString('"', escQuote='""')
-        print(sql_qs.searchString('lsjdf "This is the quote with ""embedded"" quotes" sldjf'))
-
-    prints::
-
-        [['This is the quote']]
-        [['This is the "quote"']]
-        [['This is the quote with "embedded" quotes']]
-    """
-    def __init__(self, quoteChar, escChar=None, escQuote=None, multiline=False,
-                 unquoteResults=True, endQuoteChar=None, convertWhitespaceEscapes=True):
-        super(QuotedString, self).__init__()
-
-        # remove white space from quote chars - wont work anyway
-        quoteChar = quoteChar.strip()
-        if not quoteChar:
-            warnings.warn("quoteChar cannot be the empty string", SyntaxWarning, stacklevel=2)
-            raise SyntaxError()
-
-        if endQuoteChar is None:
-            endQuoteChar = quoteChar
-        else:
-            endQuoteChar = endQuoteChar.strip()
-            if not endQuoteChar:
-                warnings.warn("endQuoteChar cannot be the empty string", SyntaxWarning, stacklevel=2)
-                raise SyntaxError()
-
-        self.quoteChar = quoteChar
-        self.quoteCharLen = len(quoteChar)
-        self.firstQuoteChar = quoteChar[0]
-        self.endQuoteChar = endQuoteChar
-        self.endQuoteCharLen = len(endQuoteChar)
-        self.escChar = escChar
-        self.escQuote = escQuote
-        self.unquoteResults = unquoteResults
-        self.convertWhitespaceEscapes = convertWhitespaceEscapes
-
-        if multiline:
-            self.flags = re.MULTILINE | re.DOTALL
-            self.pattern = r'%s(?:[^%s%s]' % (re.escape(self.quoteChar),
-                                              _escapeRegexRangeChars(self.endQuoteChar[0]),
-                                              (escChar is not None and _escapeRegexRangeChars(escChar) or ''))
-        else:
-            self.flags = 0
-            self.pattern = r'%s(?:[^%s\n\r%s]' % (re.escape(self.quoteChar),
-                                                  _escapeRegexRangeChars(self.endQuoteChar[0]),
-                                                  (escChar is not None and _escapeRegexRangeChars(escChar) or ''))
-        if len(self.endQuoteChar) > 1:
-            self.pattern += (
-                '|(?:' + ')|(?:'.join("%s[^%s]" % (re.escape(self.endQuoteChar[:i]),
-                                                   _escapeRegexRangeChars(self.endQuoteChar[i]))
-                                      for i in range(len(self.endQuoteChar) - 1, 0, -1)) + ')')
-
-        if escQuote:
-            self.pattern += (r'|(?:%s)' % re.escape(escQuote))
-        if escChar:
-            self.pattern += (r'|(?:%s.)' % re.escape(escChar))
-            self.escCharReplacePattern = re.escape(self.escChar) + "(.)"
-        self.pattern += (r')*%s' % re.escape(self.endQuoteChar))
-
-        try:
-            self.re = re.compile(self.pattern, self.flags)
-            self.reString = self.pattern
-            self.re_match = self.re.match
-        except sre_constants.error:
-            warnings.warn("invalid pattern (%s) passed to Regex" % self.pattern,
-                          SyntaxWarning, stacklevel=2)
-            raise
-
-        self.name = _ustr(self)
-        self.errmsg = "Expected " + self.name
-        self.mayIndexError = False
-        self.mayReturnEmpty = True
-
-    def parseImpl(self, instring, loc, doActions=True):
-        result = instring[loc] == self.firstQuoteChar and self.re_match(instring, loc) or None
-        if not result:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        loc = result.end()
-        ret = result.group()
-
-        if self.unquoteResults:
-
-            # strip off quotes
-            ret = ret[self.quoteCharLen: -self.endQuoteCharLen]
-
-            if isinstance(ret, basestring):
-                # replace escaped whitespace
-                if '\\' in ret and self.convertWhitespaceEscapes:
-                    ws_map = {
-                        r'\t': '\t',
-                        r'\n': '\n',
-                        r'\f': '\f',
-                        r'\r': '\r',
-                    }
-                    for wslit, wschar in ws_map.items():
-                        ret = ret.replace(wslit, wschar)
-
-                # replace escaped characters
-                if self.escChar:
-                    ret = re.sub(self.escCharReplacePattern, r"\g<1>", ret)
-
-                # replace escaped quotes
-                if self.escQuote:
-                    ret = ret.replace(self.escQuote, self.endQuoteChar)
-
-        return loc, ret
-
-    def __str__(self):
-        try:
-            return super(QuotedString, self).__str__()
-        except Exception:
-            pass
-
-        if self.strRepr is None:
-            self.strRepr = "quoted string, starting with %s ending with %s" % (self.quoteChar, self.endQuoteChar)
-
-        return self.strRepr
-
-
-class CharsNotIn(Token):
-    """Token for matching words composed of characters *not* in a given
-    set (will include whitespace in matched characters if not listed in
-    the provided exclusion set - see example). Defined with string
-    containing all disallowed characters, and an optional minimum,
-    maximum, and/or exact length.  The default value for ``min`` is
-    1 (a minimum value < 1 is not valid); the default values for
-    ``max`` and ``exact`` are 0, meaning no maximum or exact
-    length restriction.
-
-    Example::
-
-        # define a comma-separated-value as anything that is not a ','
-        csv_value = CharsNotIn(',')
-        print(delimitedList(csv_value).parseString("dkls,lsdkjf,s12 34,@!#,213"))
-
-    prints::
-
-        ['dkls', 'lsdkjf', 's12 34', '@!#', '213']
-    """
-    def __init__(self, notChars, min=1, max=0, exact=0):
-        super(CharsNotIn, self).__init__()
-        self.skipWhitespace = False
-        self.notChars = notChars
-
-        if min < 1:
-            raise ValueError("cannot specify a minimum length < 1; use "
-                             "Optional(CharsNotIn()) if zero-length char group is permitted")
-
-        self.minLen = min
-
-        if max > 0:
-            self.maxLen = max
-        else:
-            self.maxLen = _MAX_INT
-
-        if exact > 0:
-            self.maxLen = exact
-            self.minLen = exact
-
-        self.name = _ustr(self)
-        self.errmsg = "Expected " + self.name
-        self.mayReturnEmpty = (self.minLen == 0)
-        self.mayIndexError = False
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if instring[loc] in self.notChars:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        start = loc
-        loc += 1
-        notchars = self.notChars
-        maxlen = min(start + self.maxLen, len(instring))
-        while loc < maxlen and instring[loc] not in notchars:
-            loc += 1
-
-        if loc - start < self.minLen:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        return loc, instring[start:loc]
-
-    def __str__(self):
-        try:
-            return super(CharsNotIn, self).__str__()
-        except Exception:
-            pass
-
-        if self.strRepr is None:
-            if len(self.notChars) > 4:
-                self.strRepr = "!W:(%s...)" % self.notChars[:4]
-            else:
-                self.strRepr = "!W:(%s)" % self.notChars
-
-        return self.strRepr
-
-class White(Token):
-    """Special matching class for matching whitespace.  Normally,
-    whitespace is ignored by pyparsing grammars.  This class is included
-    when some whitespace structures are significant.  Define with
-    a string containing the whitespace characters to be matched; default
-    is ``" \\t\\r\\n"``.  Also takes optional ``min``,
-    ``max``, and ``exact`` arguments, as defined for the
-    :class:`Word` class.
-    """
-    whiteStrs = {
-        ' ' : '<SP>',
-        '\t': '<TAB>',
-        '\n': '<LF>',
-        '\r': '<CR>',
-        '\f': '<FF>',
-        u'\u00A0': '<NBSP>',
-        u'\u1680': '<OGHAM_SPACE_MARK>',
-        u'\u180E': '<MONGOLIAN_VOWEL_SEPARATOR>',
-        u'\u2000': '<EN_QUAD>',
-        u'\u2001': '<EM_QUAD>',
-        u'\u2002': '<EN_SPACE>',
-        u'\u2003': '<EM_SPACE>',
-        u'\u2004': '<THREE-PER-EM_SPACE>',
-        u'\u2005': '<FOUR-PER-EM_SPACE>',
-        u'\u2006': '<SIX-PER-EM_SPACE>',
-        u'\u2007': '<FIGURE_SPACE>',
-        u'\u2008': '<PUNCTUATION_SPACE>',
-        u'\u2009': '<THIN_SPACE>',
-        u'\u200A': '<HAIR_SPACE>',
-        u'\u200B': '<ZERO_WIDTH_SPACE>',
-        u'\u202F': '<NNBSP>',
-        u'\u205F': '<MMSP>',
-        u'\u3000': '<IDEOGRAPHIC_SPACE>',
-        }
-    def __init__(self, ws=" \t\r\n", min=1, max=0, exact=0):
-        super(White, self).__init__()
-        self.matchWhite = ws
-        self.setWhitespaceChars("".join(c for c in self.whiteChars if c not in self.matchWhite))
-        # ~ self.leaveWhitespace()
-        self.name = ("".join(White.whiteStrs[c] for c in self.matchWhite))
-        self.mayReturnEmpty = True
-        self.errmsg = "Expected " + self.name
-
-        self.minLen = min
-
-        if max > 0:
-            self.maxLen = max
-        else:
-            self.maxLen = _MAX_INT
-
-        if exact > 0:
-            self.maxLen = exact
-            self.minLen = exact
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if instring[loc] not in self.matchWhite:
-            raise ParseException(instring, loc, self.errmsg, self)
-        start = loc
-        loc += 1
-        maxloc = start + self.maxLen
-        maxloc = min(maxloc, len(instring))
-        while loc < maxloc and instring[loc] in self.matchWhite:
-            loc += 1
-
-        if loc - start < self.minLen:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        return loc, instring[start:loc]
-
-
-class _PositionToken(Token):
-    def __init__(self):
-        super(_PositionToken, self).__init__()
-        self.name = self.__class__.__name__
-        self.mayReturnEmpty = True
-        self.mayIndexError = False
-
-class GoToColumn(_PositionToken):
-    """Token to advance to a specific column of input text; useful for
-    tabular report scraping.
-    """
-    def __init__(self, colno):
-        super(GoToColumn, self).__init__()
-        self.col = colno
-
-    def preParse(self, instring, loc):
-        if col(loc, instring) != self.col:
-            instrlen = len(instring)
-            if self.ignoreExprs:
-                loc = self._skipIgnorables(instring, loc)
-            while loc < instrlen and instring[loc].isspace() and col(loc, instring) != self.col:
-                loc += 1
-        return loc
-
-    def parseImpl(self, instring, loc, doActions=True):
-        thiscol = col(loc, instring)
-        if thiscol > self.col:
-            raise ParseException(instring, loc, "Text not in expected column", self)
-        newloc = loc + self.col - thiscol
-        ret = instring[loc: newloc]
-        return newloc, ret
-
-
-class LineStart(_PositionToken):
-    r"""Matches if current position is at the beginning of a line within
-    the parse string
-
-    Example::
-
-        test = '''\
-        AAA this line
-        AAA and this line
-          AAA but not this one
-        B AAA and definitely not this one
-        '''
-
-        for t in (LineStart() + 'AAA' + restOfLine).searchString(test):
-            print(t)
-
-    prints::
-
-        ['AAA', ' this line']
-        ['AAA', ' and this line']
-
-    """
-    def __init__(self):
-        super(LineStart, self).__init__()
-        self.errmsg = "Expected start of line"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if col(loc, instring) == 1:
-            return loc, []
-        raise ParseException(instring, loc, self.errmsg, self)
-
-class LineEnd(_PositionToken):
-    """Matches if current position is at the end of a line within the
-    parse string
-    """
-    def __init__(self):
-        super(LineEnd, self).__init__()
-        self.setWhitespaceChars(ParserElement.DEFAULT_WHITE_CHARS.replace("\n", ""))
-        self.errmsg = "Expected end of line"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if loc < len(instring):
-            if instring[loc] == "\n":
-                return loc + 1, "\n"
-            else:
-                raise ParseException(instring, loc, self.errmsg, self)
-        elif loc == len(instring):
-            return loc + 1, []
-        else:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-class StringStart(_PositionToken):
-    """Matches if current position is at the beginning of the parse
-    string
-    """
-    def __init__(self):
-        super(StringStart, self).__init__()
-        self.errmsg = "Expected start of text"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if loc != 0:
-            # see if entire string up to here is just whitespace and ignoreables
-            if loc != self.preParse(instring, 0):
-                raise ParseException(instring, loc, self.errmsg, self)
-        return loc, []
-
-class StringEnd(_PositionToken):
-    """Matches if current position is at the end of the parse string
-    """
-    def __init__(self):
-        super(StringEnd, self).__init__()
-        self.errmsg = "Expected end of text"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if loc < len(instring):
-            raise ParseException(instring, loc, self.errmsg, self)
-        elif loc == len(instring):
-            return loc + 1, []
-        elif loc > len(instring):
-            return loc, []
-        else:
-            raise ParseException(instring, loc, self.errmsg, self)
-
-class WordStart(_PositionToken):
-    """Matches if the current position is at the beginning of a Word,
-    and is not preceded by any character in a given set of
-    ``wordChars`` (default= ``printables``). To emulate the
-    ``\b`` behavior of regular expressions, use
-    ``WordStart(alphanums)``. ``WordStart`` will also match at
-    the beginning of the string being parsed, or at the beginning of
-    a line.
-    """
-    def __init__(self, wordChars=printables):
-        super(WordStart, self).__init__()
-        self.wordChars = set(wordChars)
-        self.errmsg = "Not at the start of a word"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if loc != 0:
-            if (instring[loc - 1] in self.wordChars
-                    or instring[loc] not in self.wordChars):
-                raise ParseException(instring, loc, self.errmsg, self)
-        return loc, []
-
-class WordEnd(_PositionToken):
-    """Matches if the current position is at the end of a Word, and is
-    not followed by any character in a given set of ``wordChars``
-    (default= ``printables``). To emulate the ``\b`` behavior of
-    regular expressions, use ``WordEnd(alphanums)``. ``WordEnd``
-    will also match at the end of the string being parsed, or at the end
-    of a line.
-    """
-    def __init__(self, wordChars=printables):
-        super(WordEnd, self).__init__()
-        self.wordChars = set(wordChars)
-        self.skipWhitespace = False
-        self.errmsg = "Not at the end of a word"
-
-    def parseImpl(self, instring, loc, doActions=True):
-        instrlen = len(instring)
-        if instrlen > 0 and loc < instrlen:
-            if (instring[loc] in self.wordChars or
-                    instring[loc - 1] not in self.wordChars):
-                raise ParseException(instring, loc, self.errmsg, self)
-        return loc, []
-
-
-class ParseExpression(ParserElement):
-    """Abstract subclass of ParserElement, for combining and
-    post-processing parsed tokens.
-    """
-    def __init__(self, exprs, savelist=False):
-        super(ParseExpression, self).__init__(savelist)
-        if isinstance(exprs, _generatorType):
-            exprs = list(exprs)
-
-        if isinstance(exprs, basestring):
-            self.exprs = [self._literalStringClass(exprs)]
-        elif isinstance(exprs, ParserElement):
-            self.exprs = [exprs]
-        elif isinstance(exprs, Iterable):
-            exprs = list(exprs)
-            # if sequence of strings provided, wrap with Literal
-            if any(isinstance(expr, basestring) for expr in exprs):
-                exprs = (self._literalStringClass(e) if isinstance(e, basestring) else e for e in exprs)
-            self.exprs = list(exprs)
-        else:
-            try:
-                self.exprs = list(exprs)
-            except TypeError:
-                self.exprs = [exprs]
-        self.callPreparse = False
-
-    def append(self, other):
-        self.exprs.append(other)
-        self.strRepr = None
-        return self
-
-    def leaveWhitespace(self):
-        """Extends ``leaveWhitespace`` defined in base class, and also invokes ``leaveWhitespace`` on
-           all contained expressions."""
-        self.skipWhitespace = False
-        self.exprs = [e.copy() for e in self.exprs]
-        for e in self.exprs:
-            e.leaveWhitespace()
-        return self
-
-    def ignore(self, other):
-        if isinstance(other, Suppress):
-            if other not in self.ignoreExprs:
-                super(ParseExpression, self).ignore(other)
-                for e in self.exprs:
-                    e.ignore(self.ignoreExprs[-1])
-        else:
-            super(ParseExpression, self).ignore(other)
-            for e in self.exprs:
-                e.ignore(self.ignoreExprs[-1])
-        return self
-
-    def __str__(self):
-        try:
-            return super(ParseExpression, self).__str__()
-        except Exception:
-            pass
-
-        if self.strRepr is None:
-            self.strRepr = "%s:(%s)" % (self.__class__.__name__, _ustr(self.exprs))
-        return self.strRepr
-
-    def streamline(self):
-        super(ParseExpression, self).streamline()
-
-        for e in self.exprs:
-            e.streamline()
-
-        # collapse nested And's of the form And(And(And(a, b), c), d) to And(a, b, c, d)
-        # but only if there are no parse actions or resultsNames on the nested And's
-        # (likewise for Or's and MatchFirst's)
-        if len(self.exprs) == 2:
-            other = self.exprs[0]
-            if (isinstance(other, self.__class__)
-                    and not other.parseAction
-                    and other.resultsName is None
-                    and not other.debug):
-                self.exprs = other.exprs[:] + [self.exprs[1]]
-                self.strRepr = None
-                self.mayReturnEmpty |= other.mayReturnEmpty
-                self.mayIndexError  |= other.mayIndexError
-
-            other = self.exprs[-1]
-            if (isinstance(other, self.__class__)
-                    and not other.parseAction
-                    and other.resultsName is None
-                    and not other.debug):
-                self.exprs = self.exprs[:-1] + other.exprs[:]
-                self.strRepr = None
-                self.mayReturnEmpty |= other.mayReturnEmpty
-                self.mayIndexError  |= other.mayIndexError
-
-        self.errmsg = "Expected " + _ustr(self)
-
-        return self
-
-    def validate(self, validateTrace=None):
-        tmp = (validateTrace if validateTrace is not None else [])[:] + [self]
-        for e in self.exprs:
-            e.validate(tmp)
-        self.checkRecursion([])
-
-    def copy(self):
-        ret = super(ParseExpression, self).copy()
-        ret.exprs = [e.copy() for e in self.exprs]
-        return ret
-
-    def _setResultsName(self, name, listAllMatches=False):
-        if __diag__.warn_ungrouped_named_tokens_in_collection:
-            for e in self.exprs:
-                if isinstance(e, ParserElement) and e.resultsName:
-                    warnings.warn("{0}: setting results name {1!r} on {2} expression "
-                                  "collides with {3!r} on contained expression".format("warn_ungrouped_named_tokens_in_collection",
-                                                                                       name,
-                                                                                       type(self).__name__,
-                                                                                       e.resultsName),
-                                  stacklevel=3)
-
-        return super(ParseExpression, self)._setResultsName(name, listAllMatches)
-
-
-class And(ParseExpression):
-    """
-    Requires all given :class:`ParseExpression` s to be found in the given order.
-    Expressions may be separated by whitespace.
-    May be constructed using the ``'+'`` operator.
-    May also be constructed using the ``'-'`` operator, which will
-    suppress backtracking.
-
-    Example::
-
-        integer = Word(nums)
-        name_expr = OneOrMore(Word(alphas))
-
-        expr = And([integer("id"), name_expr("name"), integer("age")])
-        # more easily written as:
-        expr = integer("id") + name_expr("name") + integer("age")
-    """
-
-    class _ErrorStop(Empty):
-        def __init__(self, *args, **kwargs):
-            super(And._ErrorStop, self).__init__(*args, **kwargs)
-            self.name = '-'
-            self.leaveWhitespace()
-
-    def __init__(self, exprs, savelist=True):
-        exprs = list(exprs)
-        if exprs and Ellipsis in exprs:
-            tmp = []
-            for i, expr in enumerate(exprs):
-                if expr is Ellipsis:
-                    if i < len(exprs) - 1:
-                        skipto_arg = (Empty() + exprs[i + 1]).exprs[-1]
-                        tmp.append(SkipTo(skipto_arg)("_skipped*"))
-                    else:
-                        raise Exception("cannot construct And with sequence ending in ...")
-                else:
-                    tmp.append(expr)
-            exprs[:] = tmp
-        super(And, self).__init__(exprs, savelist)
-        self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs)
-        self.setWhitespaceChars(self.exprs[0].whiteChars)
-        self.skipWhitespace = self.exprs[0].skipWhitespace
-        self.callPreparse = True
-
-    def streamline(self):
-        # collapse any _PendingSkip's
-        if self.exprs:
-            if any(isinstance(e, ParseExpression) and e.exprs and isinstance(e.exprs[-1], _PendingSkip)
-                   for e in self.exprs[:-1]):
-                for i, e in enumerate(self.exprs[:-1]):
-                    if e is None:
-                        continue
-                    if (isinstance(e, ParseExpression)
-                            and e.exprs and isinstance(e.exprs[-1], _PendingSkip)):
-                        e.exprs[-1] = e.exprs[-1] + self.exprs[i + 1]
-                        self.exprs[i + 1] = None
-                self.exprs = [e for e in self.exprs if e is not None]
-
-        super(And, self).streamline()
-        self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs)
-        return self
-
-    def parseImpl(self, instring, loc, doActions=True):
-        # pass False as last arg to _parse for first element, since we already
-        # pre-parsed the string as part of our And pre-parsing
-        loc, resultlist = self.exprs[0]._parse(instring, loc, doActions, callPreParse=False)
-        errorStop = False
-        for e in self.exprs[1:]:
-            if isinstance(e, And._ErrorStop):
-                errorStop = True
-                continue
-            if errorStop:
-                try:
-                    loc, exprtokens = e._parse(instring, loc, doActions)
-                except ParseSyntaxException:
-                    raise
-                except ParseBaseException as pe:
-                    pe.__traceback__ = None
-                    raise ParseSyntaxException._from_exception(pe)
-                except IndexError:
-                    raise ParseSyntaxException(instring, len(instring), self.errmsg, self)
-            else:
-                loc, exprtokens = e._parse(instring, loc, doActions)
-            if exprtokens or exprtokens.haskeys():
-                resultlist += exprtokens
-        return loc, resultlist
-
-    def __iadd__(self, other):
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        return self.append(other)  # And([self, other])
-
-    def checkRecursion(self, parseElementList):
-        subRecCheckList = parseElementList[:] + [self]
-        for e in self.exprs:
-            e.checkRecursion(subRecCheckList)
-            if not e.mayReturnEmpty:
-                break
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "{" + " ".join(_ustr(e) for e in self.exprs) + "}"
-
-        return self.strRepr
-
-
-class Or(ParseExpression):
-    """Requires that at least one :class:`ParseExpression` is found. If
-    two expressions match, the expression that matches the longest
-    string will be used. May be constructed using the ``'^'``
-    operator.
-
-    Example::
-
-        # construct Or using '^' operator
-
-        number = Word(nums) ^ Combine(Word(nums) + '.' + Word(nums))
-        print(number.searchString("123 3.1416 789"))
-
-    prints::
-
-        [['123'], ['3.1416'], ['789']]
-    """
-    def __init__(self, exprs, savelist=False):
-        super(Or, self).__init__(exprs, savelist)
-        if self.exprs:
-            self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs)
-        else:
-            self.mayReturnEmpty = True
-
-    def streamline(self):
-        super(Or, self).streamline()
-        if __compat__.collect_all_And_tokens:
-            self.saveAsList = any(e.saveAsList for e in self.exprs)
-        return self
-
-    def parseImpl(self, instring, loc, doActions=True):
-        maxExcLoc = -1
-        maxException = None
-        matches = []
-        for e in self.exprs:
-            try:
-                loc2 = e.tryParse(instring, loc)
-            except ParseException as err:
-                err.__traceback__ = None
-                if err.loc > maxExcLoc:
-                    maxException = err
-                    maxExcLoc = err.loc
-            except IndexError:
-                if len(instring) > maxExcLoc:
-                    maxException = ParseException(instring, len(instring), e.errmsg, self)
-                    maxExcLoc = len(instring)
-            else:
-                # save match among all matches, to retry longest to shortest
-                matches.append((loc2, e))
-
-        if matches:
-            # re-evaluate all matches in descending order of length of match, in case attached actions
-            # might change whether or how much they match of the input.
-            matches.sort(key=itemgetter(0), reverse=True)
-
-            if not doActions:
-                # no further conditions or parse actions to change the selection of
-                # alternative, so the first match will be the best match
-                best_expr = matches[0][1]
-                return best_expr._parse(instring, loc, doActions)
-
-            longest = -1, None
-            for loc1, expr1 in matches:
-                if loc1 <= longest[0]:
-                    # already have a longer match than this one will deliver, we are done
-                    return longest
-
-                try:
-                    loc2, toks = expr1._parse(instring, loc, doActions)
-                except ParseException as err:
-                    err.__traceback__ = None
-                    if err.loc > maxExcLoc:
-                        maxException = err
-                        maxExcLoc = err.loc
-                else:
-                    if loc2 >= loc1:
-                        return loc2, toks
-                    # didn't match as much as before
-                    elif loc2 > longest[0]:
-                        longest = loc2, toks
-
-            if longest != (-1, None):
-                return longest
-
-        if maxException is not None:
-            maxException.msg = self.errmsg
-            raise maxException
-        else:
-            raise ParseException(instring, loc, "no defined alternatives to match", self)
-
-
-    def __ixor__(self, other):
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        return self.append(other)  # Or([self, other])
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "{" + " ^ ".join(_ustr(e) for e in self.exprs) + "}"
-
-        return self.strRepr
-
-    def checkRecursion(self, parseElementList):
-        subRecCheckList = parseElementList[:] + [self]
-        for e in self.exprs:
-            e.checkRecursion(subRecCheckList)
-
-    def _setResultsName(self, name, listAllMatches=False):
-        if (not __compat__.collect_all_And_tokens
-                and __diag__.warn_multiple_tokens_in_named_alternation):
-            if any(isinstance(e, And) for e in self.exprs):
-                warnings.warn("{0}: setting results name {1!r} on {2} expression "
-                              "may only return a single token for an And alternative, "
-                              "in future will return the full list of tokens".format(
-                    "warn_multiple_tokens_in_named_alternation", name, type(self).__name__),
-                    stacklevel=3)
-
-        return super(Or, self)._setResultsName(name, listAllMatches)
-
-
-class MatchFirst(ParseExpression):
-    """Requires that at least one :class:`ParseExpression` is found. If
-    two expressions match, the first one listed is the one that will
-    match. May be constructed using the ``'|'`` operator.
-
-    Example::
-
-        # construct MatchFirst using '|' operator
-
-        # watch the order of expressions to match
-        number = Word(nums) | Combine(Word(nums) + '.' + Word(nums))
-        print(number.searchString("123 3.1416 789")) #  Fail! -> [['123'], ['3'], ['1416'], ['789']]
-
-        # put more selective expression first
-        number = Combine(Word(nums) + '.' + Word(nums)) | Word(nums)
-        print(number.searchString("123 3.1416 789")) #  Better -> [['123'], ['3.1416'], ['789']]
-    """
-    def __init__(self, exprs, savelist=False):
-        super(MatchFirst, self).__init__(exprs, savelist)
-        if self.exprs:
-            self.mayReturnEmpty = any(e.mayReturnEmpty for e in self.exprs)
-        else:
-            self.mayReturnEmpty = True
-
-    def streamline(self):
-        super(MatchFirst, self).streamline()
-        if __compat__.collect_all_And_tokens:
-            self.saveAsList = any(e.saveAsList for e in self.exprs)
-        return self
-
-    def parseImpl(self, instring, loc, doActions=True):
-        maxExcLoc = -1
-        maxException = None
-        for e in self.exprs:
-            try:
-                ret = e._parse(instring, loc, doActions)
-                return ret
-            except ParseException as err:
-                if err.loc > maxExcLoc:
-                    maxException = err
-                    maxExcLoc = err.loc
-            except IndexError:
-                if len(instring) > maxExcLoc:
-                    maxException = ParseException(instring, len(instring), e.errmsg, self)
-                    maxExcLoc = len(instring)
-
-        # only got here if no expression matched, raise exception for match that made it the furthest
-        else:
-            if maxException is not None:
-                maxException.msg = self.errmsg
-                raise maxException
-            else:
-                raise ParseException(instring, loc, "no defined alternatives to match", self)
-
-    def __ior__(self, other):
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        return self.append(other)  # MatchFirst([self, other])
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "{" + " | ".join(_ustr(e) for e in self.exprs) + "}"
-
-        return self.strRepr
-
-    def checkRecursion(self, parseElementList):
-        subRecCheckList = parseElementList[:] + [self]
-        for e in self.exprs:
-            e.checkRecursion(subRecCheckList)
-
-    def _setResultsName(self, name, listAllMatches=False):
-        if (not __compat__.collect_all_And_tokens
-                and __diag__.warn_multiple_tokens_in_named_alternation):
-            if any(isinstance(e, And) for e in self.exprs):
-                warnings.warn("{0}: setting results name {1!r} on {2} expression "
-                              "may only return a single token for an And alternative, "
-                              "in future will return the full list of tokens".format(
-                    "warn_multiple_tokens_in_named_alternation", name, type(self).__name__),
-                    stacklevel=3)
-
-        return super(MatchFirst, self)._setResultsName(name, listAllMatches)
-
-
-class Each(ParseExpression):
-    """Requires all given :class:`ParseExpression` s to be found, but in
-    any order. Expressions may be separated by whitespace.
-
-    May be constructed using the ``'&'`` operator.
-
-    Example::
-
-        color = oneOf("RED ORANGE YELLOW GREEN BLUE PURPLE BLACK WHITE BROWN")
-        shape_type = oneOf("SQUARE CIRCLE TRIANGLE STAR HEXAGON OCTAGON")
-        integer = Word(nums)
-        shape_attr = "shape:" + shape_type("shape")
-        posn_attr = "posn:" + Group(integer("x") + ',' + integer("y"))("posn")
-        color_attr = "color:" + color("color")
-        size_attr = "size:" + integer("size")
-
-        # use Each (using operator '&') to accept attributes in any order
-        # (shape and posn are required, color and size are optional)
-        shape_spec = shape_attr & posn_attr & Optional(color_attr) & Optional(size_attr)
-
-        shape_spec.runTests('''
-            shape: SQUARE color: BLACK posn: 100, 120
-            shape: CIRCLE size: 50 color: BLUE posn: 50,80
-            color:GREEN size:20 shape:TRIANGLE posn:20,40
-            '''
-            )
-
-    prints::
-
-        shape: SQUARE color: BLACK posn: 100, 120
-        ['shape:', 'SQUARE', 'color:', 'BLACK', 'posn:', ['100', ',', '120']]
-        - color: BLACK
-        - posn: ['100', ',', '120']
-          - x: 100
-          - y: 120
-        - shape: SQUARE
-
-
-        shape: CIRCLE size: 50 color: BLUE posn: 50,80
-        ['shape:', 'CIRCLE', 'size:', '50', 'color:', 'BLUE', 'posn:', ['50', ',', '80']]
-        - color: BLUE
-        - posn: ['50', ',', '80']
-          - x: 50
-          - y: 80
-        - shape: CIRCLE
-        - size: 50
-
-
-        color: GREEN size: 20 shape: TRIANGLE posn: 20,40
-        ['color:', 'GREEN', 'size:', '20', 'shape:', 'TRIANGLE', 'posn:', ['20', ',', '40']]
-        - color: GREEN
-        - posn: ['20', ',', '40']
-          - x: 20
-          - y: 40
-        - shape: TRIANGLE
-        - size: 20
-    """
-    def __init__(self, exprs, savelist=True):
-        super(Each, self).__init__(exprs, savelist)
-        self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs)
-        self.skipWhitespace = True
-        self.initExprGroups = True
-        self.saveAsList = True
-
-    def streamline(self):
-        super(Each, self).streamline()
-        self.mayReturnEmpty = all(e.mayReturnEmpty for e in self.exprs)
-        return self
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if self.initExprGroups:
-            self.opt1map = dict((id(e.expr), e) for e in self.exprs if isinstance(e, Optional))
-            opt1 = [e.expr for e in self.exprs if isinstance(e, Optional)]
-            opt2 = [e for e in self.exprs if e.mayReturnEmpty and not isinstance(e, (Optional, Regex))]
-            self.optionals = opt1 + opt2
-            self.multioptionals = [e.expr for e in self.exprs if isinstance(e, ZeroOrMore)]
-            self.multirequired = [e.expr for e in self.exprs if isinstance(e, OneOrMore)]
-            self.required = [e for e in self.exprs if not isinstance(e, (Optional, ZeroOrMore, OneOrMore))]
-            self.required += self.multirequired
-            self.initExprGroups = False
-        tmpLoc = loc
-        tmpReqd = self.required[:]
-        tmpOpt  = self.optionals[:]
-        matchOrder = []
-
-        keepMatching = True
-        while keepMatching:
-            tmpExprs = tmpReqd + tmpOpt + self.multioptionals + self.multirequired
-            failed = []
-            for e in tmpExprs:
-                try:
-                    tmpLoc = e.tryParse(instring, tmpLoc)
-                except ParseException:
-                    failed.append(e)
-                else:
-                    matchOrder.append(self.opt1map.get(id(e), e))
-                    if e in tmpReqd:
-                        tmpReqd.remove(e)
-                    elif e in tmpOpt:
-                        tmpOpt.remove(e)
-            if len(failed) == len(tmpExprs):
-                keepMatching = False
-
-        if tmpReqd:
-            missing = ", ".join(_ustr(e) for e in tmpReqd)
-            raise ParseException(instring, loc, "Missing one or more required elements (%s)" % missing)
-
-        # add any unmatched Optionals, in case they have default values defined
-        matchOrder += [e for e in self.exprs if isinstance(e, Optional) and e.expr in tmpOpt]
-
-        resultlist = []
-        for e in matchOrder:
-            loc, results = e._parse(instring, loc, doActions)
-            resultlist.append(results)
-
-        finalResults = sum(resultlist, ParseResults([]))
-        return loc, finalResults
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "{" + " & ".join(_ustr(e) for e in self.exprs) + "}"
-
-        return self.strRepr
-
-    def checkRecursion(self, parseElementList):
-        subRecCheckList = parseElementList[:] + [self]
-        for e in self.exprs:
-            e.checkRecursion(subRecCheckList)
-
-
-class ParseElementEnhance(ParserElement):
-    """Abstract subclass of :class:`ParserElement`, for combining and
-    post-processing parsed tokens.
-    """
-    def __init__(self, expr, savelist=False):
-        super(ParseElementEnhance, self).__init__(savelist)
-        if isinstance(expr, basestring):
-            if issubclass(self._literalStringClass, Token):
-                expr = self._literalStringClass(expr)
-            else:
-                expr = self._literalStringClass(Literal(expr))
-        self.expr = expr
-        self.strRepr = None
-        if expr is not None:
-            self.mayIndexError = expr.mayIndexError
-            self.mayReturnEmpty = expr.mayReturnEmpty
-            self.setWhitespaceChars(expr.whiteChars)
-            self.skipWhitespace = expr.skipWhitespace
-            self.saveAsList = expr.saveAsList
-            self.callPreparse = expr.callPreparse
-            self.ignoreExprs.extend(expr.ignoreExprs)
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if self.expr is not None:
-            return self.expr._parse(instring, loc, doActions, callPreParse=False)
-        else:
-            raise ParseException("", loc, self.errmsg, self)
-
-    def leaveWhitespace(self):
-        self.skipWhitespace = False
-        self.expr = self.expr.copy()
-        if self.expr is not None:
-            self.expr.leaveWhitespace()
-        return self
-
-    def ignore(self, other):
-        if isinstance(other, Suppress):
-            if other not in self.ignoreExprs:
-                super(ParseElementEnhance, self).ignore(other)
-                if self.expr is not None:
-                    self.expr.ignore(self.ignoreExprs[-1])
-        else:
-            super(ParseElementEnhance, self).ignore(other)
-            if self.expr is not None:
-                self.expr.ignore(self.ignoreExprs[-1])
-        return self
-
-    def streamline(self):
-        super(ParseElementEnhance, self).streamline()
-        if self.expr is not None:
-            self.expr.streamline()
-        return self
-
-    def checkRecursion(self, parseElementList):
-        if self in parseElementList:
-            raise RecursiveGrammarException(parseElementList + [self])
-        subRecCheckList = parseElementList[:] + [self]
-        if self.expr is not None:
-            self.expr.checkRecursion(subRecCheckList)
-
-    def validate(self, validateTrace=None):
-        if validateTrace is None:
-            validateTrace = []
-        tmp = validateTrace[:] + [self]
-        if self.expr is not None:
-            self.expr.validate(tmp)
-        self.checkRecursion([])
-
-    def __str__(self):
-        try:
-            return super(ParseElementEnhance, self).__str__()
-        except Exception:
-            pass
-
-        if self.strRepr is None and self.expr is not None:
-            self.strRepr = "%s:(%s)" % (self.__class__.__name__, _ustr(self.expr))
-        return self.strRepr
-
-
-class FollowedBy(ParseElementEnhance):
-    """Lookahead matching of the given parse expression.
-    ``FollowedBy`` does *not* advance the parsing position within
-    the input string, it only verifies that the specified parse
-    expression matches at the current position.  ``FollowedBy``
-    always returns a null token list. If any results names are defined
-    in the lookahead expression, those *will* be returned for access by
-    name.
-
-    Example::
-
-        # use FollowedBy to match a label only if it is followed by a ':'
-        data_word = Word(alphas)
-        label = data_word + FollowedBy(':')
-        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
-
-        OneOrMore(attr_expr).parseString("shape: SQUARE color: BLACK posn: upper left").pprint()
-
-    prints::
-
-        [['shape', 'SQUARE'], ['color', 'BLACK'], ['posn', 'upper left']]
-    """
-    def __init__(self, expr):
-        super(FollowedBy, self).__init__(expr)
-        self.mayReturnEmpty = True
-
-    def parseImpl(self, instring, loc, doActions=True):
-        # by using self._expr.parse and deleting the contents of the returned ParseResults list
-        # we keep any named results that were defined in the FollowedBy expression
-        _, ret = self.expr._parse(instring, loc, doActions=doActions)
-        del ret[:]
-
-        return loc, ret
-
-
-class PrecededBy(ParseElementEnhance):
-    """Lookbehind matching of the given parse expression.
-    ``PrecededBy`` does not advance the parsing position within the
-    input string, it only verifies that the specified parse expression
-    matches prior to the current position.  ``PrecededBy`` always
-    returns a null token list, but if a results name is defined on the
-    given expression, it is returned.
-
-    Parameters:
-
-     - expr - expression that must match prior to the current parse
-       location
-     - retreat - (default= ``None``) - (int) maximum number of characters
-       to lookbehind prior to the current parse location
-
-    If the lookbehind expression is a string, Literal, Keyword, or
-    a Word or CharsNotIn with a specified exact or maximum length, then
-    the retreat parameter is not required. Otherwise, retreat must be
-    specified to give a maximum number of characters to look back from
-    the current parse position for a lookbehind match.
-
-    Example::
-
-        # VB-style variable names with type prefixes
-        int_var = PrecededBy("#") + pyparsing_common.identifier
-        str_var = PrecededBy("$") + pyparsing_common.identifier
-
-    """
-    def __init__(self, expr, retreat=None):
-        super(PrecededBy, self).__init__(expr)
-        self.expr = self.expr().leaveWhitespace()
-        self.mayReturnEmpty = True
-        self.mayIndexError = False
-        self.exact = False
-        if isinstance(expr, str):
-            retreat = len(expr)
-            self.exact = True
-        elif isinstance(expr, (Literal, Keyword)):
-            retreat = expr.matchLen
-            self.exact = True
-        elif isinstance(expr, (Word, CharsNotIn)) and expr.maxLen != _MAX_INT:
-            retreat = expr.maxLen
-            self.exact = True
-        elif isinstance(expr, _PositionToken):
-            retreat = 0
-            self.exact = True
-        self.retreat = retreat
-        self.errmsg = "not preceded by " + str(expr)
-        self.skipWhitespace = False
-        self.parseAction.append(lambda s, l, t: t.__delitem__(slice(None, None)))
-
-    def parseImpl(self, instring, loc=0, doActions=True):
-        if self.exact:
-            if loc < self.retreat:
-                raise ParseException(instring, loc, self.errmsg)
-            start = loc - self.retreat
-            _, ret = self.expr._parse(instring, start)
-        else:
-            # retreat specified a maximum lookbehind window, iterate
-            test_expr = self.expr + StringEnd()
-            instring_slice = instring[max(0, loc - self.retreat):loc]
-            last_expr = ParseException(instring, loc, self.errmsg)
-            for offset in range(1, min(loc, self.retreat + 1)+1):
-                try:
-                    # print('trying', offset, instring_slice, repr(instring_slice[loc - offset:]))
-                    _, ret = test_expr._parse(instring_slice, len(instring_slice) - offset)
-                except ParseBaseException as pbe:
-                    last_expr = pbe
-                else:
-                    break
-            else:
-                raise last_expr
-        return loc, ret
-
-
-class NotAny(ParseElementEnhance):
-    """Lookahead to disallow matching with the given parse expression.
-    ``NotAny`` does *not* advance the parsing position within the
-    input string, it only verifies that the specified parse expression
-    does *not* match at the current position.  Also, ``NotAny`` does
-    *not* skip over leading whitespace. ``NotAny`` always returns
-    a null token list.  May be constructed using the '~' operator.
-
-    Example::
-
-        AND, OR, NOT = map(CaselessKeyword, "AND OR NOT".split())
-
-        # take care not to mistake keywords for identifiers
-        ident = ~(AND | OR | NOT) + Word(alphas)
-        boolean_term = Optional(NOT) + ident
-
-        # very crude boolean expression - to support parenthesis groups and
-        # operation hierarchy, use infixNotation
-        boolean_expr = boolean_term + ZeroOrMore((AND | OR) + boolean_term)
-
-        # integers that are followed by "." are actually floats
-        integer = Word(nums) + ~Char(".")
-    """
-    def __init__(self, expr):
-        super(NotAny, self).__init__(expr)
-        # ~ self.leaveWhitespace()
-        self.skipWhitespace = False  # do NOT use self.leaveWhitespace(), don't want to propagate to exprs
-        self.mayReturnEmpty = True
-        self.errmsg = "Found unwanted token, " + _ustr(self.expr)
-
-    def parseImpl(self, instring, loc, doActions=True):
-        if self.expr.canParseNext(instring, loc):
-            raise ParseException(instring, loc, self.errmsg, self)
-        return loc, []
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "~{" + _ustr(self.expr) + "}"
-
-        return self.strRepr
-
-class _MultipleMatch(ParseElementEnhance):
-    def __init__(self, expr, stopOn=None):
-        super(_MultipleMatch, self).__init__(expr)
-        self.saveAsList = True
-        ender = stopOn
-        if isinstance(ender, basestring):
-            ender = self._literalStringClass(ender)
-        self.stopOn(ender)
-
-    def stopOn(self, ender):
-        if isinstance(ender, basestring):
-            ender = self._literalStringClass(ender)
-        self.not_ender = ~ender if ender is not None else None
-        return self
-
-    def parseImpl(self, instring, loc, doActions=True):
-        self_expr_parse = self.expr._parse
-        self_skip_ignorables = self._skipIgnorables
-        check_ender = self.not_ender is not None
-        if check_ender:
-            try_not_ender = self.not_ender.tryParse
-
-        # must be at least one (but first see if we are the stopOn sentinel;
-        # if so, fail)
-        if check_ender:
-            try_not_ender(instring, loc)
-        loc, tokens = self_expr_parse(instring, loc, doActions, callPreParse=False)
-        try:
-            hasIgnoreExprs = (not not self.ignoreExprs)
-            while 1:
-                if check_ender:
-                    try_not_ender(instring, loc)
-                if hasIgnoreExprs:
-                    preloc = self_skip_ignorables(instring, loc)
-                else:
-                    preloc = loc
-                loc, tmptokens = self_expr_parse(instring, preloc, doActions)
-                if tmptokens or tmptokens.haskeys():
-                    tokens += tmptokens
-        except (ParseException, IndexError):
-            pass
-
-        return loc, tokens
-
-    def _setResultsName(self, name, listAllMatches=False):
-        if __diag__.warn_ungrouped_named_tokens_in_collection:
-            for e in [self.expr] + getattr(self.expr, 'exprs', []):
-                if isinstance(e, ParserElement) and e.resultsName:
-                    warnings.warn("{0}: setting results name {1!r} on {2} expression "
-                                  "collides with {3!r} on contained expression".format("warn_ungrouped_named_tokens_in_collection",
-                                                                                       name,
-                                                                                       type(self).__name__,
-                                                                                       e.resultsName),
-                                  stacklevel=3)
-
-        return super(_MultipleMatch, self)._setResultsName(name, listAllMatches)
-
-
-class OneOrMore(_MultipleMatch):
-    """Repetition of one or more of the given expression.
-
-    Parameters:
-     - expr - expression that must match one or more times
-     - stopOn - (default= ``None``) - expression for a terminating sentinel
-          (only required if the sentinel would ordinarily match the repetition
-          expression)
-
-    Example::
-
-        data_word = Word(alphas)
-        label = data_word + FollowedBy(':')
-        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join))
-
-        text = "shape: SQUARE posn: upper left color: BLACK"
-        OneOrMore(attr_expr).parseString(text).pprint()  # Fail! read 'color' as data instead of next label -> [['shape', 'SQUARE color']]
-
-        # use stopOn attribute for OneOrMore to avoid reading label string as part of the data
-        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
-        OneOrMore(attr_expr).parseString(text).pprint() # Better -> [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'BLACK']]
-
-        # could also be written as
-        (attr_expr * (1,)).parseString(text).pprint()
-    """
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "{" + _ustr(self.expr) + "}..."
-
-        return self.strRepr
-
-class ZeroOrMore(_MultipleMatch):
-    """Optional repetition of zero or more of the given expression.
-
-    Parameters:
-     - expr - expression that must match zero or more times
-     - stopOn - (default= ``None``) - expression for a terminating sentinel
-          (only required if the sentinel would ordinarily match the repetition
-          expression)
-
-    Example: similar to :class:`OneOrMore`
-    """
-    def __init__(self, expr, stopOn=None):
-        super(ZeroOrMore, self).__init__(expr, stopOn=stopOn)
-        self.mayReturnEmpty = True
-
-    def parseImpl(self, instring, loc, doActions=True):
-        try:
-            return super(ZeroOrMore, self).parseImpl(instring, loc, doActions)
-        except (ParseException, IndexError):
-            return loc, []
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "[" + _ustr(self.expr) + "]..."
-
-        return self.strRepr
-
-
-class _NullToken(object):
-    def __bool__(self):
-        return False
-    __nonzero__ = __bool__
-    def __str__(self):
-        return ""
-
-class Optional(ParseElementEnhance):
-    """Optional matching of the given expression.
-
-    Parameters:
-     - expr - expression that must match zero or more times
-     - default (optional) - value to be returned if the optional expression is not found.
-
-    Example::
-
-        # US postal code can be a 5-digit zip, plus optional 4-digit qualifier
-        zip = Combine(Word(nums, exact=5) + Optional('-' + Word(nums, exact=4)))
-        zip.runTests('''
-            # traditional ZIP code
-            12345
-
-            # ZIP+4 form
-            12101-0001
-
-            # invalid ZIP
-            98765-
-            ''')
-
-    prints::
-
-        # traditional ZIP code
-        12345
-        ['12345']
-
-        # ZIP+4 form
-        12101-0001
-        ['12101-0001']
-
-        # invalid ZIP
-        98765-
-             ^
-        FAIL: Expected end of text (at char 5), (line:1, col:6)
-    """
-    __optionalNotMatched = _NullToken()
-
-    def __init__(self, expr, default=__optionalNotMatched):
-        super(Optional, self).__init__(expr, savelist=False)
-        self.saveAsList = self.expr.saveAsList
-        self.defaultValue = default
-        self.mayReturnEmpty = True
-
-    def parseImpl(self, instring, loc, doActions=True):
-        try:
-            loc, tokens = self.expr._parse(instring, loc, doActions, callPreParse=False)
-        except (ParseException, IndexError):
-            if self.defaultValue is not self.__optionalNotMatched:
-                if self.expr.resultsName:
-                    tokens = ParseResults([self.defaultValue])
-                    tokens[self.expr.resultsName] = self.defaultValue
-                else:
-                    tokens = [self.defaultValue]
-            else:
-                tokens = []
-        return loc, tokens
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-
-        if self.strRepr is None:
-            self.strRepr = "[" + _ustr(self.expr) + "]"
-
-        return self.strRepr
-
-class SkipTo(ParseElementEnhance):
-    """Token for skipping over all undefined text until the matched
-    expression is found.
-
-    Parameters:
-     - expr - target expression marking the end of the data to be skipped
-     - include - (default= ``False``) if True, the target expression is also parsed
-          (the skipped text and target expression are returned as a 2-element list).
-     - ignore - (default= ``None``) used to define grammars (typically quoted strings and
-          comments) that might contain false matches to the target expression
-     - failOn - (default= ``None``) define expressions that are not allowed to be
-          included in the skipped test; if found before the target expression is found,
-          the SkipTo is not a match
-
-    Example::
-
-        report = '''
-            Outstanding Issues Report - 1 Jan 2000
-
-               # | Severity | Description                               |  Days Open
-            -----+----------+-------------------------------------------+-----------
-             101 | Critical | Intermittent system crash                 |          6
-              94 | Cosmetic | Spelling error on Login ('log|n')         |         14
-              79 | Minor    | System slow when running too many reports |         47
-            '''
-        integer = Word(nums)
-        SEP = Suppress('|')
-        # use SkipTo to simply match everything up until the next SEP
-        # - ignore quoted strings, so that a '|' character inside a quoted string does not match
-        # - parse action will call token.strip() for each matched token, i.e., the description body
-        string_data = SkipTo(SEP, ignore=quotedString)
-        string_data.setParseAction(tokenMap(str.strip))
-        ticket_expr = (integer("issue_num") + SEP
-                      + string_data("sev") + SEP
-                      + string_data("desc") + SEP
-                      + integer("days_open"))
-
-        for tkt in ticket_expr.searchString(report):
-            print tkt.dump()
-
-    prints::
-
-        ['101', 'Critical', 'Intermittent system crash', '6']
-        - days_open: 6
-        - desc: Intermittent system crash
-        - issue_num: 101
-        - sev: Critical
-        ['94', 'Cosmetic', "Spelling error on Login ('log|n')", '14']
-        - days_open: 14
-        - desc: Spelling error on Login ('log|n')
-        - issue_num: 94
-        - sev: Cosmetic
-        ['79', 'Minor', 'System slow when running too many reports', '47']
-        - days_open: 47
-        - desc: System slow when running too many reports
-        - issue_num: 79
-        - sev: Minor
-    """
-    def __init__(self, other, include=False, ignore=None, failOn=None):
-        super(SkipTo, self).__init__(other)
-        self.ignoreExpr = ignore
-        self.mayReturnEmpty = True
-        self.mayIndexError = False
-        self.includeMatch = include
-        self.saveAsList = False
-        if isinstance(failOn, basestring):
-            self.failOn = self._literalStringClass(failOn)
-        else:
-            self.failOn = failOn
-        self.errmsg = "No match found for " + _ustr(self.expr)
-
-    def parseImpl(self, instring, loc, doActions=True):
-        startloc = loc
-        instrlen = len(instring)
-        expr = self.expr
-        expr_parse = self.expr._parse
-        self_failOn_canParseNext = self.failOn.canParseNext if self.failOn is not None else None
-        self_ignoreExpr_tryParse = self.ignoreExpr.tryParse if self.ignoreExpr is not None else None
-
-        tmploc = loc
-        while tmploc <= instrlen:
-            if self_failOn_canParseNext is not None:
-                # break if failOn expression matches
-                if self_failOn_canParseNext(instring, tmploc):
-                    break
-
-            if self_ignoreExpr_tryParse is not None:
-                # advance past ignore expressions
-                while 1:
-                    try:
-                        tmploc = self_ignoreExpr_tryParse(instring, tmploc)
-                    except ParseBaseException:
-                        break
-
-            try:
-                expr_parse(instring, tmploc, doActions=False, callPreParse=False)
-            except (ParseException, IndexError):
-                # no match, advance loc in string
-                tmploc += 1
-            else:
-                # matched skipto expr, done
-                break
-
-        else:
-            # ran off the end of the input string without matching skipto expr, fail
-            raise ParseException(instring, loc, self.errmsg, self)
-
-        # build up return values
-        loc = tmploc
-        skiptext = instring[startloc:loc]
-        skipresult = ParseResults(skiptext)
-
-        if self.includeMatch:
-            loc, mat = expr_parse(instring, loc, doActions, callPreParse=False)
-            skipresult += mat
-
-        return loc, skipresult
-
-class Forward(ParseElementEnhance):
-    """Forward declaration of an expression to be defined later -
-    used for recursive grammars, such as algebraic infix notation.
-    When the expression is known, it is assigned to the ``Forward``
-    variable using the '<<' operator.
-
-    Note: take care when assigning to ``Forward`` not to overlook
-    precedence of operators.
-
-    Specifically, '|' has a lower precedence than '<<', so that::
-
-        fwdExpr << a | b | c
-
-    will actually be evaluated as::
-
-        (fwdExpr << a) | b | c
-
-    thereby leaving b and c out as parseable alternatives.  It is recommended that you
-    explicitly group the values inserted into the ``Forward``::
-
-        fwdExpr << (a | b | c)
-
-    Converting to use the '<<=' operator instead will avoid this problem.
-
-    See :class:`ParseResults.pprint` for an example of a recursive
-    parser created using ``Forward``.
-    """
-    def __init__(self, other=None):
-        super(Forward, self).__init__(other, savelist=False)
-
-    def __lshift__(self, other):
-        if isinstance(other, basestring):
-            other = self._literalStringClass(other)
-        self.expr = other
-        self.strRepr = None
-        self.mayIndexError = self.expr.mayIndexError
-        self.mayReturnEmpty = self.expr.mayReturnEmpty
-        self.setWhitespaceChars(self.expr.whiteChars)
-        self.skipWhitespace = self.expr.skipWhitespace
-        self.saveAsList = self.expr.saveAsList
-        self.ignoreExprs.extend(self.expr.ignoreExprs)
-        return self
-
-    def __ilshift__(self, other):
-        return self << other
-
-    def leaveWhitespace(self):
-        self.skipWhitespace = False
-        return self
-
-    def streamline(self):
-        if not self.streamlined:
-            self.streamlined = True
-            if self.expr is not None:
-                self.expr.streamline()
-        return self
-
-    def validate(self, validateTrace=None):
-        if validateTrace is None:
-            validateTrace = []
-
-        if self not in validateTrace:
-            tmp = validateTrace[:] + [self]
-            if self.expr is not None:
-                self.expr.validate(tmp)
-        self.checkRecursion([])
-
-    def __str__(self):
-        if hasattr(self, "name"):
-            return self.name
-        if self.strRepr is not None:
-            return self.strRepr
-
-        # Avoid infinite recursion by setting a temporary strRepr
-        self.strRepr = ": ..."
-
-        # Use the string representation of main expression.
-        retString = '...'
-        try:
-            if self.expr is not None:
-                retString = _ustr(self.expr)[:1000]
-            else:
-                retString = "None"
-        finally:
-            self.strRepr = self.__class__.__name__ + ": " + retString
-        return self.strRepr
-
-    def copy(self):
-        if self.expr is not None:
-            return super(Forward, self).copy()
-        else:
-            ret = Forward()
-            ret <<= self
-            return ret
-
-    def _setResultsName(self, name, listAllMatches=False):
-        if __diag__.warn_name_set_on_empty_Forward:
-            if self.expr is None:
-                warnings.warn("{0}: setting results name {0!r} on {1} expression "
-                              "that has no contained expression".format("warn_name_set_on_empty_Forward",
-                                                                        name,
-                                                                        type(self).__name__),
-                              stacklevel=3)
-
-        return super(Forward, self)._setResultsName(name, listAllMatches)
-
-class TokenConverter(ParseElementEnhance):
-    """
-    Abstract subclass of :class:`ParseExpression`, for converting parsed results.
-    """
-    def __init__(self, expr, savelist=False):
-        super(TokenConverter, self).__init__(expr)  # , savelist)
-        self.saveAsList = False
-
-class Combine(TokenConverter):
-    """Converter to concatenate all matching tokens to a single string.
-    By default, the matching patterns must also be contiguous in the
-    input string; this can be disabled by specifying
-    ``'adjacent=False'`` in the constructor.
-
-    Example::
-
-        real = Word(nums) + '.' + Word(nums)
-        print(real.parseString('3.1416')) # -> ['3', '.', '1416']
-        # will also erroneously match the following
-        print(real.parseString('3. 1416')) # -> ['3', '.', '1416']
-
-        real = Combine(Word(nums) + '.' + Word(nums))
-        print(real.parseString('3.1416')) # -> ['3.1416']
-        # no match when there are internal spaces
-        print(real.parseString('3. 1416')) # -> Exception: Expected W:(0123...)
-    """
-    def __init__(self, expr, joinString="", adjacent=True):
-        super(Combine, self).__init__(expr)
-        # suppress whitespace-stripping in contained parse expressions, but re-enable it on the Combine itself
-        if adjacent:
-            self.leaveWhitespace()
-        self.adjacent = adjacent
-        self.skipWhitespace = True
-        self.joinString = joinString
-        self.callPreparse = True
-
-    def ignore(self, other):
-        if self.adjacent:
-            ParserElement.ignore(self, other)
-        else:
-            super(Combine, self).ignore(other)
-        return self
-
-    def postParse(self, instring, loc, tokenlist):
-        retToks = tokenlist.copy()
-        del retToks[:]
-        retToks += ParseResults(["".join(tokenlist._asStringList(self.joinString))], modal=self.modalResults)
-
-        if self.resultsName and retToks.haskeys():
-            return [retToks]
-        else:
-            return retToks
-
-class Group(TokenConverter):
-    """Converter to return the matched tokens as a list - useful for
-    returning tokens of :class:`ZeroOrMore` and :class:`OneOrMore` expressions.
-
-    Example::
-
-        ident = Word(alphas)
-        num = Word(nums)
-        term = ident | num
-        func = ident + Optional(delimitedList(term))
-        print(func.parseString("fn a, b, 100"))  # -> ['fn', 'a', 'b', '100']
-
-        func = ident + Group(Optional(delimitedList(term)))
-        print(func.parseString("fn a, b, 100"))  # -> ['fn', ['a', 'b', '100']]
-    """
-    def __init__(self, expr):
-        super(Group, self).__init__(expr)
-        self.saveAsList = True
-
-    def postParse(self, instring, loc, tokenlist):
-        return [tokenlist]
-
-class Dict(TokenConverter):
-    """Converter to return a repetitive expression as a list, but also
-    as a dictionary. Each element can also be referenced using the first
-    token in the expression as its key. Useful for tabular report
-    scraping when the first column can be used as a item key.
-
-    Example::
-
-        data_word = Word(alphas)
-        label = data_word + FollowedBy(':')
-        attr_expr = Group(label + Suppress(':') + OneOrMore(data_word).setParseAction(' '.join))
-
-        text = "shape: SQUARE posn: upper left color: light blue texture: burlap"
-        attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
-
-        # print attributes as plain groups
-        print(OneOrMore(attr_expr).parseString(text).dump())
-
-        # instead of OneOrMore(expr), parse using Dict(OneOrMore(Group(expr))) - Dict will auto-assign names
-        result = Dict(OneOrMore(Group(attr_expr))).parseString(text)
-        print(result.dump())
-
-        # access named fields as dict entries, or output as dict
-        print(result['shape'])
-        print(result.asDict())
-
-    prints::
-
-        ['shape', 'SQUARE', 'posn', 'upper left', 'color', 'light blue', 'texture', 'burlap']
-        [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']]
-        - color: light blue
-        - posn: upper left
-        - shape: SQUARE
-        - texture: burlap
-        SQUARE
-        {'color': 'light blue', 'posn': 'upper left', 'texture': 'burlap', 'shape': 'SQUARE'}
-
-    See more examples at :class:`ParseResults` of accessing fields by results name.
-    """
-    def __init__(self, expr):
-        super(Dict, self).__init__(expr)
-        self.saveAsList = True
-
-    def postParse(self, instring, loc, tokenlist):
-        for i, tok in enumerate(tokenlist):
-            if len(tok) == 0:
-                continue
-            ikey = tok[0]
-            if isinstance(ikey, int):
-                ikey = _ustr(tok[0]).strip()
-            if len(tok) == 1:
-                tokenlist[ikey] = _ParseResultsWithOffset("", i)
-            elif len(tok) == 2 and not isinstance(tok[1], ParseResults):
-                tokenlist[ikey] = _ParseResultsWithOffset(tok[1], i)
-            else:
-                dictvalue = tok.copy()  # ParseResults(i)
-                del dictvalue[0]
-                if len(dictvalue) != 1 or (isinstance(dictvalue, ParseResults) and dictvalue.haskeys()):
-                    tokenlist[ikey] = _ParseResultsWithOffset(dictvalue, i)
-                else:
-                    tokenlist[ikey] = _ParseResultsWithOffset(dictvalue[0], i)
-
-        if self.resultsName:
-            return [tokenlist]
-        else:
-            return tokenlist
-
-
-class Suppress(TokenConverter):
-    """Converter for ignoring the results of a parsed expression.
-
-    Example::
-
-        source = "a, b, c,d"
-        wd = Word(alphas)
-        wd_list1 = wd + ZeroOrMore(',' + wd)
-        print(wd_list1.parseString(source))
-
-        # often, delimiters that are useful during parsing are just in the
-        # way afterward - use Suppress to keep them out of the parsed output
-        wd_list2 = wd + ZeroOrMore(Suppress(',') + wd)
-        print(wd_list2.parseString(source))
-
-    prints::
-
-        ['a', ',', 'b', ',', 'c', ',', 'd']
-        ['a', 'b', 'c', 'd']
-
-    (See also :class:`delimitedList`.)
-    """
-    def postParse(self, instring, loc, tokenlist):
-        return []
-
-    def suppress(self):
-        return self
-
-
-class OnlyOnce(object):
-    """Wrapper for parse actions, to ensure they are only called once.
-    """
-    def __init__(self, methodCall):
-        self.callable = _trim_arity(methodCall)
-        self.called = False
-    def __call__(self, s, l, t):
-        if not self.called:
-            results = self.callable(s, l, t)
-            self.called = True
-            return results
-        raise ParseException(s, l, "")
-    def reset(self):
-        self.called = False
-
-def traceParseAction(f):
-    """Decorator for debugging parse actions.
-
-    When the parse action is called, this decorator will print
-    ``">> entering method-name(line:<current_source_line>, <parse_location>, <matched_tokens>)"``.
-    When the parse action completes, the decorator will print
-    ``"<<"`` followed by the returned value, or any exception that the parse action raised.
-
-    Example::
-
-        wd = Word(alphas)
-
-        @traceParseAction
-        def remove_duplicate_chars(tokens):
-            return ''.join(sorted(set(''.join(tokens))))
-
-        wds = OneOrMore(wd).setParseAction(remove_duplicate_chars)
-        print(wds.parseString("slkdjs sld sldd sdlf sdljf"))
-
-    prints::
-
-        >>entering remove_duplicate_chars(line: 'slkdjs sld sldd sdlf sdljf', 0, (['slkdjs', 'sld', 'sldd', 'sdlf', 'sdljf'], {}))
-        <<leaving remove_duplicate_chars (ret: 'dfjkls')
-        ['dfjkls']
-    """
-    f = _trim_arity(f)
-    def z(*paArgs):
-        thisFunc = f.__name__
-        s, l, t = paArgs[-3:]
-        if len(paArgs) > 3:
-            thisFunc = paArgs[0].__class__.__name__ + '.' + thisFunc
-        sys.stderr.write(">>entering %s(line: '%s', %d, %r)\n" % (thisFunc, line(l, s), l, t))
-        try:
-            ret = f(*paArgs)
-        except Exception as exc:
-            sys.stderr.write("<<leaving %s (exception: %s)\n" % (thisFunc, exc))
-            raise
-        sys.stderr.write("<<leaving %s (ret: %r)\n" % (thisFunc, ret))
-        return ret
-    try:
-        z.__name__ = f.__name__
-    except AttributeError:
-        pass
-    return z
-
-#
-# global helpers
-#
-def delimitedList(expr, delim=",", combine=False):
-    """Helper to define a delimited list of expressions - the delimiter
-    defaults to ','. By default, the list elements and delimiters can
-    have intervening whitespace, and comments, but this can be
-    overridden by passing ``combine=True`` in the constructor. If
-    ``combine`` is set to ``True``, the matching tokens are
-    returned as a single token string, with the delimiters included;
-    otherwise, the matching tokens are returned as a list of tokens,
-    with the delimiters suppressed.
-
-    Example::
-
-        delimitedList(Word(alphas)).parseString("aa,bb,cc") # -> ['aa', 'bb', 'cc']
-        delimitedList(Word(hexnums), delim=':', combine=True).parseString("AA:BB:CC:DD:EE") # -> ['AA:BB:CC:DD:EE']
-    """
-    dlName = _ustr(expr) + " [" + _ustr(delim) + " " + _ustr(expr) + "]..."
-    if combine:
-        return Combine(expr + ZeroOrMore(delim + expr)).setName(dlName)
-    else:
-        return (expr + ZeroOrMore(Suppress(delim) + expr)).setName(dlName)
-
-def countedArray(expr, intExpr=None):
-    """Helper to define a counted list of expressions.
-
-    This helper defines a pattern of the form::
-
-        integer expr expr expr...
-
-    where the leading integer tells how many expr expressions follow.
-    The matched tokens returns the array of expr tokens as a list - the
-    leading count token is suppressed.
-
-    If ``intExpr`` is specified, it should be a pyparsing expression
-    that produces an integer value.
-
-    Example::
-
-        countedArray(Word(alphas)).parseString('2 ab cd ef')  # -> ['ab', 'cd']
-
-        # in this parser, the leading integer value is given in binary,
-        # '10' indicating that 2 values are in the array
-        binaryConstant = Word('01').setParseAction(lambda t: int(t[0], 2))
-        countedArray(Word(alphas), intExpr=binaryConstant).parseString('10 ab cd ef')  # -> ['ab', 'cd']
-    """
-    arrayExpr = Forward()
-    def countFieldParseAction(s, l, t):
-        n = t[0]
-        arrayExpr << (n and Group(And([expr] * n)) or Group(empty))
-        return []
-    if intExpr is None:
-        intExpr = Word(nums).setParseAction(lambda t: int(t[0]))
-    else:
-        intExpr = intExpr.copy()
-    intExpr.setName("arrayLen")
-    intExpr.addParseAction(countFieldParseAction, callDuringTry=True)
-    return (intExpr + arrayExpr).setName('(len) ' + _ustr(expr) + '...')
-
-def _flatten(L):
-    ret = []
-    for i in L:
-        if isinstance(i, list):
-            ret.extend(_flatten(i))
-        else:
-            ret.append(i)
-    return ret
-
-def matchPreviousLiteral(expr):
-    """Helper to define an expression that is indirectly defined from
-    the tokens matched in a previous expression, that is, it looks for
-    a 'repeat' of a previous expression.  For example::
-
-        first = Word(nums)
-        second = matchPreviousLiteral(first)
-        matchExpr = first + ":" + second
-
-    will match ``"1:1"``, but not ``"1:2"``.  Because this
-    matches a previous literal, will also match the leading
-    ``"1:1"`` in ``"1:10"``. If this is not desired, use
-    :class:`matchPreviousExpr`. Do *not* use with packrat parsing
-    enabled.
-    """
-    rep = Forward()
-    def copyTokenToRepeater(s, l, t):
-        if t:
-            if len(t) == 1:
-                rep << t[0]
-            else:
-                # flatten t tokens
-                tflat = _flatten(t.asList())
-                rep << And(Literal(tt) for tt in tflat)
-        else:
-            rep << Empty()
-    expr.addParseAction(copyTokenToRepeater, callDuringTry=True)
-    rep.setName('(prev) ' + _ustr(expr))
-    return rep
-
-def matchPreviousExpr(expr):
-    """Helper to define an expression that is indirectly defined from
-    the tokens matched in a previous expression, that is, it looks for
-    a 'repeat' of a previous expression.  For example::
-
-        first = Word(nums)
-        second = matchPreviousExpr(first)
-        matchExpr = first + ":" + second
-
-    will match ``"1:1"``, but not ``"1:2"``.  Because this
-    matches by expressions, will *not* match the leading ``"1:1"``
-    in ``"1:10"``; the expressions are evaluated first, and then
-    compared, so ``"1"`` is compared with ``"10"``. Do *not* use
-    with packrat parsing enabled.
-    """
-    rep = Forward()
-    e2 = expr.copy()
-    rep <<= e2
-    def copyTokenToRepeater(s, l, t):
-        matchTokens = _flatten(t.asList())
-        def mustMatchTheseTokens(s, l, t):
-            theseTokens = _flatten(t.asList())
-            if theseTokens != matchTokens:
-                raise ParseException('', 0, '')
-        rep.setParseAction(mustMatchTheseTokens, callDuringTry=True)
-    expr.addParseAction(copyTokenToRepeater, callDuringTry=True)
-    rep.setName('(prev) ' + _ustr(expr))
-    return rep
-
-def _escapeRegexRangeChars(s):
-    # ~  escape these chars: ^-[]
-    for c in r"\^-[]":
-        s = s.replace(c, _bslash + c)
-    s = s.replace("\n", r"\n")
-    s = s.replace("\t", r"\t")
-    return _ustr(s)
-
-def oneOf(strs, caseless=False, useRegex=True, asKeyword=False):
-    """Helper to quickly define a set of alternative Literals, and makes
-    sure to do longest-first testing when there is a conflict,
-    regardless of the input order, but returns
-    a :class:`MatchFirst` for best performance.
-
-    Parameters:
-
-     - strs - a string of space-delimited literals, or a collection of
-       string literals
-     - caseless - (default= ``False``) - treat all literals as
-       caseless
-     - useRegex - (default= ``True``) - as an optimization, will
-       generate a Regex object; otherwise, will generate
-       a :class:`MatchFirst` object (if ``caseless=True`` or ``asKeyword=True``, or if
-       creating a :class:`Regex` raises an exception)
-     - asKeyword - (default=``False``) - enforce Keyword-style matching on the
-       generated expressions
-
-    Example::
-
-        comp_oper = oneOf("< = > <= >= !=")
-        var = Word(alphas)
-        number = Word(nums)
-        term = var | number
-        comparison_expr = term + comp_oper + term
-        print(comparison_expr.searchString("B = 12  AA=23 B<=AA AA>12"))
-
-    prints::
-
-        [['B', '=', '12'], ['AA', '=', '23'], ['B', '<=', 'AA'], ['AA', '>', '12']]
-    """
-    if isinstance(caseless, basestring):
-        warnings.warn("More than one string argument passed to oneOf, pass "
-                      "choices as a list or space-delimited string", stacklevel=2)
-
-    if caseless:
-        isequal = (lambda a, b: a.upper() == b.upper())
-        masks = (lambda a, b: b.upper().startswith(a.upper()))
-        parseElementClass = CaselessKeyword if asKeyword else CaselessLiteral
-    else:
-        isequal = (lambda a, b: a == b)
-        masks = (lambda a, b: b.startswith(a))
-        parseElementClass = Keyword if asKeyword else Literal
-
-    symbols = []
-    if isinstance(strs, basestring):
-        symbols = strs.split()
-    elif isinstance(strs, Iterable):
-        symbols = list(strs)
-    else:
-        warnings.warn("Invalid argument to oneOf, expected string or iterable",
-                      SyntaxWarning, stacklevel=2)
-    if not symbols:
-        return NoMatch()
-
-    if not asKeyword:
-        # if not producing keywords, need to reorder to take care to avoid masking
-        # longer choices with shorter ones
-        i = 0
-        while i < len(symbols) - 1:
-            cur = symbols[i]
-            for j, other in enumerate(symbols[i + 1:]):
-                if isequal(other, cur):
-                    del symbols[i + j + 1]
-                    break
-                elif masks(cur, other):
-                    del symbols[i + j + 1]
-                    symbols.insert(i, other)
-                    break
-            else:
-                i += 1
-
-    if not (caseless or asKeyword) and useRegex:
-        # ~ print (strs, "->", "|".join([_escapeRegexChars(sym) for sym in symbols]))
-        try:
-            if len(symbols) == len("".join(symbols)):
-                return Regex("[%s]" % "".join(_escapeRegexRangeChars(sym) for sym in symbols)).setName(' | '.join(symbols))
-            else:
-                return Regex("|".join(re.escape(sym) for sym in symbols)).setName(' | '.join(symbols))
-        except Exception:
-            warnings.warn("Exception creating Regex for oneOf, building MatchFirst",
-                    SyntaxWarning, stacklevel=2)
-
-    # last resort, just use MatchFirst
-    return MatchFirst(parseElementClass(sym) for sym in symbols).setName(' | '.join(symbols))
-
-def dictOf(key, value):
-    """Helper to easily and clearly define a dictionary by specifying
-    the respective patterns for the key and value.  Takes care of
-    defining the :class:`Dict`, :class:`ZeroOrMore`, and
-    :class:`Group` tokens in the proper order.  The key pattern
-    can include delimiting markers or punctuation, as long as they are
-    suppressed, thereby leaving the significant key text.  The value
-    pattern can include named results, so that the :class:`Dict` results
-    can include named token fields.
-
-    Example::
-
-        text = "shape: SQUARE posn: upper left color: light blue texture: burlap"
-        attr_expr = (label + Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join))
-        print(OneOrMore(attr_expr).parseString(text).dump())
-
-        attr_label = label
-        attr_value = Suppress(':') + OneOrMore(data_word, stopOn=label).setParseAction(' '.join)
-
-        # similar to Dict, but simpler call format
-        result = dictOf(attr_label, attr_value).parseString(text)
-        print(result.dump())
-        print(result['shape'])
-        print(result.shape)  # object attribute access works too
-        print(result.asDict())
-
-    prints::
-
-        [['shape', 'SQUARE'], ['posn', 'upper left'], ['color', 'light blue'], ['texture', 'burlap']]
-        - color: light blue
-        - posn: upper left
-        - shape: SQUARE
-        - texture: burlap
-        SQUARE
-        SQUARE
-        {'color': 'light blue', 'shape': 'SQUARE', 'posn': 'upper left', 'texture': 'burlap'}
-    """
-    return Dict(OneOrMore(Group(key + value)))
-
-def originalTextFor(expr, asString=True):
-    """Helper to return the original, untokenized text for a given
-    expression.  Useful to restore the parsed fields of an HTML start
-    tag into the raw tag text itself, or to revert separate tokens with
-    intervening whitespace back to the original matching input text. By
-    default, returns astring containing the original parsed text.
-
-    If the optional ``asString`` argument is passed as
-    ``False``, then the return value is
-    a :class:`ParseResults` containing any results names that
-    were originally matched, and a single token containing the original
-    matched text from the input string.  So if the expression passed to
-    :class:`originalTextFor` contains expressions with defined
-    results names, you must set ``asString`` to ``False`` if you
-    want to preserve those results name values.
-
-    Example::
-
-        src = "this is test <b> bold <i>text</i> </b> normal text "
-        for tag in ("b", "i"):
-            opener, closer = makeHTMLTags(tag)
-            patt = originalTextFor(opener + SkipTo(closer) + closer)
-            print(patt.searchString(src)[0])
-
-    prints::
-
-        ['<b> bold <i>text</i> </b>']
-        ['<i>text</i>']
-    """
-    locMarker = Empty().setParseAction(lambda s, loc, t: loc)
-    endlocMarker = locMarker.copy()
-    endlocMarker.callPreparse = False
-    matchExpr = locMarker("_original_start") + expr + endlocMarker("_original_end")
-    if asString:
-        extractText = lambda s, l, t: s[t._original_start: t._original_end]
-    else:
-        def extractText(s, l, t):
-            t[:] = [s[t.pop('_original_start'):t.pop('_original_end')]]
-    matchExpr.setParseAction(extractText)
-    matchExpr.ignoreExprs = expr.ignoreExprs
-    return matchExpr
-
-def ungroup(expr):
-    """Helper to undo pyparsing's default grouping of And expressions,
-    even if all but one are non-empty.
-    """
-    return TokenConverter(expr).addParseAction(lambda t: t[0])
-
-def locatedExpr(expr):
-    """Helper to decorate a returned token with its starting and ending
-    locations in the input string.
-
-    This helper adds the following results names:
-
-     - locn_start = location where matched expression begins
-     - locn_end = location where matched expression ends
-     - value = the actual parsed results
-
-    Be careful if the input text contains ``<TAB>`` characters, you
-    may want to call :class:`ParserElement.parseWithTabs`
-
-    Example::
-
-        wd = Word(alphas)
-        for match in locatedExpr(wd).searchString("ljsdf123lksdjjf123lkkjj1222"):
-            print(match)
-
-    prints::
-
-        [[0, 'ljsdf', 5]]
-        [[8, 'lksdjjf', 15]]
-        [[18, 'lkkjj', 23]]
-    """
-    locator = Empty().setParseAction(lambda s, l, t: l)
-    return Group(locator("locn_start") + expr("value") + locator.copy().leaveWhitespace()("locn_end"))
-
-
-# convenience constants for positional expressions
-empty       = Empty().setName("empty")
-lineStart   = LineStart().setName("lineStart")
-lineEnd     = LineEnd().setName("lineEnd")
-stringStart = StringStart().setName("stringStart")
-stringEnd   = StringEnd().setName("stringEnd")
-
-_escapedPunc = Word(_bslash, r"\[]-*.$+^?()~ ", exact=2).setParseAction(lambda s, l, t: t[0][1])
-_escapedHexChar = Regex(r"\\0?[xX][0-9a-fA-F]+").setParseAction(lambda s, l, t: unichr(int(t[0].lstrip(r'\0x'), 16)))
-_escapedOctChar = Regex(r"\\0[0-7]+").setParseAction(lambda s, l, t: unichr(int(t[0][1:], 8)))
-_singleChar = _escapedPunc | _escapedHexChar | _escapedOctChar | CharsNotIn(r'\]', exact=1)
-_charRange = Group(_singleChar + Suppress("-") + _singleChar)
-_reBracketExpr = Literal("[") + Optional("^").setResultsName("negate") + Group(OneOrMore(_charRange | _singleChar)).setResultsName("body") + "]"
-
-def srange(s):
-    r"""Helper to easily define string ranges for use in Word
-    construction. Borrows syntax from regexp '[]' string range
-    definitions::
-
-        srange("[0-9]")   -> "0123456789"
-        srange("[a-z]")   -> "abcdefghijklmnopqrstuvwxyz"
-        srange("[a-z$_]") -> "abcdefghijklmnopqrstuvwxyz$_"
-
-    The input string must be enclosed in []'s, and the returned string
-    is the expanded character set joined into a single string. The
-    values enclosed in the []'s may be:
-
-     - a single character
-     - an escaped character with a leading backslash (such as ``\-``
-       or ``\]``)
-     - an escaped hex character with a leading ``'\x'``
-       (``\x21``, which is a ``'!'`` character) (``\0x##``
-       is also supported for backwards compatibility)
-     - an escaped octal character with a leading ``'\0'``
-       (``\041``, which is a ``'!'`` character)
-     - a range of any of the above, separated by a dash (``'a-z'``,
-       etc.)
-     - any combination of the above (``'aeiouy'``,
-       ``'a-zA-Z0-9_$'``, etc.)
-    """
-    _expanded = lambda p: p if not isinstance(p, ParseResults) else ''.join(unichr(c) for c in range(ord(p[0]), ord(p[1]) + 1))
-    try:
-        return "".join(_expanded(part) for part in _reBracketExpr.parseString(s).body)
-    except Exception:
-        return ""
-
-def matchOnlyAtCol(n):
-    """Helper method for defining parse actions that require matching at
-    a specific column in the input text.
-    """
-    def verifyCol(strg, locn, toks):
-        if col(locn, strg) != n:
-            raise ParseException(strg, locn, "matched token not at column %d" % n)
-    return verifyCol
-
-def replaceWith(replStr):
-    """Helper method for common parse actions that simply return
-    a literal value.  Especially useful when used with
-    :class:`transformString<ParserElement.transformString>` ().
-
-    Example::
-
-        num = Word(nums).setParseAction(lambda toks: int(toks[0]))
-        na = oneOf("N/A NA").setParseAction(replaceWith(math.nan))
-        term = na | num
-
-        OneOrMore(term).parseString("324 234 N/A 234") # -> [324, 234, nan, 234]
-    """
-    return lambda s, l, t: [replStr]
-
-def removeQuotes(s, l, t):
-    """Helper parse action for removing quotation marks from parsed
-    quoted strings.
-
-    Example::
-
-        # by default, quotation marks are included in parsed results
-        quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["'Now is the Winter of our Discontent'"]
-
-        # use removeQuotes to strip quotation marks from parsed results
-        quotedString.setParseAction(removeQuotes)
-        quotedString.parseString("'Now is the Winter of our Discontent'") # -> ["Now is the Winter of our Discontent"]
-    """
-    return t[0][1:-1]
-
-def tokenMap(func, *args):
-    """Helper to define a parse action by mapping a function to all
-    elements of a ParseResults list. If any additional args are passed,
-    they are forwarded to the given function as additional arguments
-    after the token, as in
-    ``hex_integer = Word(hexnums).setParseAction(tokenMap(int, 16))``,
-    which will convert the parsed data to an integer using base 16.
-
-    Example (compare the last to example in :class:`ParserElement.transformString`::
-
-        hex_ints = OneOrMore(Word(hexnums)).setParseAction(tokenMap(int, 16))
-        hex_ints.runTests('''
-            00 11 22 aa FF 0a 0d 1a
-            ''')
-
-        upperword = Word(alphas).setParseAction(tokenMap(str.upper))
-        OneOrMore(upperword).runTests('''
-            my kingdom for a horse
-            ''')
-
-        wd = Word(alphas).setParseAction(tokenMap(str.title))
-        OneOrMore(wd).setParseAction(' '.join).runTests('''
-            now is the winter of our discontent made glorious summer by this sun of york
-            ''')
-
-    prints::
-
-        00 11 22 aa FF 0a 0d 1a
-        [0, 17, 34, 170, 255, 10, 13, 26]
-
-        my kingdom for a horse
-        ['MY', 'KINGDOM', 'FOR', 'A', 'HORSE']
-
-        now is the winter of our discontent made glorious summer by this sun of york
-        ['Now Is The Winter Of Our Discontent Made Glorious Summer By This Sun Of York']
-    """
-    def pa(s, l, t):
-        return [func(tokn, *args) for tokn in t]
-
-    try:
-        func_name = getattr(func, '__name__',
-                            getattr(func, '__class__').__name__)
-    except Exception:
-        func_name = str(func)
-    pa.__name__ = func_name
-
-    return pa
-
-upcaseTokens = tokenMap(lambda t: _ustr(t).upper())
-"""(Deprecated) Helper parse action to convert tokens to upper case.
-Deprecated in favor of :class:`pyparsing_common.upcaseTokens`"""
-
-downcaseTokens = tokenMap(lambda t: _ustr(t).lower())
-"""(Deprecated) Helper parse action to convert tokens to lower case.
-Deprecated in favor of :class:`pyparsing_common.downcaseTokens`"""
-
-def _makeTags(tagStr, xml,
-              suppress_LT=Suppress("<"),
-              suppress_GT=Suppress(">")):
-    """Internal helper to construct opening and closing tag expressions, given a tag name"""
-    if isinstance(tagStr, basestring):
-        resname = tagStr
-        tagStr = Keyword(tagStr, caseless=not xml)
-    else:
-        resname = tagStr.name
-
-    tagAttrName = Word(alphas, alphanums + "_-:")
-    if xml:
-        tagAttrValue = dblQuotedString.copy().setParseAction(removeQuotes)
-        openTag = (suppress_LT
-                   + tagStr("tag")
-                   + Dict(ZeroOrMore(Group(tagAttrName + Suppress("=") + tagAttrValue)))
-                   + Optional("/", default=[False])("empty").setParseAction(lambda s, l, t: t[0] == '/')
-                   + suppress_GT)
-    else:
-        tagAttrValue = quotedString.copy().setParseAction(removeQuotes) | Word(printables, excludeChars=">")
-        openTag = (suppress_LT
-                   + tagStr("tag")
-                   + Dict(ZeroOrMore(Group(tagAttrName.setParseAction(downcaseTokens)
-                                           + Optional(Suppress("=") + tagAttrValue))))
-                   + Optional("/", default=[False])("empty").setParseAction(lambda s, l, t: t[0] == '/')
-                   + suppress_GT)
-    closeTag = Combine(_L("</") + tagStr + ">", adjacent=False)
-
-    openTag.setName("<%s>" % resname)
-    # add start<tagname> results name in parse action now that ungrouped names are not reported at two levels
-    openTag.addParseAction(lambda t: t.__setitem__("start" + "".join(resname.replace(":", " ").title().split()), t.copy()))
-    closeTag = closeTag("end" + "".join(resname.replace(":", " ").title().split())).setName("</%s>" % resname)
-    openTag.tag = resname
-    closeTag.tag = resname
-    openTag.tag_body = SkipTo(closeTag())
-    return openTag, closeTag
-
-def makeHTMLTags(tagStr):
-    """Helper to construct opening and closing tag expressions for HTML,
-    given a tag name. Matches tags in either upper or lower case,
-    attributes with namespaces and with quoted or unquoted values.
-
-    Example::
-
-        text = '<td>More info at the <a href="https://github.com/pyparsing/pyparsing/wiki">pyparsing</a> wiki page</td>'
-        # makeHTMLTags returns pyparsing expressions for the opening and
-        # closing tags as a 2-tuple
-        a, a_end = makeHTMLTags("A")
-        link_expr = a + SkipTo(a_end)("link_text") + a_end
-
-        for link in link_expr.searchString(text):
-            # attributes in the <A> tag (like "href" shown here) are
-            # also accessible as named results
-            print(link.link_text, '->', link.href)
-
-    prints::
-
-        pyparsing -> https://github.com/pyparsing/pyparsing/wiki
-    """
-    return _makeTags(tagStr, False)
-
-def makeXMLTags(tagStr):
-    """Helper to construct opening and closing tag expressions for XML,
-    given a tag name. Matches tags only in the given upper/lower case.
-
-    Example: similar to :class:`makeHTMLTags`
-    """
-    return _makeTags(tagStr, True)
-
-def withAttribute(*args, **attrDict):
-    """Helper to create a validating parse action to be used with start
-    tags created with :class:`makeXMLTags` or
-    :class:`makeHTMLTags`. Use ``withAttribute`` to qualify
-    a starting tag with a required attribute value, to avoid false
-    matches on common tags such as ``<TD>`` or ``<DIV>``.
-
-    Call ``withAttribute`` with a series of attribute names and
-    values. Specify the list of filter attributes names and values as:
-
-     - keyword arguments, as in ``(align="right")``, or
-     - as an explicit dict with ``**`` operator, when an attribute
-       name is also a Python reserved word, as in ``**{"class":"Customer", "align":"right"}``
-     - a list of name-value tuples, as in ``(("ns1:class", "Customer"), ("ns2:align", "right"))``
-
-    For attribute names with a namespace prefix, you must use the second
-    form.  Attribute names are matched insensitive to upper/lower case.
-
-    If just testing for ``class`` (with or without a namespace), use
-    :class:`withClass`.
-
-    To verify that the attribute exists, but without specifying a value,
-    pass ``withAttribute.ANY_VALUE`` as the value.
-
-    Example::
-
-        html = '''
-            <div>
-            Some text
-            <div type="grid">1 4 0 1 0</div>
-            <div type="graph">1,3 2,3 1,1</div>
-            <div>this has no type</div>
-            </div>
-
-        '''
-        div,div_end = makeHTMLTags("div")
-
-        # only match div tag having a type attribute with value "grid"
-        div_grid = div().setParseAction(withAttribute(type="grid"))
-        grid_expr = div_grid + SkipTo(div | div_end)("body")
-        for grid_header in grid_expr.searchString(html):
-            print(grid_header.body)
-
-        # construct a match with any div tag having a type attribute, regardless of the value
-        div_any_type = div().setParseAction(withAttribute(type=withAttribute.ANY_VALUE))
-        div_expr = div_any_type + SkipTo(div | div_end)("body")
-        for div_header in div_expr.searchString(html):
-            print(div_header.body)
-
-    prints::
-
-        1 4 0 1 0
-
-        1 4 0 1 0
-        1,3 2,3 1,1
-    """
-    if args:
-        attrs = args[:]
-    else:
-        attrs = attrDict.items()
-    attrs = [(k, v) for k, v in attrs]
-    def pa(s, l, tokens):
-        for attrName, attrValue in attrs:
-            if attrName not in tokens:
-                raise ParseException(s, l, "no matching attribute " + attrName)
-            if attrValue != withAttribute.ANY_VALUE and tokens[attrName] != attrValue:
-                raise ParseException(s, l, "attribute '%s' has value '%s', must be '%s'" %
-                                            (attrName, tokens[attrName], attrValue))
-    return pa
-withAttribute.ANY_VALUE = object()
-
-def withClass(classname, namespace=''):
-    """Simplified version of :class:`withAttribute` when
-    matching on a div class - made difficult because ``class`` is
-    a reserved word in Python.
-
-    Example::
-
-        html = '''
-            <div>
-            Some text
-            <div class="grid">1 4 0 1 0</div>
-            <div class="graph">1,3 2,3 1,1</div>
-            <div>this &lt;div&gt; has no class</div>
-            </div>
-
-        '''
-        div,div_end = makeHTMLTags("div")
-        div_grid = div().setParseAction(withClass("grid"))
-
-        grid_expr = div_grid + SkipTo(div | div_end)("body")
-        for grid_header in grid_expr.searchString(html):
-            print(grid_header.body)
-
-        div_any_type = div().setParseAction(withClass(withAttribute.ANY_VALUE))
-        div_expr = div_any_type + SkipTo(div | div_end)("body")
-        for div_header in div_expr.searchString(html):
-            print(div_header.body)
-
-    prints::
-
-        1 4 0 1 0
-
-        1 4 0 1 0
-        1,3 2,3 1,1
-    """
-    classattr = "%s:class" % namespace if namespace else "class"
-    return withAttribute(**{classattr: classname})
-
-opAssoc = SimpleNamespace()
-opAssoc.LEFT = object()
-opAssoc.RIGHT = object()
-
-def infixNotation(baseExpr, opList, lpar=Suppress('('), rpar=Suppress(')')):
-    """Helper method for constructing grammars of expressions made up of
-    operators working in a precedence hierarchy.  Operators may be unary
-    or binary, left- or right-associative.  Parse actions can also be
-    attached to operator expressions. The generated parser will also
-    recognize the use of parentheses to override operator precedences
-    (see example below).
-
-    Note: if you define a deep operator list, you may see performance
-    issues when using infixNotation. See
-    :class:`ParserElement.enablePackrat` for a mechanism to potentially
-    improve your parser performance.
-
-    Parameters:
-     - baseExpr - expression representing the most basic element for the
-       nested
-     - opList - list of tuples, one for each operator precedence level
-       in the expression grammar; each tuple is of the form ``(opExpr,
-       numTerms, rightLeftAssoc, parseAction)``, where:
-
-       - opExpr is the pyparsing expression for the operator; may also
-         be a string, which will be converted to a Literal; if numTerms
-         is 3, opExpr is a tuple of two expressions, for the two
-         operators separating the 3 terms
-       - numTerms is the number of terms for this operator (must be 1,
-         2, or 3)
-       - rightLeftAssoc is the indicator whether the operator is right
-         or left associative, using the pyparsing-defined constants
-         ``opAssoc.RIGHT`` and ``opAssoc.LEFT``.
-       - parseAction is the parse action to be associated with
-         expressions matching this operator expression (the parse action
-         tuple member may be omitted); if the parse action is passed
-         a tuple or list of functions, this is equivalent to calling
-         ``setParseAction(*fn)``
-         (:class:`ParserElement.setParseAction`)
-     - lpar - expression for matching left-parentheses
-       (default= ``Suppress('(')``)
-     - rpar - expression for matching right-parentheses
-       (default= ``Suppress(')')``)
-
-    Example::
-
-        # simple example of four-function arithmetic with ints and
-        # variable names
-        integer = pyparsing_common.signed_integer
-        varname = pyparsing_common.identifier
-
-        arith_expr = infixNotation(integer | varname,
-            [
-            ('-', 1, opAssoc.RIGHT),
-            (oneOf('* /'), 2, opAssoc.LEFT),
-            (oneOf('+ -'), 2, opAssoc.LEFT),
-            ])
-
-        arith_expr.runTests('''
-            5+3*6
-            (5+3)*6
-            -2--11
-            ''', fullDump=False)
-
-    prints::
-
-        5+3*6
-        [[5, '+', [3, '*', 6]]]
-
-        (5+3)*6
-        [[[5, '+', 3], '*', 6]]
-
-        -2--11
-        [[['-', 2], '-', ['-', 11]]]
-    """
-    # captive version of FollowedBy that does not do parse actions or capture results names
-    class _FB(FollowedBy):
-        def parseImpl(self, instring, loc, doActions=True):
-            self.expr.tryParse(instring, loc)
-            return loc, []
-
-    ret = Forward()
-    lastExpr = baseExpr | (lpar + ret + rpar)
-    for i, operDef in enumerate(opList):
-        opExpr, arity, rightLeftAssoc, pa = (operDef + (None, ))[:4]
-        termName = "%s term" % opExpr if arity < 3 else "%s%s term" % opExpr
-        if arity == 3:
-            if opExpr is None or len(opExpr) != 2:
-                raise ValueError(
-                    "if numterms=3, opExpr must be a tuple or list of two expressions")
-            opExpr1, opExpr2 = opExpr
-        thisExpr = Forward().setName(termName)
-        if rightLeftAssoc == opAssoc.LEFT:
-            if arity == 1:
-                matchExpr = _FB(lastExpr + opExpr) + Group(lastExpr + OneOrMore(opExpr))
-            elif arity == 2:
-                if opExpr is not None:
-                    matchExpr = _FB(lastExpr + opExpr + lastExpr) + Group(lastExpr + OneOrMore(opExpr + lastExpr))
-                else:
-                    matchExpr = _FB(lastExpr + lastExpr) + Group(lastExpr + OneOrMore(lastExpr))
-            elif arity == 3:
-                matchExpr = (_FB(lastExpr + opExpr1 + lastExpr + opExpr2 + lastExpr)
-                             + Group(lastExpr + OneOrMore(opExpr1 + lastExpr + opExpr2 + lastExpr)))
-            else:
-                raise ValueError("operator must be unary (1), binary (2), or ternary (3)")
-        elif rightLeftAssoc == opAssoc.RIGHT:
-            if arity == 1:
-                # try to avoid LR with this extra test
-                if not isinstance(opExpr, Optional):
-                    opExpr = Optional(opExpr)
-                matchExpr = _FB(opExpr.expr + thisExpr) + Group(opExpr + thisExpr)
-            elif arity == 2:
-                if opExpr is not None:
-                    matchExpr = _FB(lastExpr + opExpr + thisExpr) + Group(lastExpr + OneOrMore(opExpr + thisExpr))
-                else:
-                    matchExpr = _FB(lastExpr + thisExpr) + Group(lastExpr + OneOrMore(thisExpr))
-            elif arity == 3:
-                matchExpr = (_FB(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr)
-                             + Group(lastExpr + opExpr1 + thisExpr + opExpr2 + thisExpr))
-            else:
-                raise ValueError("operator must be unary (1), binary (2), or ternary (3)")
-        else:
-            raise ValueError("operator must indicate right or left associativity")
-        if pa:
-            if isinstance(pa, (tuple, list)):
-                matchExpr.setParseAction(*pa)
-            else:
-                matchExpr.setParseAction(pa)
-        thisExpr <<= (matchExpr.setName(termName) | lastExpr)
-        lastExpr = thisExpr
-    ret <<= lastExpr
-    return ret
-
-operatorPrecedence = infixNotation
-"""(Deprecated) Former name of :class:`infixNotation`, will be
-dropped in a future release."""
-
-dblQuotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"').setName("string enclosed in double quotes")
-sglQuotedString = Combine(Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'").setName("string enclosed in single quotes")
-quotedString = Combine(Regex(r'"(?:[^"\n\r\\]|(?:"")|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*') + '"'
-                       | Regex(r"'(?:[^'\n\r\\]|(?:'')|(?:\\(?:[^x]|x[0-9a-fA-F]+)))*") + "'").setName("quotedString using single or double quotes")
-unicodeString = Combine(_L('u') + quotedString.copy()).setName("unicode string literal")
-
-def nestedExpr(opener="(", closer=")", content=None, ignoreExpr=quotedString.copy()):
-    """Helper method for defining nested lists enclosed in opening and
-    closing delimiters ("(" and ")" are the default).
-
-    Parameters:
-     - opener - opening character for a nested list
-       (default= ``"("``); can also be a pyparsing expression
-     - closer - closing character for a nested list
-       (default= ``")"``); can also be a pyparsing expression
-     - content - expression for items within the nested lists
-       (default= ``None``)
-     - ignoreExpr - expression for ignoring opening and closing
-       delimiters (default= :class:`quotedString`)
-
-    If an expression is not provided for the content argument, the
-    nested expression will capture all whitespace-delimited content
-    between delimiters as a list of separate values.
-
-    Use the ``ignoreExpr`` argument to define expressions that may
-    contain opening or closing characters that should not be treated as
-    opening or closing characters for nesting, such as quotedString or
-    a comment expression.  Specify multiple expressions using an
-    :class:`Or` or :class:`MatchFirst`. The default is
-    :class:`quotedString`, but if no expressions are to be ignored, then
-    pass ``None`` for this argument.
-
-    Example::
-
-        data_type = oneOf("void int short long char float double")
-        decl_data_type = Combine(data_type + Optional(Word('*')))
-        ident = Word(alphas+'_', alphanums+'_')
-        number = pyparsing_common.number
-        arg = Group(decl_data_type + ident)
-        LPAR, RPAR = map(Suppress, "()")
-
-        code_body = nestedExpr('{', '}', ignoreExpr=(quotedString | cStyleComment))
-
-        c_function = (decl_data_type("type")
-                      + ident("name")
-                      + LPAR + Optional(delimitedList(arg), [])("args") + RPAR
-                      + code_body("body"))
-        c_function.ignore(cStyleComment)
-
-        source_code = '''
-            int is_odd(int x) {
-                return (x%2);
-            }
-
-            int dec_to_hex(char hchar) {
-                if (hchar >= '0' && hchar <= '9') {
-                    return (ord(hchar)-ord('0'));
-                } else {
-                    return (10+ord(hchar)-ord('A'));
-                }
-            }
-        '''
-        for func in c_function.searchString(source_code):
-            print("%(name)s (%(type)s) args: %(args)s" % func)
-
-
-    prints::
-
-        is_odd (int) args: [['int', 'x']]
-        dec_to_hex (int) args: [['char', 'hchar']]
-    """
-    if opener == closer:
-        raise ValueError("opening and closing strings cannot be the same")
-    if content is None:
-        if isinstance(opener, basestring) and isinstance(closer, basestring):
-            if len(opener) == 1 and len(closer) == 1:
-                if ignoreExpr is not None:
-                    content = (Combine(OneOrMore(~ignoreExpr
-                                                 + CharsNotIn(opener
-                                                              + closer
-                                                              + ParserElement.DEFAULT_WHITE_CHARS, exact=1)
-                                                 )
-                                       ).setParseAction(lambda t: t[0].strip()))
-                else:
-                    content = (empty.copy() + CharsNotIn(opener
-                                                         + closer
-                                                         + ParserElement.DEFAULT_WHITE_CHARS
-                                                         ).setParseAction(lambda t: t[0].strip()))
-            else:
-                if ignoreExpr is not None:
-                    content = (Combine(OneOrMore(~ignoreExpr
-                                                 + ~Literal(opener)
-                                                 + ~Literal(closer)
-                                                 + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS, exact=1))
-                                       ).setParseAction(lambda t: t[0].strip()))
-                else:
-                    content = (Combine(OneOrMore(~Literal(opener)
-                                                 + ~Literal(closer)
-                                                 + CharsNotIn(ParserElement.DEFAULT_WHITE_CHARS, exact=1))
-                                       ).setParseAction(lambda t: t[0].strip()))
-        else:
-            raise ValueError("opening and closing arguments must be strings if no content expression is given")
-    ret = Forward()
-    if ignoreExpr is not None:
-        ret <<= Group(Suppress(opener) + ZeroOrMore(ignoreExpr | ret | content) + Suppress(closer))
-    else:
-        ret <<= Group(Suppress(opener) + ZeroOrMore(ret | content)  + Suppress(closer))
-    ret.setName('nested %s%s expression' % (opener, closer))
-    return ret
-
-def indentedBlock(blockStatementExpr, indentStack, indent=True):
-    """Helper method for defining space-delimited indentation blocks,
-    such as those used to define block statements in Python source code.
-
-    Parameters:
-
-     - blockStatementExpr - expression defining syntax of statement that
-       is repeated within the indented block
-     - indentStack - list created by caller to manage indentation stack
-       (multiple statementWithIndentedBlock expressions within a single
-       grammar should share a common indentStack)
-     - indent - boolean indicating whether block must be indented beyond
-       the current level; set to False for block of left-most
-       statements (default= ``True``)
-
-    A valid block must contain at least one ``blockStatement``.
-
-    Example::
-
-        data = '''
-        def A(z):
-          A1
-          B = 100
-          G = A2
-          A2
-          A3
-        B
-        def BB(a,b,c):
-          BB1
-          def BBA():
-            bba1
-            bba2
-            bba3
-        C
-        D
-        def spam(x,y):
-             def eggs(z):
-                 pass
-        '''
-
-
-        indentStack = [1]
-        stmt = Forward()
-
-        identifier = Word(alphas, alphanums)
-        funcDecl = ("def" + identifier + Group("(" + Optional(delimitedList(identifier)) + ")") + ":")
-        func_body = indentedBlock(stmt, indentStack)
-        funcDef = Group(funcDecl + func_body)
-
-        rvalue = Forward()
-        funcCall = Group(identifier + "(" + Optional(delimitedList(rvalue)) + ")")
-        rvalue << (funcCall | identifier | Word(nums))
-        assignment = Group(identifier + "=" + rvalue)
-        stmt << (funcDef | assignment | identifier)
-
-        module_body = OneOrMore(stmt)
-
-        parseTree = module_body.parseString(data)
-        parseTree.pprint()
-
-    prints::
-
-        [['def',
-          'A',
-          ['(', 'z', ')'],
-          ':',
-          [['A1'], [['B', '=', '100']], [['G', '=', 'A2']], ['A2'], ['A3']]],
-         'B',
-         ['def',
-          'BB',
-          ['(', 'a', 'b', 'c', ')'],
-          ':',
-          [['BB1'], [['def', 'BBA', ['(', ')'], ':', [['bba1'], ['bba2'], ['bba3']]]]]],
-         'C',
-         'D',
-         ['def',
-          'spam',
-          ['(', 'x', 'y', ')'],
-          ':',
-          [[['def', 'eggs', ['(', 'z', ')'], ':', [['pass']]]]]]]
-    """
-    backup_stack = indentStack[:]
-
-    def reset_stack():
-        indentStack[:] = backup_stack
-
-    def checkPeerIndent(s, l, t):
-        if l >= len(s): return
-        curCol = col(l, s)
-        if curCol != indentStack[-1]:
-            if curCol > indentStack[-1]:
-                raise ParseException(s, l, "illegal nesting")
-            raise ParseException(s, l, "not a peer entry")
-
-    def checkSubIndent(s, l, t):
-        curCol = col(l, s)
-        if curCol > indentStack[-1]:
-            indentStack.append(curCol)
-        else:
-            raise ParseException(s, l, "not a subentry")
-
-    def checkUnindent(s, l, t):
-        if l >= len(s): return
-        curCol = col(l, s)
-        if not(indentStack and curCol in indentStack):
-            raise ParseException(s, l, "not an unindent")
-        if curCol < indentStack[-1]:
-            indentStack.pop()
-
-    NL = OneOrMore(LineEnd().setWhitespaceChars("\t ").suppress(), stopOn=StringEnd())
-    INDENT = (Empty() + Empty().setParseAction(checkSubIndent)).setName('INDENT')
-    PEER   = Empty().setParseAction(checkPeerIndent).setName('')
-    UNDENT = Empty().setParseAction(checkUnindent).setName('UNINDENT')
-    if indent:
-        smExpr = Group(Optional(NL)
-                       + INDENT
-                       + OneOrMore(PEER + Group(blockStatementExpr) + Optional(NL), stopOn=StringEnd())
-                       + UNDENT)
-    else:
-        smExpr = Group(Optional(NL)
-                       + OneOrMore(PEER + Group(blockStatementExpr) + Optional(NL), stopOn=StringEnd())
-                       + UNDENT)
-    smExpr.setFailAction(lambda a, b, c, d: reset_stack())
-    blockStatementExpr.ignore(_bslash + LineEnd())
-    return smExpr.setName('indented block')
-
-alphas8bit = srange(r"[\0xc0-\0xd6\0xd8-\0xf6\0xf8-\0xff]")
-punc8bit = srange(r"[\0xa1-\0xbf\0xd7\0xf7]")
-
-anyOpenTag, anyCloseTag = makeHTMLTags(Word(alphas, alphanums + "_:").setName('any tag'))
-_htmlEntityMap = dict(zip("gt lt amp nbsp quot apos".split(), '><& "\''))
-commonHTMLEntity = Regex('&(?P<entity>' + '|'.join(_htmlEntityMap.keys()) +");").setName("common HTML entity")
-def replaceHTMLEntity(t):
-    """Helper parser action to replace common HTML entities with their special characters"""
-    return _htmlEntityMap.get(t.entity)
-
-# it's easy to get these comment structures wrong - they're very common, so may as well make them available
-cStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/').setName("C style comment")
-"Comment of the form ``/* ... */``"
-
-htmlComment = Regex(r"<!--[\s\S]*?-->").setName("HTML comment")
-"Comment of the form ``<!-- ... -->``"
-
-restOfLine = Regex(r".*").leaveWhitespace().setName("rest of line")
-dblSlashComment = Regex(r"//(?:\\\n|[^\n])*").setName("// comment")
-"Comment of the form ``// ... (to end of line)``"
-
-cppStyleComment = Combine(Regex(r"/\*(?:[^*]|\*(?!/))*") + '*/' | dblSlashComment).setName("C++ style comment")
-"Comment of either form :class:`cStyleComment` or :class:`dblSlashComment`"
-
-javaStyleComment = cppStyleComment
-"Same as :class:`cppStyleComment`"
-
-pythonStyleComment = Regex(r"#.*").setName("Python style comment")
-"Comment of the form ``# ... (to end of line)``"
-
-_commasepitem = Combine(OneOrMore(Word(printables, excludeChars=',')
-                                  + Optional(Word(" \t")
-                                             + ~Literal(",") + ~LineEnd()))).streamline().setName("commaItem")
-commaSeparatedList = delimitedList(Optional(quotedString.copy() | _commasepitem, default="")).setName("commaSeparatedList")
-"""(Deprecated) Predefined expression of 1 or more printable words or
-quoted strings, separated by commas.
-
-This expression is deprecated in favor of :class:`pyparsing_common.comma_separated_list`.
-"""
-
-# some other useful expressions - using lower-case class name since we are really using this as a namespace
-class pyparsing_common:
-    """Here are some common low-level expressions that may be useful in
-    jump-starting parser development:
-
-     - numeric forms (:class:`integers<integer>`, :class:`reals<real>`,
-       :class:`scientific notation<sci_real>`)
-     - common :class:`programming identifiers<identifier>`
-     - network addresses (:class:`MAC<mac_address>`,
-       :class:`IPv4<ipv4_address>`, :class:`IPv6<ipv6_address>`)
-     - ISO8601 :class:`dates<iso8601_date>` and
-       :class:`datetime<iso8601_datetime>`
-     - :class:`UUID<uuid>`
-     - :class:`comma-separated list<comma_separated_list>`
-
-    Parse actions:
-
-     - :class:`convertToInteger`
-     - :class:`convertToFloat`
-     - :class:`convertToDate`
-     - :class:`convertToDatetime`
-     - :class:`stripHTMLTags`
-     - :class:`upcaseTokens`
-     - :class:`downcaseTokens`
-
-    Example::
-
-        pyparsing_common.number.runTests('''
-            # any int or real number, returned as the appropriate type
-            100
-            -100
-            +100
-            3.14159
-            6.02e23
-            1e-12
-            ''')
-
-        pyparsing_common.fnumber.runTests('''
-            # any int or real number, returned as float
-            100
-            -100
-            +100
-            3.14159
-            6.02e23
-            1e-12
-            ''')
-
-        pyparsing_common.hex_integer.runTests('''
-            # hex numbers
-            100
-            FF
-            ''')
-
-        pyparsing_common.fraction.runTests('''
-            # fractions
-            1/2
-            -3/4
-            ''')
-
-        pyparsing_common.mixed_integer.runTests('''
-            # mixed fractions
-            1
-            1/2
-            -3/4
-            1-3/4
-            ''')
-
-        import uuid
-        pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID))
-        pyparsing_common.uuid.runTests('''
-            # uuid
-            12345678-1234-5678-1234-567812345678
-            ''')
-
-    prints::
-
-        # any int or real number, returned as the appropriate type
-        100
-        [100]
-
-        -100
-        [-100]
-
-        +100
-        [100]
-
-        3.14159
-        [3.14159]
-
-        6.02e23
-        [6.02e+23]
-
-        1e-12
-        [1e-12]
-
-        # any int or real number, returned as float
-        100
-        [100.0]
-
-        -100
-        [-100.0]
-
-        +100
-        [100.0]
-
-        3.14159
-        [3.14159]
-
-        6.02e23
-        [6.02e+23]
-
-        1e-12
-        [1e-12]
-
-        # hex numbers
-        100
-        [256]
-
-        FF
-        [255]
-
-        # fractions
-        1/2
-        [0.5]
-
-        -3/4
-        [-0.75]
-
-        # mixed fractions
-        1
-        [1]
-
-        1/2
-        [0.5]
-
-        -3/4
-        [-0.75]
-
-        1-3/4
-        [1.75]
-
-        # uuid
-        12345678-1234-5678-1234-567812345678
-        [UUID('12345678-1234-5678-1234-567812345678')]
-    """
-
-    convertToInteger = tokenMap(int)
-    """
-    Parse action for converting parsed integers to Python int
-    """
-
-    convertToFloat = tokenMap(float)
-    """
-    Parse action for converting parsed numbers to Python float
-    """
-
-    integer = Word(nums).setName("integer").setParseAction(convertToInteger)
-    """expression that parses an unsigned integer, returns an int"""
-
-    hex_integer = Word(hexnums).setName("hex integer").setParseAction(tokenMap(int, 16))
-    """expression that parses a hexadecimal integer, returns an int"""
-
-    signed_integer = Regex(r'[+-]?\d+').setName("signed integer").setParseAction(convertToInteger)
-    """expression that parses an integer with optional leading sign, returns an int"""
-
-    fraction = (signed_integer().setParseAction(convertToFloat) + '/' + signed_integer().setParseAction(convertToFloat)).setName("fraction")
-    """fractional expression of an integer divided by an integer, returns a float"""
-    fraction.addParseAction(lambda t: t[0]/t[-1])
-
-    mixed_integer = (fraction | signed_integer + Optional(Optional('-').suppress() + fraction)).setName("fraction or mixed integer-fraction")
-    """mixed integer of the form 'integer - fraction', with optional leading integer, returns float"""
-    mixed_integer.addParseAction(sum)
-
-    real = Regex(r'[+-]?(?:\d+\.\d*|\.\d+)').setName("real number").setParseAction(convertToFloat)
-    """expression that parses a floating point number and returns a float"""
-
-    sci_real = Regex(r'[+-]?(?:\d+(?:[eE][+-]?\d+)|(?:\d+\.\d*|\.\d+)(?:[eE][+-]?\d+)?)').setName("real number with scientific notation").setParseAction(convertToFloat)
-    """expression that parses a floating point number with optional
-    scientific notation and returns a float"""
-
-    # streamlining this expression makes the docs nicer-looking
-    number = (sci_real | real | signed_integer).streamline()
-    """any numeric expression, returns the corresponding Python type"""
-
-    fnumber = Regex(r'[+-]?\d+\.?\d*([eE][+-]?\d+)?').setName("fnumber").setParseAction(convertToFloat)
-    """any int or real number, returned as float"""
-
-    identifier = Word(alphas + '_', alphanums + '_').setName("identifier")
-    """typical code identifier (leading alpha or '_', followed by 0 or more alphas, nums, or '_')"""
-
-    ipv4_address = Regex(r'(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})(\.(25[0-5]|2[0-4][0-9]|1?[0-9]{1,2})){3}').setName("IPv4 address")
-    "IPv4 address (``0.0.0.0 - 255.255.255.255``)"
-
-    _ipv6_part = Regex(r'[0-9a-fA-F]{1,4}').setName("hex_integer")
-    _full_ipv6_address = (_ipv6_part + (':' + _ipv6_part) * 7).setName("full IPv6 address")
-    _short_ipv6_address = (Optional(_ipv6_part + (':' + _ipv6_part) * (0, 6))
-                           + "::"
-                           + Optional(_ipv6_part + (':' + _ipv6_part) * (0, 6))
-                           ).setName("short IPv6 address")
-    _short_ipv6_address.addCondition(lambda t: sum(1 for tt in t if pyparsing_common._ipv6_part.matches(tt)) < 8)
-    _mixed_ipv6_address = ("::ffff:" + ipv4_address).setName("mixed IPv6 address")
-    ipv6_address = Combine((_full_ipv6_address | _mixed_ipv6_address | _short_ipv6_address).setName("IPv6 address")).setName("IPv6 address")
-    "IPv6 address (long, short, or mixed form)"
-
-    mac_address = Regex(r'[0-9a-fA-F]{2}([:.-])[0-9a-fA-F]{2}(?:\1[0-9a-fA-F]{2}){4}').setName("MAC address")
-    "MAC address xx:xx:xx:xx:xx (may also have '-' or '.' delimiters)"
-
-    @staticmethod
-    def convertToDate(fmt="%Y-%m-%d"):
-        """
-        Helper to create a parse action for converting parsed date string to Python datetime.date
-
-        Params -
-         - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%d"``)
-
-        Example::
-
-            date_expr = pyparsing_common.iso8601_date.copy()
-            date_expr.setParseAction(pyparsing_common.convertToDate())
-            print(date_expr.parseString("1999-12-31"))
-
-        prints::
-
-            [datetime.date(1999, 12, 31)]
-        """
-        def cvt_fn(s, l, t):
-            try:
-                return datetime.strptime(t[0], fmt).date()
-            except ValueError as ve:
-                raise ParseException(s, l, str(ve))
-        return cvt_fn
-
-    @staticmethod
-    def convertToDatetime(fmt="%Y-%m-%dT%H:%M:%S.%f"):
-        """Helper to create a parse action for converting parsed
-        datetime string to Python datetime.datetime
-
-        Params -
-         - fmt - format to be passed to datetime.strptime (default= ``"%Y-%m-%dT%H:%M:%S.%f"``)
-
-        Example::
-
-            dt_expr = pyparsing_common.iso8601_datetime.copy()
-            dt_expr.setParseAction(pyparsing_common.convertToDatetime())
-            print(dt_expr.parseString("1999-12-31T23:59:59.999"))
-
-        prints::
-
-            [datetime.datetime(1999, 12, 31, 23, 59, 59, 999000)]
-        """
-        def cvt_fn(s, l, t):
-            try:
-                return datetime.strptime(t[0], fmt)
-            except ValueError as ve:
-                raise ParseException(s, l, str(ve))
-        return cvt_fn
-
-    iso8601_date = Regex(r'(?P<year>\d{4})(?:-(?P<month>\d\d)(?:-(?P<day>\d\d))?)?').setName("ISO8601 date")
-    "ISO8601 date (``yyyy-mm-dd``)"
-
-    iso8601_datetime = Regex(r'(?P<year>\d{4})-(?P<month>\d\d)-(?P<day>\d\d)[T ](?P<hour>\d\d):(?P<minute>\d\d)(:(?P<second>\d\d(\.\d*)?)?)?(?P<tz>Z|[+-]\d\d:?\d\d)?').setName("ISO8601 datetime")
-    "ISO8601 datetime (``yyyy-mm-ddThh:mm:ss.s(Z|+-00:00)``) - trailing seconds, milliseconds, and timezone optional; accepts separating ``'T'`` or ``' '``"
-
-    uuid = Regex(r'[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}').setName("UUID")
-    "UUID (``xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx``)"
-
-    _html_stripper = anyOpenTag.suppress() | anyCloseTag.suppress()
-    @staticmethod
-    def stripHTMLTags(s, l, tokens):
-        """Parse action to remove HTML tags from web page HTML source
-
-        Example::
-
-            # strip HTML links from normal text
-            text = '<td>More info at the <a href="https://github.com/pyparsing/pyparsing/wiki">pyparsing</a> wiki page</td>'
-            td, td_end = makeHTMLTags("TD")
-            table_text = td + SkipTo(td_end).setParseAction(pyparsing_common.stripHTMLTags)("body") + td_end
-            print(table_text.parseString(text).body)
-
-        Prints::
-
-            More info at the pyparsing wiki page
-        """
-        return pyparsing_common._html_stripper.transformString(tokens[0])
-
-    _commasepitem = Combine(OneOrMore(~Literal(",")
-                                      + ~LineEnd()
-                                      + Word(printables, excludeChars=',')
-                                      + Optional(White(" \t")))).streamline().setName("commaItem")
-    comma_separated_list = delimitedList(Optional(quotedString.copy()
-                                                  | _commasepitem, default='')
-                                         ).setName("comma separated list")
-    """Predefined expression of 1 or more printable words or quoted strings, separated by commas."""
-
-    upcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).upper()))
-    """Parse action to convert tokens to upper case."""
-
-    downcaseTokens = staticmethod(tokenMap(lambda t: _ustr(t).lower()))
-    """Parse action to convert tokens to lower case."""
-
-
-class _lazyclassproperty(object):
-    def __init__(self, fn):
-        self.fn = fn
-        self.__doc__ = fn.__doc__
-        self.__name__ = fn.__name__
-
-    def __get__(self, obj, cls):
-        if cls is None:
-            cls = type(obj)
-        if not hasattr(cls, '_intern') or any(cls._intern is getattr(superclass, '_intern', [])
-                                              for superclass in cls.__mro__[1:]):
-            cls._intern = {}
-        attrname = self.fn.__name__
-        if attrname not in cls._intern:
-            cls._intern[attrname] = self.fn(cls)
-        return cls._intern[attrname]
-
-
-class unicode_set(object):
-    """
-    A set of Unicode characters, for language-specific strings for
-    ``alphas``, ``nums``, ``alphanums``, and ``printables``.
-    A unicode_set is defined by a list of ranges in the Unicode character
-    set, in a class attribute ``_ranges``, such as::
-
-        _ranges = [(0x0020, 0x007e), (0x00a0, 0x00ff),]
-
-    A unicode set can also be defined using multiple inheritance of other unicode sets::
-
-        class CJK(Chinese, Japanese, Korean):
-            pass
-    """
-    _ranges = []
-
-    @classmethod
-    def _get_chars_for_ranges(cls):
-        ret = []
-        for cc in cls.__mro__:
-            if cc is unicode_set:
-                break
-            for rr in cc._ranges:
-                ret.extend(range(rr[0], rr[-1] + 1))
-        return [unichr(c) for c in sorted(set(ret))]
-
-    @_lazyclassproperty
-    def printables(cls):
-        "all non-whitespace characters in this range"
-        return u''.join(filterfalse(unicode.isspace, cls._get_chars_for_ranges()))
-
-    @_lazyclassproperty
-    def alphas(cls):
-        "all alphabetic characters in this range"
-        return u''.join(filter(unicode.isalpha, cls._get_chars_for_ranges()))
-
-    @_lazyclassproperty
-    def nums(cls):
-        "all numeric digit characters in this range"
-        return u''.join(filter(unicode.isdigit, cls._get_chars_for_ranges()))
-
-    @_lazyclassproperty
-    def alphanums(cls):
-        "all alphanumeric characters in this range"
-        return cls.alphas + cls.nums
-
-
-class pyparsing_unicode(unicode_set):
-    """
-    A namespace class for defining common language unicode_sets.
-    """
-    _ranges = [(32, sys.maxunicode)]
-
-    class Latin1(unicode_set):
-        "Unicode set for Latin-1 Unicode Character Range"
-        _ranges = [(0x0020, 0x007e), (0x00a0, 0x00ff),]
-
-    class LatinA(unicode_set):
-        "Unicode set for Latin-A Unicode Character Range"
-        _ranges = [(0x0100, 0x017f),]
-
-    class LatinB(unicode_set):
-        "Unicode set for Latin-B Unicode Character Range"
-        _ranges = [(0x0180, 0x024f),]
-
-    class Greek(unicode_set):
-        "Unicode set for Greek Unicode Character Ranges"
-        _ranges = [
-            (0x0370, 0x03ff), (0x1f00, 0x1f15), (0x1f18, 0x1f1d), (0x1f20, 0x1f45), (0x1f48, 0x1f4d),
-            (0x1f50, 0x1f57), (0x1f59,), (0x1f5b,), (0x1f5d,), (0x1f5f, 0x1f7d), (0x1f80, 0x1fb4), (0x1fb6, 0x1fc4),
-            (0x1fc6, 0x1fd3), (0x1fd6, 0x1fdb), (0x1fdd, 0x1fef), (0x1ff2, 0x1ff4), (0x1ff6, 0x1ffe),
-        ]
-
-    class Cyrillic(unicode_set):
-        "Unicode set for Cyrillic Unicode Character Range"
-        _ranges = [(0x0400, 0x04ff)]
-
-    class Chinese(unicode_set):
-        "Unicode set for Chinese Unicode Character Range"
-        _ranges = [(0x4e00, 0x9fff), (0x3000, 0x303f),]
-
-    class Japanese(unicode_set):
-        "Unicode set for Japanese Unicode Character Range, combining Kanji, Hiragana, and Katakana ranges"
-        _ranges = []
-
-        class Kanji(unicode_set):
-            "Unicode set for Kanji Unicode Character Range"
-            _ranges = [(0x4E00, 0x9Fbf), (0x3000, 0x303f),]
-
-        class Hiragana(unicode_set):
-            "Unicode set for Hiragana Unicode Character Range"
-            _ranges = [(0x3040, 0x309f),]
-
-        class Katakana(unicode_set):
-            "Unicode set for Katakana  Unicode Character Range"
-            _ranges = [(0x30a0, 0x30ff),]
-
-    class Korean(unicode_set):
-        "Unicode set for Korean Unicode Character Range"
-        _ranges = [(0xac00, 0xd7af), (0x1100, 0x11ff), (0x3130, 0x318f), (0xa960, 0xa97f), (0xd7b0, 0xd7ff), (0x3000, 0x303f),]
-
-    class CJK(Chinese, Japanese, Korean):
-        "Unicode set for combined Chinese, Japanese, and Korean (CJK) Unicode Character Range"
-        pass
-
-    class Thai(unicode_set):
-        "Unicode set for Thai Unicode Character Range"
-        _ranges = [(0x0e01, 0x0e3a), (0x0e3f, 0x0e5b),]
-
-    class Arabic(unicode_set):
-        "Unicode set for Arabic Unicode Character Range"
-        _ranges = [(0x0600, 0x061b), (0x061e, 0x06ff), (0x0700, 0x077f),]
-
-    class Hebrew(unicode_set):
-        "Unicode set for Hebrew Unicode Character Range"
-        _ranges = [(0x0590, 0x05ff),]
-
-    class Devanagari(unicode_set):
-        "Unicode set for Devanagari Unicode Character Range"
-        _ranges = [(0x0900, 0x097f), (0xa8e0, 0xa8ff)]
-
-pyparsing_unicode.Japanese._ranges = (pyparsing_unicode.Japanese.Kanji._ranges
-                                      + pyparsing_unicode.Japanese.Hiragana._ranges
-                                      + pyparsing_unicode.Japanese.Katakana._ranges)
-
-# define ranges in language character sets
-if PY_3:
-    setattr(pyparsing_unicode, u"العربية", pyparsing_unicode.Arabic)
-    setattr(pyparsing_unicode, u"中文", pyparsing_unicode.Chinese)
-    setattr(pyparsing_unicode, u"кириллица", pyparsing_unicode.Cyrillic)
-    setattr(pyparsing_unicode, u"Ελληνικά", pyparsing_unicode.Greek)
-    setattr(pyparsing_unicode, u"עִברִית", pyparsing_unicode.Hebrew)
-    setattr(pyparsing_unicode, u"日本語", pyparsing_unicode.Japanese)
-    setattr(pyparsing_unicode.Japanese, u"漢字", pyparsing_unicode.Japanese.Kanji)
-    setattr(pyparsing_unicode.Japanese, u"カタカナ", pyparsing_unicode.Japanese.Katakana)
-    setattr(pyparsing_unicode.Japanese, u"ひらがな", pyparsing_unicode.Japanese.Hiragana)
-    setattr(pyparsing_unicode, u"한국어", pyparsing_unicode.Korean)
-    setattr(pyparsing_unicode, u"ไทย", pyparsing_unicode.Thai)
-    setattr(pyparsing_unicode, u"देवनागरी", pyparsing_unicode.Devanagari)
-
-
-class pyparsing_test:
-    """
-    namespace class for classes useful in writing unit tests
-    """
-
-    class reset_pyparsing_context:
-        """
-        Context manager to be used when writing unit tests that modify pyparsing config values:
-         - packrat parsing
-         - default whitespace characters.
-         - default keyword characters
-         - literal string auto-conversion class
-         - __diag__ settings
-
-        Example:
-            with reset_pyparsing_context():
-                # test that literals used to construct a grammar are automatically suppressed
-                ParserElement.inlineLiteralsUsing(Suppress)
-
-                term = Word(alphas) | Word(nums)
-                group = Group('(' + term[...] + ')')
-
-                # assert that the '()' characters are not included in the parsed tokens
-                self.assertParseAndCheckLisst(group, "(abc 123 def)", ['abc', '123', 'def'])
-
-            # after exiting context manager, literals are converted to Literal expressions again
-        """
-
-        def __init__(self):
-            self._save_context = {}
-
-        def save(self):
-            self._save_context["default_whitespace"] = ParserElement.DEFAULT_WHITE_CHARS
-            self._save_context["default_keyword_chars"] = Keyword.DEFAULT_KEYWORD_CHARS
-            self._save_context[
-                "literal_string_class"
-            ] = ParserElement._literalStringClass
-            self._save_context["packrat_enabled"] = ParserElement._packratEnabled
-            self._save_context["packrat_parse"] = ParserElement._parse
-            self._save_context["__diag__"] = {
-                name: getattr(__diag__, name) for name in __diag__._all_names
-            }
-            self._save_context["__compat__"] = {
-                "collect_all_And_tokens": __compat__.collect_all_And_tokens
-            }
-            return self
-
-        def restore(self):
-            # reset pyparsing global state
-            if (
-                ParserElement.DEFAULT_WHITE_CHARS
-                != self._save_context["default_whitespace"]
-            ):
-                ParserElement.setDefaultWhitespaceChars(
-                    self._save_context["default_whitespace"]
-                )
-            Keyword.DEFAULT_KEYWORD_CHARS = self._save_context["default_keyword_chars"]
-            ParserElement.inlineLiteralsUsing(
-                self._save_context["literal_string_class"]
-            )
-            for name, value in self._save_context["__diag__"].items():
-                setattr(__diag__, name, value)
-            ParserElement._packratEnabled = self._save_context["packrat_enabled"]
-            ParserElement._parse = self._save_context["packrat_parse"]
-            __compat__.collect_all_And_tokens = self._save_context["__compat__"]
-
-        def __enter__(self):
-            return self.save()
-
-        def __exit__(self, *args):
-            return self.restore()
-
-    class TestParseResultsAsserts:
-        """
-        A mixin class to add parse results assertion methods to normal unittest.TestCase classes.
-        """
-        def assertParseResultsEquals(
-            self, result, expected_list=None, expected_dict=None, msg=None
-        ):
-            """
-            Unit test assertion to compare a ParseResults object with an optional expected_list,
-            and compare any defined results names with an optional expected_dict.
-            """
-            if expected_list is not None:
-                self.assertEqual(expected_list, result.asList(), msg=msg)
-            if expected_dict is not None:
-                self.assertEqual(expected_dict, result.asDict(), msg=msg)
-
-        def assertParseAndCheckList(
-            self, expr, test_string, expected_list, msg=None, verbose=True
-        ):
-            """
-            Convenience wrapper assert to test a parser element and input string, and assert that
-            the resulting ParseResults.asList() is equal to the expected_list.
-            """
-            result = expr.parseString(test_string, parseAll=True)
-            if verbose:
-                print(result.dump())
-            self.assertParseResultsEquals(result, expected_list=expected_list, msg=msg)
-
-        def assertParseAndCheckDict(
-            self, expr, test_string, expected_dict, msg=None, verbose=True
-        ):
-            """
-            Convenience wrapper assert to test a parser element and input string, and assert that
-            the resulting ParseResults.asDict() is equal to the expected_dict.
-            """
-            result = expr.parseString(test_string, parseAll=True)
-            if verbose:
-                print(result.dump())
-            self.assertParseResultsEquals(result, expected_dict=expected_dict, msg=msg)
-
-        def assertRunTestResults(
-            self, run_tests_report, expected_parse_results=None, msg=None
-        ):
-            """
-            Unit test assertion to evaluate output of ParserElement.runTests(). If a list of
-            list-dict tuples is given as the expected_parse_results argument, then these are zipped
-            with the report tuples returned by runTests and evaluated using assertParseResultsEquals.
-            Finally, asserts that the overall runTests() success value is True.
-
-            :param run_tests_report: tuple(bool, [tuple(str, ParseResults or Exception)]) returned from runTests
-            :param expected_parse_results (optional): [tuple(str, list, dict, Exception)]
-            """
-            run_test_success, run_test_results = run_tests_report
-
-            if expected_parse_results is not None:
-                merged = [
-                    (rpt[0], rpt[1], expected)
-                    for rpt, expected in zip(run_test_results, expected_parse_results)
-                ]
-                for test_string, result, expected in merged:
-                    # expected should be a tuple containing a list and/or a dict or an exception,
-                    # and optional failure message string
-                    # an empty tuple will skip any result validation
-                    fail_msg = next(
-                        (exp for exp in expected if isinstance(exp, str)), None
-                    )
-                    expected_exception = next(
-                        (
-                            exp
-                            for exp in expected
-                            if isinstance(exp, type) and issubclass(exp, Exception)
-                        ),
-                        None,
-                    )
-                    if expected_exception is not None:
-                        with self.assertRaises(
-                            expected_exception=expected_exception, msg=fail_msg or msg
-                        ):
-                            if isinstance(result, Exception):
-                                raise result
-                    else:
-                        expected_list = next(
-                            (exp for exp in expected if isinstance(exp, list)), None
-                        )
-                        expected_dict = next(
-                            (exp for exp in expected if isinstance(exp, dict)), None
-                        )
-                        if (expected_list, expected_dict) != (None, None):
-                            self.assertParseResultsEquals(
-                                result,
-                                expected_list=expected_list,
-                                expected_dict=expected_dict,
-                                msg=fail_msg or msg,
-                            )
-                        else:
-                            # warning here maybe?
-                            print("no validation for {!r}".format(test_string))
-
-            # do this last, in case some specific test results can be reported instead
-            self.assertTrue(
-                run_test_success, msg=msg if msg is not None else "failed runTests"
-            )
-
-        @contextmanager
-        def assertRaisesParseException(self, exc_type=ParseException, msg=None):
-            with self.assertRaises(exc_type, msg=msg):
-                yield
-
-
-if __name__ == "__main__":
-
-    selectToken    = CaselessLiteral("select")
-    fromToken      = CaselessLiteral("from")
-
-    ident          = Word(alphas, alphanums + "_$")
-
-    columnName     = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens)
-    columnNameList = Group(delimitedList(columnName)).setName("columns")
-    columnSpec     = ('*' | columnNameList)
-
-    tableName      = delimitedList(ident, ".", combine=True).setParseAction(upcaseTokens)
-    tableNameList  = Group(delimitedList(tableName)).setName("tables")
-
-    simpleSQL      = selectToken("command") + columnSpec("columns") + fromToken + tableNameList("tables")
-
-    # demo runTests method, including embedded comments in test string
-    simpleSQL.runTests("""
-        # '*' as column list and dotted table name
-        select * from SYS.XYZZY
-
-        # caseless match on "SELECT", and casts back to "select"
-        SELECT * from XYZZY, ABC
-
-        # list of column names, and mixed case SELECT keyword
-        Select AA,BB,CC from Sys.dual
-
-        # multiple tables
-        Select A, B, C from Sys.dual, Table2
-
-        # invalid SELECT keyword - should fail
-        Xelect A, B, C from Sys.dual
-
-        # incomplete command - should fail
-        Select
-
-        # invalid column name - should fail
-        Select ^^^ frox Sys.dual
-
-        """)
-
-    pyparsing_common.number.runTests("""
-        100
-        -100
-        +100
-        3.14159
-        6.02e23
-        1e-12
-        """)
-
-    # any int or real number, returned as float
-    pyparsing_common.fnumber.runTests("""
-        100
-        -100
-        +100
-        3.14159
-        6.02e23
-        1e-12
-        """)
-
-    pyparsing_common.hex_integer.runTests("""
-        100
-        FF
-        """)
-
-    import uuid
-    pyparsing_common.uuid.setParseAction(tokenMap(uuid.UUID))
-    pyparsing_common.uuid.runTests("""
-        12345678-1234-5678-1234-567812345678
-        """)
diff --git a/env/Lib/site-packages/pip/_vendor/requests/__init__.py b/env/Lib/site-packages/pip/_vendor/requests/__init__.py
index 18046c45..10ff67ff 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/__init__.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 #   __
 #  /__)  _  _     _   _ _/   _
 # / (   (- (/ (/ (- _)  /  _)
@@ -40,53 +38,78 @@ is at <https://requests.readthedocs.io>.
 :license: Apache 2.0, see LICENSE for more details.
 """
 
-from pip._vendor import urllib3
-from pip._vendor import chardet
 import warnings
+
+from pip._vendor import urllib3
+
 from .exceptions import RequestsDependencyWarning
 
+charset_normalizer_version = None
+
+try:
+    from pip._vendor.chardet import __version__ as chardet_version
+except ImportError:
+    chardet_version = None
+
 
-def check_compatibility(urllib3_version, chardet_version):
-    urllib3_version = urllib3_version.split('.')
-    assert urllib3_version != ['dev']  # Verify urllib3 isn't installed from git.
+def check_compatibility(urllib3_version, chardet_version, charset_normalizer_version):
+    urllib3_version = urllib3_version.split(".")
+    assert urllib3_version != ["dev"]  # Verify urllib3 isn't installed from git.
 
     # Sometimes, urllib3 only reports its version as 16.1.
     if len(urllib3_version) == 2:
-        urllib3_version.append('0')
+        urllib3_version.append("0")
 
     # Check urllib3 for compatibility.
     major, minor, patch = urllib3_version  # noqa: F811
     major, minor, patch = int(major), int(minor), int(patch)
-    # urllib3 >= 1.21.1, <= 1.26
-    assert major == 1
-    assert minor >= 21
-    assert minor <= 26
-
-    # Check chardet for compatibility.
-    major, minor, patch = chardet_version.split('.')[:3]
-    major, minor, patch = int(major), int(minor), int(patch)
-    # chardet >= 3.0.2, < 5.0.0
-    assert (3, 0, 2) <= (major, minor, patch) < (5, 0, 0)
+    # urllib3 >= 1.21.1
+    assert major >= 1
+    if major == 1:
+        assert minor >= 21
+
+    # Check charset_normalizer for compatibility.
+    if chardet_version:
+        major, minor, patch = chardet_version.split(".")[:3]
+        major, minor, patch = int(major), int(minor), int(patch)
+        # chardet_version >= 3.0.2, < 6.0.0
+        assert (3, 0, 2) <= (major, minor, patch) < (6, 0, 0)
+    elif charset_normalizer_version:
+        major, minor, patch = charset_normalizer_version.split(".")[:3]
+        major, minor, patch = int(major), int(minor), int(patch)
+        # charset_normalizer >= 2.0.0 < 4.0.0
+        assert (2, 0, 0) <= (major, minor, patch) < (4, 0, 0)
+    else:
+        raise Exception("You need either charset_normalizer or chardet installed")
 
 
 def _check_cryptography(cryptography_version):
     # cryptography < 1.3.4
     try:
-        cryptography_version = list(map(int, cryptography_version.split('.')))
+        cryptography_version = list(map(int, cryptography_version.split(".")))
     except ValueError:
         return
 
     if cryptography_version < [1, 3, 4]:
-        warning = 'Old version of cryptography ({}) may cause slowdown.'.format(cryptography_version)
+        warning = "Old version of cryptography ({}) may cause slowdown.".format(
+            cryptography_version
+        )
         warnings.warn(warning, RequestsDependencyWarning)
 
+
 # Check imported dependencies for compatibility.
 try:
-    check_compatibility(urllib3.__version__, chardet.__version__)
+    check_compatibility(
+        urllib3.__version__, chardet_version, charset_normalizer_version
+    )
 except (AssertionError, ValueError):
-    warnings.warn("urllib3 ({}) or chardet ({}) doesn't match a supported "
-                  "version!".format(urllib3.__version__, chardet.__version__),
-                  RequestsDependencyWarning)
+    warnings.warn(
+        "urllib3 ({}) or chardet ({})/charset_normalizer ({}) doesn't match a supported "
+        "version!".format(
+            urllib3.__version__, chardet_version, charset_normalizer_version
+        ),
+        RequestsDependencyWarning,
+    )
 
 # Attempt to enable urllib3's fallback for SNI support
 # if the standard library doesn't support SNI or the
@@ -104,39 +127,56 @@ try:
 
     if not getattr(ssl, "HAS_SNI", False):
         from pip._vendor.urllib3.contrib import pyopenssl
+
         pyopenssl.inject_into_urllib3()
 
         # Check cryptography version
         from cryptography import __version__ as cryptography_version
+
         _check_cryptography(cryptography_version)
 except ImportError:
     pass
 
 # urllib3's DependencyWarnings should be silenced.
 from pip._vendor.urllib3.exceptions import DependencyWarning
-warnings.simplefilter('ignore', DependencyWarning)
-
-from .__version__ import __title__, __description__, __url__, __version__
-from .__version__ import __build__, __author__, __author_email__, __license__
-from .__version__ import __copyright__, __cake__
 
-from . import utils
-from . import packages
-from .models import Request, Response, PreparedRequest
-from .api import request, get, head, post, patch, put, delete, options
-from .sessions import session, Session
-from .status_codes import codes
-from .exceptions import (
-    RequestException, Timeout, URLRequired,
-    TooManyRedirects, HTTPError, ConnectionError,
-    FileModeWarning, ConnectTimeout, ReadTimeout
-)
+warnings.simplefilter("ignore", DependencyWarning)
 
 # Set default logging handler to avoid "No handler found" warnings.
 import logging
 from logging import NullHandler
 
+from . import packages, utils
+from .__version__ import (
+    __author__,
+    __author_email__,
+    __build__,
+    __cake__,
+    __copyright__,
+    __description__,
+    __license__,
+    __title__,
+    __url__,
+    __version__,
+)
+from .api import delete, get, head, options, patch, post, put, request
+from .exceptions import (
+    ConnectionError,
+    ConnectTimeout,
+    FileModeWarning,
+    HTTPError,
+    JSONDecodeError,
+    ReadTimeout,
+    RequestException,
+    Timeout,
+    TooManyRedirects,
+    URLRequired,
+)
+from .models import PreparedRequest, Request, Response
+from .sessions import Session, session
+from .status_codes import codes
+
 logging.getLogger(__name__).addHandler(NullHandler())
 
 # FileModeWarnings go off per the default.
-warnings.simplefilter('default', FileModeWarning, append=True)
+warnings.simplefilter("default", FileModeWarning, append=True)
diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 352e07bdce4aebb4420eb0b53a2840e8d474e02b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3697
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
X1;FAWj2esrj694w>>P|dOhU{6Nfi+)

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/__version__.cpython-39.pyc
deleted file mode 100644
index 14b384f2fe0b155693eda83433bd2e85ff380d4a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 583
zcmYe~<>g{vU|^UdaWHi!BLl-@5C<7EGB7YWFfcF_>o71dq%cG=q%cM?rZ7b@r7%Y^
zr?5n^q_9S@rm#h^rLae_r*K4Zq;N)Yrf>x_Xma1;C`v6XO)V}dt`ZNZEXl~vQ}750
z2~bGOFH-O*%}vZJ)~k}wC@Co@w$j&!Db*`VO-w1tNKMI4F4oJ;uVOROGcwgP%w$w$
zVyNQvPR+|pEy+*_O3f^(suIpkb;yQ@6oCZv@{7`|xEu=-lQU8kjPwkuWSsL0DvL7H
zGfEVU42%pEP_&owFfcGYnzKUT!~EV23XkTj@YCeF#Tg%8l39|I8Xtd)KR!MswK%yb
zv!En1KQBK17JGbrX;Dsm{4MVI__EZZVu&bbe0)-AW==|c{4K8d_{7qZjQpbb_*(*S
zc4}^7CRA5WW^!s?G01S<`1oX)+v4MIam2?bCuXO{$FF240yzsz{AzKwiU}=FEh>&l
z%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwu
ziAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uEM(fIgD%
d^a?6(aoFVMr<CTT+OdL?fe-@&0}CTM1OSlUxV``Y

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/_internal_utils.cpython-39.pyc
deleted file mode 100644
index 374571eee1605a25b55e8d58efb33f090fa984aa..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1330
zcmYe~<>g{vU|^UdaWK_`g@NHQh=Yuo85kHG7#J9e^%xi!QW&BbQW#U1au{=&qL^}-
zqnLA9qF5LiQaDpsQdnCUqgYeeQrKG<qS#V6f*CZqs@8E8r52W^7MB$3#b@S~q!#5R
z=ERqlWaboe)u8|`u7INavdom!Vg-<NW=W+&T4`Q#NoIatu|i2kVu?axQK~|6eqM2D
zZfc4G%&eSBg``S_AgCQ&<r$gD844+>1*v%{3i){osTCzfskx~+l?rL8<scr|0SXzZ
zIR&Xj#R?k5rO6oziNy-Z`MCv&C7N6>85tNDG?{O)WfsR5R2tplPAbjJDap)>FD@y%
z#S9`?6N{5GGn1K+f(R5sAnXhar4oi3h7!hRrXqnFhFYdPsS>6lg&Kwh%r%S)8EcvH
zxM~;{ut3-~Ou-DAj8&)IGs{x*6cQDRONuh{(iQTPvQm>vbQFqG(-VtQa#D+n74p**
zN-7IdL1HDPMR~;vi3&xj1x2aFsd*)dpiolCPvcThP=JIL)SS#bg_4X^g}lU)%(7IN
z;Sgg|^OEyZKz1eOr6{DNLOJCbsYR(^WAajyQ;Uleiz@XLLNYRo6%va<0bi`(80_rn
zsZg2+c2r4zPKrW)Nk(c>d1i5{9$2F$>n*O#;>^6_lEl2^)FM#86oEqP78}^g)LU#|
z+fqTH3~}Zy4zNsSUivNO{L+$@3`IN)3=F?IoULL)i&Kk=V^VWcGK*sT^HN=kK>pBG
z2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwuiAglk&B;&CEH25+j!Dfc
zi}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH7}B~yL0WU5zCc}t)qKOPc>pmdO#
zm(B-@X^<lsSh*P4m{=Hjn7EjVK%&W@1O!VPAT|dB0|Pi=STHa!z!F9=pBF<DW0gP+
z!vdxh#)XWG4B-qZOu-B+3?<B!MvM#~7|D>r9L!+AkirtopvhXb#U-^QwJ0|;FI6Ek
zO`$X|GdVv69;NwtIhCNiQIeRM2aBTQjKreE<dW2)Vm&T!#8?$17A59_Qh`D#)E`#p
z29@M1Bxj^1XX`2WmKK*NB&EU>fK31;FHmyH%P&y~s4U6I&r>i`NGL8TN`OSYRS_s{
zSt%st=jVVm6tOZeFod}IX|fctF)%O`v49A61_p*(LZJ{JxPp>ls%ueEevu~QEe@E&
zz$pMi@Pd>JKs_9vSsV|}fO7B{VCQ3GV&r0EW8`5h5@cXt@Y7@jTdT=_i#<L*B|kYn
y{uUb~e}mH@Bt?Q<0*WxO9*9k#2!*h~c5>L{=BJeAq}qX!a52dJEF2=tTmk?yEPJj1

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/adapters.cpython-39.pyc
deleted file mode 100644
index df29b1900ffe0afb90f0b3fb96e51ee647c48a4e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/api.cpython-39.pyc
deleted file mode 100644
index 14204a4270461ca36cb2de310a9dbde001094927..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/auth.cpython-39.pyc
deleted file mode 100644
index 7a92375c9f29e9ad6e4ded4cb5b504ef84437755..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8359
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
F0|2U{^sxW{

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/certs.cpython-39.pyc
deleted file mode 100644
index d0348e7aafc7bdc2141b1a15da6910c69d712750..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 661
zcmYe~<>g{vU|^UdaWM5FBLl-@5C<7EF)%PVFfcF_t1&Pzq%cG=q%fv1<uK+lMKLil
zq%x;4XEPNkrLv?lH8V6bGBTvF1T$!|mbx)AFmM&67M7+KmlW$IrxukIbJd{$F0PP_
z%wmPy{FKt1RE46{lG38QVug~7RE2_~)U?#1qSO?Hl+?7u(wq_nXGaB)5t(V3$%!SY
z3Q47TDLJWn3LzP(MX3sz#a#J$Ih6|ed8rDI8m54a0I}1G@^ir)s8)r7#N_P6^i(}A
zF3&WD%KTD=#G+KFU}j#rLJ-uoItr<J>3TW}Y57G8i3&cMd8HK!DVfD3MVU#ZC7Jno
z3SjZv#Jt4x)D*7Nyt2%q{Jh-Myb>L-p~;DP3dtFXdFiQO%TrR*GV?Ma`qC82K`z$N
zR4B=Z`dA@Rp*Xc5u_&=5HK&pb>cSL|hoPS2dI^dQO~zZSV7<3E;^T7@GxOr({WMu`
zvB$@!<R{0+-x4m!EYOQDOU+BkF9L^lW?E(uDCR)w^AdAY<Ku6!78GUXm8@ha;$UEa
z5Wni2tztrpQ;UjYQgc!=i(>rqQeBEN%Tg6|6+-<y!(4-cJwqIW6+Hc1{QX>mJso3$
zU431HLtKLt%whrpd}0z!baV34GmA?yvtv^8%3^#nlVXZ9OHy^A9x09~$Slx@x=SCH
i9P~jEQmj`{d5gm)7aaX|ET9C&#=yY9!p+0P!3Y2dtkXgO

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index 5c24a9d94c66d7c7c7b8d367cab8cd078b2a0818..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1640
zcmYe~<>g{vU|^UdaWM5SI|IXG5C<7EGcYhXFfcF_uVZ9jNMVR#NMTH2%3;i9ieh2}
zv6*w2qnJ~fvsj{7Q(03OB^gp!vYDdTplsG`rYQCl#uVlpjwp^)wxUldj45n6oVi?4
zT)Es)+_^kaJh{A4yt#Z)e7XEl{J8>A0=a@wg1JIbLSWO`bA)q+ql9xsqC|2<qeOGX
zqQr8=qr|~-961uXl2MXiHgk?tlvE013TKXVu1u5+Sd1%2Hdi)E7R=_(k;|2jlFwC$
zQpi<|Qp{C~QetFCRgO|gRgO|kRf|$iRgY3n)kxJ$)k<TI(gv~8n4)y@cBHaTU@Tgd
z!kEI7ql@7ZkgL&s0&^X2jvmN$SbfEpqn~RKB?WdFXO1C~i;dte=FgFXxH5$?MIgr*
z+4XRjE2pYPsirEYs-`i4U9XkK1af;CW0Xz`b1;LZU{xVkQEFjnYH>-iUUGhJL1GD4
z9V+1B3dzVUR>;jyDa}b$$Vkjf$w@6%$jmLsFDg-hXvs{<%*iaNRLCqYE=?^~NJ=d!
zPfg8J2&gQ{$j?(SQb^28;ev9E^|)Sw5|1Y1E%xM$#G;hc62F&B3=9k}LCHvy^A>Ai
zX?{uSE%wqp2!jhu#TVq17T@B53PO0CrA0ZZdCB=HskgY&Q%eep@+&e^i*NCO7?tr!
zl?92##kVAodGV=vWtm0!dAX^1CAY*7dXU96S#NQa7UdKq78R%7;wml5Db0hh*-MLZ
zvhp+Yz|zG9IhiH5KrTp0O)E-F*JQlK4^|eRQBqP6pOaZ!qRDuR%{RZOI5kI;@fJsL
zNl|8Ax~IP;%PkJ)#GIVOq@2`S?7oQw1(|v2xA=TZOF$wpKDU2SN@`JRic4m4i6&PO
z9|HqJ5kH6!01<*9f)hlrf(SMc!44ugK!gwj1A``OkuZo2%D6?`AQlgZ-~~xB-r`Ko
z&(F?G%}OlNWGs>di7^+6f#k(Ogak;y<Q98;d`f<DeEco$g3JQF__EZzl>DM1P)yxo
zF0L%T#Z#7ARGgWg7oVAzmVb*SzAUxq7F%X<d_koVls3M_l2x3acZ;pGC?_W~sR)~6
z!M?!aN~~T6`Ro=b8gep|jKCg*c_k+^=@y$a*jGg&AWw)gFfiQWPR`HCNlh-v%+D)E
z^B~yUx0s7dif(Zym1gFYWah<#IIKyPC8@=r)RzfKSV@V+sm0*9yTzQDS8|IbCqFO!
z7He8geqzZj-n`P>)S}Gf_>#(k)Z$ybnRz9t>8V9fE)T@tdf;?%ix0|!=C)fbpoCH+
z1#%}3h^YsOl;T@VnfbT)kzB5qn3TMdp~wQ{EfDdm-q|W9v^ce>I3_hGC9^2TKQGm#
zD6=e8L02Kv&oj(5DA+T^F<8OV&&A)*HQ3WJCfL>2H8{jINWm;7AiyUk(L^^VKRvU!
zBr`iEHLonjCo?IgII|>Gw;(Y&J25@AIHn-8Kpz_8`cU^4>qD}-UP0w84x3zXVPFT!
zvc)b83=AwBJWL$yY|K2&Je(YCEQ~tLGK@To9E?1SJWLYIEQ}Dy#mL3P#%RC@k^{-`
NFp4liWH=Z(7y-F;(6;~p

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/cookies.cpython-39.pyc
deleted file mode 100644
index a7ccf7ba7d882764fffa266e696cb587eeefaf6c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/exceptions.cpython-39.pyc
deleted file mode 100644
index 2458922bbb3e95b7590746342d0e8059d3c97942..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5273
zcmYe~<>g{vU|^UdaWFNNhk@ZSh=Yt-85kHG7#J9er!X=wq%cG=q%fv1<uK+lMKLon
zxHF_Mr?9jzq_Cv2G&4uBx-+D(rm(dzq_Cy3HZw;txih4&r*O0|q;P=wZ0-yxoGDx_
z3@KcxY|YG3?CuOH+$lUQ3@JQdK8HI)3U3Nu3quMYSUsmZLkfS2Knp{PKq^}*XERF_
zmpem>V2V%+LyAx;XESpYw>v|MaEeF^Ly8Dk2ah{LifD>h3qy(+n9u9ZkRqNU(ZY}-
zk;<CN*US>d@6M1SnIhG~kRk;Y5pZWnkxr3mVMvjIiU_(hq{ybowJ@Z}K}Cez8B*j^
z6j~Tk6jBA7nWKc=8B!Eelv)^4l)(0gxHF_Er>L|rq^P8_rZP9PM2WgHq^PE-wJ@Zp
zrLv}qHM2yCyECMyr)ab=q-cQkNVqekXr^ejFr;XK`I7DoDcUJIEet6-sZ!0%QPS=V
zDY_|oEet7osnV%3%`8!}?hGmVDF!VJDF&(1&CF49DTcuennqO#Tt%scrK!aw#d@g~
z$*Bb;nfZCeTy>a$iz_4}vsfWFKczG$RUtV)uOu-uuUMfZBUPa|wL~F5O(6(skh%iG
zBt5Q|pcJ9Wc#G2`BqYGKs3^ZE86<*?nW3Cw1qKF&RE8+V6ox3K6vim#c7`;@6s8pB
z7LF*Eb_N!PDAr&GO_o~%P@7y~4z3Cb$w)0qRVYs^R!GcKNX$*jOfStZEk-y*p(G=*
zL?J&pxwNP#HASI3BQqyeAtNy_B_}g4U7<3+w1`VVK|ui;7J6V#G9%PoAc}>7fdPd1
zLFqY$fq|ihX#qGrFJ!7^u3@fWh-U<gFsCprWU66^XR2XNVJc-Ta;jm-Vk&kjVXk3L
zVQyvu^BJ?iDoR*NSZf%XnX=ew7&94an3gd1F)}iwFoFD7<>Z-{S(2HUlUbDt3s|^!
z70NS9G87V^j!jTV%u50BiVO1dic=F5@{_VslS_*AZgCW)Ld5)Tu|pMWvfpAZ$S)`Y
zd8G)HKX0*TBo-%@loZ`!EiNrcEh+*<#x0Kc_{_Y_lK6N{mRl^vsX1x4SQ3lUi*K=I
zmxE}q_LYpcIOF4!a}tY-<KtH{{AzZ#iU}=FEh>&l%}L2Dit*1&bt%d$OI6TS2=(&}
za}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwuiAglk&B;&CEH25+j!Dfci}A@!
ziYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH7}`lnbQDXkS$7I88#FbIO8NB|UROgxNi
zjC_oIj2!=&n7A0LB+(O&9^9X7AV23N=BCES-{Ojo&jly*`1o5q@$rSFi8)Xi_W1ae
z{N(s}usyeUq25nU&B=+6F9IbE2*Jz1z)%Eo0XQ^yK<)trI0qvO3s?jr2Y^x<xTFMW
zLe2r;)WBTC#K6E%CGMD~0LnxPsi0g0Pt1CLD_M#_el8LMSt|@8L_h?>Jzy5dXs|&t
zAoqYw<X{BzNp;OFe&_tWywqe+Q31}-RWgnW2q6sT6^Y?;jW`1X11QfILtO*nlk6I<
zfTH}0N{B<m9Tf^dJQCa>!N9<vf)pYkKFMz22oCmvxIoM?Pa!zihXe;mGB7Y`AUOcU
zC)ok)A(^?U`K2XQt3xtUVa1q2NoH<pib8&Ai5?fYL~~9oNzMQjcqO2s9FmO6Gjnnj
zl0gy*N%<uiV0Bih70Ff!b+9~!R5R#7;~8olxa=XMB`7s91+E@!X)&aL^~0Sqq!<_&
zbdUlC#3wmW_)r~N)r2){pp`*MQ6)HJ@<DYQD0M58<b!LsqSV~{5>O>qRF+x<4M=D?
z0;>KJOF&63r8GG;MFA;T6N^$6iWAdPL8cU?mK0SI^s+Pq1A{4&mqC1zz08di*i{Z7
z{}!i$+^vw3nWB)FU!qW)nwO%Gm{+Ngl30?ckeLVeVq#8Ceo0Acib7&;erX=KG6y9c
zJv<QvDnx9MTnplp?%L2GA5c(c7Nw?CX*nvCCFW$ND1-+2C}b9c6ER2v6oR>l*{KSN
zV4>9F5`6BGg|#`MMGA;dvbzLA^7DNY^D2W<Q!<M{b!nAwNPfOTE-2iJU}E@OA;-YL
z;DQu7AU?^i;PuTcF3!wL4^GZV%}uP*2gN2RY>L5r1&vg_bUlTPl9B?2{30-2tO*LY
zT!=1w&XZ?gVDLb49*9r6^E~sw@db6BQgCXjLP}~{VrfoEv0g!?LRx+iG(sT`F2?5~
zP%Yqt<RTECWEXKkT@)JRQ>6+Et%9Qbvdk1vn=i3gp*TM`H6y=VArs<sd@fRCU|<M9
zauJA6vWs}3F7ilCOi3-O(gQgv1Iz{mO=&8q=pf5=N(>APAxN$R@kw?aKh$;L3KSG*
zN+9<^Do{{Dg9lw^F)<;g%)r19f#fC-pJX?QIA@gRWv8aN<|XH+WagzqYE^rX!(b&@
zYI05@s1ctGQK^s$RjQCw3NGJDKz#sc3@d;Y;frTb-4ANd!`dJqJ{hjg&nrpID{)Ch
zcD0gQVrCAgTF6&O0ZD)=W=Mk^RL6kS<8zoQ0|P?>QgDL!Bs)wvxTGjGG1oaiuedZf
zH3bry#-Pvy_25$TO2F9^TyMcT3y@w^PEl%NN+rmhV2$`3s>T57-7_%2LJ-6!*`ZuP
zph^<rK56ID;*$Ja1yH@2nOdv>>J}s`q=5qyPnD$3z`&4!6ks4e$?gyh%_~YR&&*3n
zOv*`h%1?ndEUiJ+6sVUBPHm-mC8?kkn3xA`=apxq<|!ar5D*g-5*3p2Q!4QV9jM)x
zgXClopJXTV!`v30Sd^EUmtH01lvoVv41;;#2!^S^=N3&+D;>!#AU^4Cam&m}_03O7
zg}KGcQ6UY~*Dg;iR>&_%%}Y%IH#$-)N<c#isXE|H3v-@AN@_`JQEnz!RY|czQf6La
zQKdpoYF>It20piIF)%QcA-NsIC)w?=-eIvzYC&pVN@`wmCCnENj(G~1xdr(}phi*(
zTv{O|Keaedy+k1w+<pd)g``##q$Yz@m8BLHXXfWA6eZ@Rr{Z(FHUk4g6_VRQd_PV3
zB2XVLO0FQYKo8pI)hjK^$;nJIMrw|O`){{+LGcah8G^IVEp|_TFazAxECThZia?#3
zB2dSo2-J`+0yQm*KrOZ+Q1hq=)H=Dv6_%J&nhMbfY7Z2Fs^B6}tycu9T#7)Yc@d~^
zECLlow>U#83!th&`Mn5~*@{5P_ZB-e(276_=$4R6YC%zIaw4d+2$KNCP7%nPklr%5
zcM2vzUDR6~HjvJ@9cUz?*Z?%{!p6faARxd3g`7g{5S9=N1cG=VmH>+Yn*fUt3ji8+
BqhJ64

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/help.cpython-39.pyc
deleted file mode 100644
index d12a2de85885cf37b9ceae801f6bb718a9da7d00..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2744
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
G9E<=!4*K!{

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/hooks.cpython-39.pyc
deleted file mode 100644
index 0b85dce6ca22560e9f9887ee792b05b55ad6ef00..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1018
zcmYe~<>g{vU|^UdaWM5O69dCz5C<7EF)%PVFfcF_%P}x8q%cG=q%fv4Mlq%^r7*WJ
zL@}kXq_DOyL@}qZ1v6-}S8e1fN-Zo+EiNh6%gE2qF6OF30bE=m8JWcjx%nxjIjIT-
zMfqi!DXGN@B^jv-$%zGtNtrpBC7G$k3TgR8V8I}$VG3Zw6pAa0OHy<7xVRk45;JoW
zlX6la5>{MX2?<51#Rd6!#i<DiR$K}S3JM_^sR}SLh4j?C)S|?a)D(rZqWoNiL<OkH
zdR(_SV2YBFy$xc6yzb1vz);Kw@;YM*Qwu{0g9}45V=#jzvtKeJNDUN&l(H}|Fa(2?
z3o$S-WHQt+#B$X#)-a|sOlB%%31(QyPy|w?$#jcJ&)^noYFTPt30MS7{Hk-diU}=F
zEh>&l%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1
ziwOwuiAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH7}
z#gaZaVD$<rZ*keAWG0s+=jRsKf!zNY<gqHnl+?7u(wvfbh%%d;{N%)(Vmm#AT201V
ztRDXU-oapBAQ7w#3=Fq;QS=Lf0tXZZ42(sb3=9m(%pgmkn2mvf0i?$pq$q%afuV-6
zfGv{&6oLyFY8VzWf>=d9C5$zUDU8ibMQSyS>0mJzhFFDKmKv5CrZmP(h8pH2jD3u?
ztTn7DOr?xPS~aY-OoduCOrR*MGIPl+E=Vj%&PXj*NCYPx1(2sR^YapmDi!kc6cQEE
zGs{x*6bdp^lT#J)(-cw?OA_^Nam2?bC+6hD$NOnA-C|BpExE;>kyxBqQc|SJc8fVX
zwel7#IDl?(f~a_qrdw>;<%vb<#kW{MLbtfUAqbYi3?rzcz)HkH-WLId2@?k+7b6QJ
z7b6=Z2crNZ2O}F}kuU=TgP$hLE%x~Ml>FrQ_#zGl1_p3gf~Am*1_g5wC_Ha**yMt<
Sn;j^$i$TH6!p+9a!3F>n5DV)7

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/models.cpython-39.pyc
deleted file mode 100644
index 21140b24e3ba1680b590f4f1c625943bf02f587c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 23967
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
Y92oy*;Q-Uj0!0E60$xJ(4D}550HeU1G5`Po

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/packages.cpython-39.pyc
deleted file mode 100644
index f557c13f250ce06d9f6999e7130794cb7779b710..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 530
zcmYe~<>g{vU|^UdaWHi|69dCz5C<8vF)%PVFfcF_moYFfq%fo~<}gGtq%gTK#HK_s
zrZA^6iZetpr81{7H8ZBNG&7_!+AyTDrZQx)H8Z*}#M(u%r?RIqWiu6frLr&JNM%Z4
z5ocJ)SY(jOp30fR+{~E5*vcfy5XA-3k;*Q~0HRY^Q@O+$Y#0g+3VBi(gBdj0UV>cY
zr^$Say|gGNCo{?T7E5MIUg9nG<c!3kl+=<co`TE*z4)@!yp;SRy<3cWRdUDzMX80Q
zsl_G5dIgEe*@@|?#d@0Dx0s77i*K<*MQ#Z|^roi7!$i2^<1=#$@{3C1<8QI$<R>TQ
z6yIXW$t*6p#h#m=Qks)me2Y0ZKjjuzaY<rPNpX2*NyaVaoYcHqe5H8>MX70-6{#ul
zx%nw88HxlM7$C&2MrW&-(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+uKhH4NpkU7s$6y6d
zKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~;>?m%U8t*z
xV+t}0^q~Qv5A(M^OjfU;@)m~;#QAoNpjhQ&U|`^2<zVDs<YVSz6k`-%1OScUok{=z

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/sessions.cpython-39.pyc
deleted file mode 100644
index 76ee71a4f84d66ee3c41b423d37b513e35f86327..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 19872
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
Sk30{*Ks`f|Ks^Hp8Up|_Z8`D)

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/status_codes.cpython-39.pyc
deleted file mode 100644
index 3b6879372aaf03a33d9916feb4d0ccdda39369b8..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/structures.cpython-39.pyc
deleted file mode 100644
index fb9e8d36fb22c87b967f26a81413e07e8b8ecbc6..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/requests/__pycache__/utils.cpython-39.pyc
deleted file mode 100644
index ce754ef04535db9472a6f2b5c333a31161c226e5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 22645
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
Ih;j%509wJEbN~PV

diff --git a/env/Lib/site-packages/pip/_vendor/requests/__version__.py b/env/Lib/site-packages/pip/_vendor/requests/__version__.py
index 1267488d..5063c3f8 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/__version__.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/__version__.py
@@ -2,13 +2,13 @@
 # |(  |-  |.| | | |-  `-.  |  `-.
 # ' ' `-' `-`.`-' `-' `-'  '  `-'
 
-__title__ = 'requests'
-__description__ = 'Python HTTP for Humans.'
-__url__ = 'https://requests.readthedocs.io'
-__version__ = '2.25.1'
-__build__ = 0x022501
-__author__ = 'Kenneth Reitz'
-__author_email__ = 'me@kennethreitz.org'
-__license__ = 'Apache 2.0'
-__copyright__ = 'Copyright 2020 Kenneth Reitz'
-__cake__ = u'\u2728 \U0001f370 \u2728'
+__title__ = "requests"
+__description__ = "Python HTTP for Humans."
+__url__ = "https://requests.readthedocs.io"
+__version__ = "2.31.0"
+__build__ = 0x023100
+__author__ = "Kenneth Reitz"
+__author_email__ = "me@kennethreitz.org"
+__license__ = "Apache 2.0"
+__copyright__ = "Copyright Kenneth Reitz"
+__cake__ = "\u2728 \U0001f370 \u2728"
diff --git a/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py b/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py
index 759d9a56..f2cf635e 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/_internal_utils.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests._internal_utils
 ~~~~~~~~~~~~~~
@@ -7,11 +5,24 @@ requests._internal_utils
 Provides utility functions that are consumed internally by Requests
 which depend on extremely few external helpers (such as compat)
 """
+import re
+
+from .compat import builtin_str
+
+_VALID_HEADER_NAME_RE_BYTE = re.compile(rb"^[^:\s][^:\r\n]*$")
+_VALID_HEADER_NAME_RE_STR = re.compile(r"^[^:\s][^:\r\n]*$")
+_VALID_HEADER_VALUE_RE_BYTE = re.compile(rb"^\S[^\r\n]*$|^$")
+_VALID_HEADER_VALUE_RE_STR = re.compile(r"^\S[^\r\n]*$|^$")
 
-from .compat import is_py2, builtin_str, str
+_HEADER_VALIDATORS_STR = (_VALID_HEADER_NAME_RE_STR, _VALID_HEADER_VALUE_RE_STR)
+_HEADER_VALIDATORS_BYTE = (_VALID_HEADER_NAME_RE_BYTE, _VALID_HEADER_VALUE_RE_BYTE)
+HEADER_VALIDATORS = {
+    bytes: _HEADER_VALIDATORS_BYTE,
+    str: _HEADER_VALIDATORS_STR,
+}
 
 
-def to_native_string(string, encoding='ascii'):
+def to_native_string(string, encoding="ascii"):
     """Given a string object, regardless of type, returns a representation of
     that string in the native string type, encoding and decoding where
     necessary. This assumes ASCII unless told otherwise.
@@ -19,10 +30,7 @@ def to_native_string(string, encoding='ascii'):
     if isinstance(string, builtin_str):
         out = string
     else:
-        if is_py2:
-            out = string.encode(encoding)
-        else:
-            out = string.decode(encoding)
+        out = string.decode(encoding)
 
     return out
 
@@ -36,7 +44,7 @@ def unicode_is_ascii(u_string):
     """
     assert isinstance(u_string, str)
     try:
-        u_string.encode('ascii')
+        u_string.encode("ascii")
         return True
     except UnicodeEncodeError:
         return False
diff --git a/env/Lib/site-packages/pip/_vendor/requests/adapters.py b/env/Lib/site-packages/pip/_vendor/requests/adapters.py
index c30e7c92..10c17679 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/adapters.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/adapters.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.adapters
 ~~~~~~~~~~~~~~~~~
@@ -9,57 +7,75 @@ and maintain connections.
 """
 
 import os.path
-import socket
+import socket  # noqa: F401
 
-from pip._vendor.urllib3.poolmanager import PoolManager, proxy_from_url
-from pip._vendor.urllib3.response import HTTPResponse
-from pip._vendor.urllib3.util import parse_url
-from pip._vendor.urllib3.util import Timeout as TimeoutSauce
-from pip._vendor.urllib3.util.retry import Retry
-from pip._vendor.urllib3.exceptions import ClosedPoolError
-from pip._vendor.urllib3.exceptions import ConnectTimeoutError
+from pip._vendor.urllib3.exceptions import ClosedPoolError, ConnectTimeoutError
 from pip._vendor.urllib3.exceptions import HTTPError as _HTTPError
-from pip._vendor.urllib3.exceptions import MaxRetryError
-from pip._vendor.urllib3.exceptions import NewConnectionError
+from pip._vendor.urllib3.exceptions import InvalidHeader as _InvalidHeader
+from pip._vendor.urllib3.exceptions import (
+    LocationValueError,
+    MaxRetryError,
+    NewConnectionError,
+    ProtocolError,
+)
 from pip._vendor.urllib3.exceptions import ProxyError as _ProxyError
-from pip._vendor.urllib3.exceptions import ProtocolError
-from pip._vendor.urllib3.exceptions import ReadTimeoutError
+from pip._vendor.urllib3.exceptions import ReadTimeoutError, ResponseError
 from pip._vendor.urllib3.exceptions import SSLError as _SSLError
-from pip._vendor.urllib3.exceptions import ResponseError
-from pip._vendor.urllib3.exceptions import LocationValueError
+from pip._vendor.urllib3.poolmanager import PoolManager, proxy_from_url
+from pip._vendor.urllib3.util import Timeout as TimeoutSauce
+from pip._vendor.urllib3.util import parse_url
+from pip._vendor.urllib3.util.retry import Retry
 
+from .auth import _basic_auth_str
+from .compat import basestring, urlparse
+from .cookies import extract_cookies_to_jar
+from .exceptions import (
+    ConnectionError,
+    ConnectTimeout,
+    InvalidHeader,
+    InvalidProxyURL,
+    InvalidSchema,
+    InvalidURL,
+    ProxyError,
+    ReadTimeout,
+    RetryError,
+    SSLError,
+)
 from .models import Response
-from .compat import urlparse, basestring
-from .utils import (DEFAULT_CA_BUNDLE_PATH, extract_zipped_paths,
-                    get_encoding_from_headers, prepend_scheme_if_needed,
-                    get_auth_from_url, urldefragauth, select_proxy)
 from .structures import CaseInsensitiveDict
-from .cookies import extract_cookies_to_jar
-from .exceptions import (ConnectionError, ConnectTimeout, ReadTimeout, SSLError,
-                         ProxyError, RetryError, InvalidSchema, InvalidProxyURL,
-                         InvalidURL)
-from .auth import _basic_auth_str
+from .utils import (
+    DEFAULT_CA_BUNDLE_PATH,
+    extract_zipped_paths,
+    get_auth_from_url,
+    get_encoding_from_headers,
+    prepend_scheme_if_needed,
+    select_proxy,
+    urldefragauth,
+)
 
 try:
     from pip._vendor.urllib3.contrib.socks import SOCKSProxyManager
 except ImportError:
+
     def SOCKSProxyManager(*args, **kwargs):
         raise InvalidSchema("Missing dependencies for SOCKS support.")
 
+
 DEFAULT_POOLBLOCK = False
 DEFAULT_POOLSIZE = 10
 DEFAULT_RETRIES = 0
 DEFAULT_POOL_TIMEOUT = None
 
 
-class BaseAdapter(object):
+class BaseAdapter:
     """The Base Transport Adapter"""
 
     def __init__(self):
-        super(BaseAdapter, self).__init__()
+        super().__init__()
 
-    def send(self, request, stream=False, timeout=None, verify=True,
-             cert=None, proxies=None):
+    def send(
+        self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None
+    ):
         """Sends PreparedRequest object. Returns Response object.
 
         :param request: The :class:`PreparedRequest <PreparedRequest>` being sent.
@@ -107,12 +123,22 @@ class HTTPAdapter(BaseAdapter):
       >>> a = requests.adapters.HTTPAdapter(max_retries=3)
       >>> s.mount('http://', a)
     """
-    __attrs__ = ['max_retries', 'config', '_pool_connections', '_pool_maxsize',
-                 '_pool_block']
 
-    def __init__(self, pool_connections=DEFAULT_POOLSIZE,
-                 pool_maxsize=DEFAULT_POOLSIZE, max_retries=DEFAULT_RETRIES,
-                 pool_block=DEFAULT_POOLBLOCK):
+    __attrs__ = [
+        "max_retries",
+        "config",
+        "_pool_connections",
+        "_pool_maxsize",
+        "_pool_block",
+    ]
+
+    def __init__(
+        self,
+        pool_connections=DEFAULT_POOLSIZE,
+        pool_maxsize=DEFAULT_POOLSIZE,
+        max_retries=DEFAULT_RETRIES,
+        pool_block=DEFAULT_POOLBLOCK,
+    ):
         if max_retries == DEFAULT_RETRIES:
             self.max_retries = Retry(0, read=False)
         else:
@@ -120,7 +146,7 @@ class HTTPAdapter(BaseAdapter):
         self.config = {}
         self.proxy_manager = {}
 
-        super(HTTPAdapter, self).__init__()
+        super().__init__()
 
         self._pool_connections = pool_connections
         self._pool_maxsize = pool_maxsize
@@ -140,10 +166,13 @@ class HTTPAdapter(BaseAdapter):
         for attr, value in state.items():
             setattr(self, attr, value)
 
-        self.init_poolmanager(self._pool_connections, self._pool_maxsize,
-                              block=self._pool_block)
+        self.init_poolmanager(
+            self._pool_connections, self._pool_maxsize, block=self._pool_block
+        )
 
-    def init_poolmanager(self, connections, maxsize, block=DEFAULT_POOLBLOCK, **pool_kwargs):
+    def init_poolmanager(
+        self, connections, maxsize, block=DEFAULT_POOLBLOCK, **pool_kwargs
+    ):
         """Initializes a urllib3 PoolManager.
 
         This method should not be called from user code, and is only
@@ -160,8 +189,12 @@ class HTTPAdapter(BaseAdapter):
         self._pool_maxsize = maxsize
         self._pool_block = block
 
-        self.poolmanager = PoolManager(num_pools=connections, maxsize=maxsize,
-                                       block=block, strict=True, **pool_kwargs)
+        self.poolmanager = PoolManager(
+            num_pools=connections,
+            maxsize=maxsize,
+            block=block,
+            **pool_kwargs,
+        )
 
     def proxy_manager_for(self, proxy, **proxy_kwargs):
         """Return urllib3 ProxyManager for the given proxy.
@@ -177,7 +210,7 @@ class HTTPAdapter(BaseAdapter):
         """
         if proxy in self.proxy_manager:
             manager = self.proxy_manager[proxy]
-        elif proxy.lower().startswith('socks'):
+        elif proxy.lower().startswith("socks"):
             username, password = get_auth_from_url(proxy)
             manager = self.proxy_manager[proxy] = SOCKSProxyManager(
                 proxy,
@@ -186,7 +219,7 @@ class HTTPAdapter(BaseAdapter):
                 num_pools=self._pool_connections,
                 maxsize=self._pool_maxsize,
                 block=self._pool_block,
-                **proxy_kwargs
+                **proxy_kwargs,
             )
         else:
             proxy_headers = self.proxy_headers(proxy)
@@ -196,7 +229,8 @@ class HTTPAdapter(BaseAdapter):
                 num_pools=self._pool_connections,
                 maxsize=self._pool_maxsize,
                 block=self._pool_block,
-                **proxy_kwargs)
+                **proxy_kwargs,
+            )
 
         return manager
 
@@ -212,7 +246,7 @@ class HTTPAdapter(BaseAdapter):
             to a CA bundle to use
         :param cert: The SSL certificate to verify.
         """
-        if url.lower().startswith('https') and verify:
+        if url.lower().startswith("https") and verify:
 
             cert_loc = None
 
@@ -224,17 +258,19 @@ class HTTPAdapter(BaseAdapter):
                 cert_loc = extract_zipped_paths(DEFAULT_CA_BUNDLE_PATH)
 
             if not cert_loc or not os.path.exists(cert_loc):
-                raise IOError("Could not find a suitable TLS CA certificate bundle, "
-                              "invalid path: {}".format(cert_loc))
+                raise OSError(
+                    f"Could not find a suitable TLS CA certificate bundle, "
+                    f"invalid path: {cert_loc}"
+                )
 
-            conn.cert_reqs = 'CERT_REQUIRED'
+            conn.cert_reqs = "CERT_REQUIRED"
 
             if not os.path.isdir(cert_loc):
                 conn.ca_certs = cert_loc
             else:
                 conn.ca_cert_dir = cert_loc
         else:
-            conn.cert_reqs = 'CERT_NONE'
+            conn.cert_reqs = "CERT_NONE"
             conn.ca_certs = None
             conn.ca_cert_dir = None
 
@@ -246,11 +282,14 @@ class HTTPAdapter(BaseAdapter):
                 conn.cert_file = cert
                 conn.key_file = None
             if conn.cert_file and not os.path.exists(conn.cert_file):
-                raise IOError("Could not find the TLS certificate file, "
-                              "invalid path: {}".format(conn.cert_file))
+                raise OSError(
+                    f"Could not find the TLS certificate file, "
+                    f"invalid path: {conn.cert_file}"
+                )
             if conn.key_file and not os.path.exists(conn.key_file):
-                raise IOError("Could not find the TLS key file, "
-                              "invalid path: {}".format(conn.key_file))
+                raise OSError(
+                    f"Could not find the TLS key file, invalid path: {conn.key_file}"
+                )
 
     def build_response(self, req, resp):
         """Builds a :class:`Response <requests.Response>` object from a urllib3
@@ -265,10 +304,10 @@ class HTTPAdapter(BaseAdapter):
         response = Response()
 
         # Fallback to None if there's no status_code, for whatever reason.
-        response.status_code = getattr(resp, 'status', None)
+        response.status_code = getattr(resp, "status", None)
 
         # Make headers case-insensitive.
-        response.headers = CaseInsensitiveDict(getattr(resp, 'headers', {}))
+        response.headers = CaseInsensitiveDict(getattr(resp, "headers", {}))
 
         # Set encoding.
         response.encoding = get_encoding_from_headers(response.headers)
@@ -276,7 +315,7 @@ class HTTPAdapter(BaseAdapter):
         response.reason = response.raw.reason
 
         if isinstance(req.url, bytes):
-            response.url = req.url.decode('utf-8')
+            response.url = req.url.decode("utf-8")
         else:
             response.url = req.url
 
@@ -301,11 +340,13 @@ class HTTPAdapter(BaseAdapter):
         proxy = select_proxy(url, proxies)
 
         if proxy:
-            proxy = prepend_scheme_if_needed(proxy, 'http')
+            proxy = prepend_scheme_if_needed(proxy, "http")
             proxy_url = parse_url(proxy)
             if not proxy_url.host:
-                raise InvalidProxyURL("Please check proxy URL. It is malformed"
-                                      " and could be missing the host.")
+                raise InvalidProxyURL(
+                    "Please check proxy URL. It is malformed "
+                    "and could be missing the host."
+                )
             proxy_manager = self.proxy_manager_for(proxy)
             conn = proxy_manager.connection_from_url(url)
         else:
@@ -343,11 +384,11 @@ class HTTPAdapter(BaseAdapter):
         proxy = select_proxy(request.url, proxies)
         scheme = urlparse(request.url).scheme
 
-        is_proxied_http_request = (proxy and scheme != 'https')
+        is_proxied_http_request = proxy and scheme != "https"
         using_socks_proxy = False
         if proxy:
             proxy_scheme = urlparse(proxy).scheme.lower()
-            using_socks_proxy = proxy_scheme.startswith('socks')
+            using_socks_proxy = proxy_scheme.startswith("socks")
 
         url = request.path_url
         if is_proxied_http_request and not using_socks_proxy:
@@ -386,12 +427,13 @@ class HTTPAdapter(BaseAdapter):
         username, password = get_auth_from_url(proxy)
 
         if username:
-            headers['Proxy-Authorization'] = _basic_auth_str(username,
-                                                             password)
+            headers["Proxy-Authorization"] = _basic_auth_str(username, password)
 
         return headers
 
-    def send(self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None):
+    def send(
+        self, request, stream=False, timeout=None, verify=True, cert=None, proxies=None
+    ):
         """Sends PreparedRequest object. Returns Response object.
 
         :param request: The :class:`PreparedRequest <PreparedRequest>` being sent.
@@ -415,86 +457,47 @@ class HTTPAdapter(BaseAdapter):
 
         self.cert_verify(conn, request.url, verify, cert)
         url = self.request_url(request, proxies)
-        self.add_headers(request, stream=stream, timeout=timeout, verify=verify, cert=cert, proxies=proxies)
+        self.add_headers(
+            request,
+            stream=stream,
+            timeout=timeout,
+            verify=verify,
+            cert=cert,
+            proxies=proxies,
+        )
 
-        chunked = not (request.body is None or 'Content-Length' in request.headers)
+        chunked = not (request.body is None or "Content-Length" in request.headers)
 
         if isinstance(timeout, tuple):
             try:
                 connect, read = timeout
                 timeout = TimeoutSauce(connect=connect, read=read)
-            except ValueError as e:
-                # this may raise a string formatting error.
-                err = ("Invalid timeout {}. Pass a (connect, read) "
-                       "timeout tuple, or a single float to set "
-                       "both timeouts to the same value".format(timeout))
-                raise ValueError(err)
+            except ValueError:
+                raise ValueError(
+                    f"Invalid timeout {timeout}. Pass a (connect, read) timeout tuple, "
+                    f"or a single float to set both timeouts to the same value."
+                )
         elif isinstance(timeout, TimeoutSauce):
             pass
         else:
             timeout = TimeoutSauce(connect=timeout, read=timeout)
 
         try:
-            if not chunked:
-                resp = conn.urlopen(
-                    method=request.method,
-                    url=url,
-                    body=request.body,
-                    headers=request.headers,
-                    redirect=False,
-                    assert_same_host=False,
-                    preload_content=False,
-                    decode_content=False,
-                    retries=self.max_retries,
-                    timeout=timeout
-                )
+            resp = conn.urlopen(
+                method=request.method,
+                url=url,
+                body=request.body,
+                headers=request.headers,
+                redirect=False,
+                assert_same_host=False,
+                preload_content=False,
+                decode_content=False,
+                retries=self.max_retries,
+                timeout=timeout,
+                chunked=chunked,
+            )
 
-            # Send the request.
-            else:
-                if hasattr(conn, 'proxy_pool'):
-                    conn = conn.proxy_pool
-
-                low_conn = conn._get_conn(timeout=DEFAULT_POOL_TIMEOUT)
-
-                try:
-                    low_conn.putrequest(request.method,
-                                        url,
-                                        skip_accept_encoding=True)
-
-                    for header, value in request.headers.items():
-                        low_conn.putheader(header, value)
-
-                    low_conn.endheaders()
-
-                    for i in request.body:
-                        low_conn.send(hex(len(i))[2:].encode('utf-8'))
-                        low_conn.send(b'\r\n')
-                        low_conn.send(i)
-                        low_conn.send(b'\r\n')
-                    low_conn.send(b'0\r\n\r\n')
-
-                    # Receive the response from the server
-                    try:
-                        # For Python 2.7, use buffering of HTTP responses
-                        r = low_conn.getresponse(buffering=True)
-                    except TypeError:
-                        # For compatibility with Python 3.3+
-                        r = low_conn.getresponse()
-
-                    resp = HTTPResponse.from_httplib(
-                        r,
-                        pool=conn,
-                        connection=low_conn,
-                        preload_content=False,
-                        decode_content=False
-                    )
-                except:
-                    # If we hit any problems here, clean up the connection.
-                    # Then, reraise so that we can handle the actual exception.
-                    low_conn.close()
-                    raise
-
-        except (ProtocolError, socket.error) as err:
+        except (ProtocolError, OSError) as err:
             raise ConnectionError(err, request=request)
 
         except MaxRetryError as e:
@@ -527,6 +530,8 @@ class HTTPAdapter(BaseAdapter):
                 raise SSLError(e, request=request)
             elif isinstance(e, ReadTimeoutError):
                 raise ReadTimeout(e, request=request)
+            elif isinstance(e, _InvalidHeader):
+                raise InvalidHeader(e, request=request)
             else:
                 raise
 
diff --git a/env/Lib/site-packages/pip/_vendor/requests/api.py b/env/Lib/site-packages/pip/_vendor/requests/api.py
index e978e203..cd0b3eea 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/api.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/api.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.api
 ~~~~~~~~~~~~
@@ -72,8 +70,7 @@ def get(url, params=None, **kwargs):
     :rtype: requests.Response
     """
 
-    kwargs.setdefault('allow_redirects', True)
-    return request('get', url, params=params, **kwargs)
+    return request("get", url, params=params, **kwargs)
 
 
 def options(url, **kwargs):
@@ -85,8 +82,7 @@ def options(url, **kwargs):
     :rtype: requests.Response
     """
 
-    kwargs.setdefault('allow_redirects', True)
-    return request('options', url, **kwargs)
+    return request("options", url, **kwargs)
 
 
 def head(url, **kwargs):
@@ -100,8 +96,8 @@ def head(url, **kwargs):
     :rtype: requests.Response
     """
 
-    kwargs.setdefault('allow_redirects', False)
-    return request('head', url, **kwargs)
+    kwargs.setdefault("allow_redirects", False)
+    return request("head", url, **kwargs)
 
 
 def post(url, data=None, json=None, **kwargs):
@@ -110,13 +106,13 @@ def post(url, data=None, json=None, **kwargs):
     :param url: URL for the new :class:`Request` object.
     :param data: (optional) Dictionary, list of tuples, bytes, or file-like
         object to send in the body of the :class:`Request`.
-    :param json: (optional) json data to send in the body of the :class:`Request`.
+    :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`.
     :param \*\*kwargs: Optional arguments that ``request`` takes.
     :return: :class:`Response <Response>` object
     :rtype: requests.Response
     """
 
-    return request('post', url, data=data, json=json, **kwargs)
+    return request("post", url, data=data, json=json, **kwargs)
 
 
 def put(url, data=None, **kwargs):
@@ -125,13 +121,13 @@ def put(url, data=None, **kwargs):
     :param url: URL for the new :class:`Request` object.
     :param data: (optional) Dictionary, list of tuples, bytes, or file-like
         object to send in the body of the :class:`Request`.
-    :param json: (optional) json data to send in the body of the :class:`Request`.
+    :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`.
     :param \*\*kwargs: Optional arguments that ``request`` takes.
     :return: :class:`Response <Response>` object
     :rtype: requests.Response
     """
 
-    return request('put', url, data=data, **kwargs)
+    return request("put", url, data=data, **kwargs)
 
 
 def patch(url, data=None, **kwargs):
@@ -140,13 +136,13 @@ def patch(url, data=None, **kwargs):
     :param url: URL for the new :class:`Request` object.
     :param data: (optional) Dictionary, list of tuples, bytes, or file-like
         object to send in the body of the :class:`Request`.
-    :param json: (optional) json data to send in the body of the :class:`Request`.
+    :param json: (optional) A JSON serializable Python object to send in the body of the :class:`Request`.
     :param \*\*kwargs: Optional arguments that ``request`` takes.
     :return: :class:`Response <Response>` object
     :rtype: requests.Response
     """
 
-    return request('patch', url, data=data, **kwargs)
+    return request("patch", url, data=data, **kwargs)
 
 
 def delete(url, **kwargs):
@@ -158,4 +154,4 @@ def delete(url, **kwargs):
     :rtype: requests.Response
     """
 
-    return request('delete', url, **kwargs)
+    return request("delete", url, **kwargs)
diff --git a/env/Lib/site-packages/pip/_vendor/requests/auth.py b/env/Lib/site-packages/pip/_vendor/requests/auth.py
index eeface39..9733686d 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/auth.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/auth.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.auth
 ~~~~~~~~~~~~~
@@ -7,22 +5,21 @@ requests.auth
 This module contains the authentication handlers for Requests.
 """
 
+import hashlib
 import os
 import re
-import time
-import hashlib
 import threading
+import time
 import warnings
-
 from base64 import b64encode
 
-from .compat import urlparse, str, basestring
-from .cookies import extract_cookies_to_jar
 from ._internal_utils import to_native_string
+from .compat import basestring, str, urlparse
+from .cookies import extract_cookies_to_jar
 from .utils import parse_dict_header
 
-CONTENT_TYPE_FORM_URLENCODED = 'application/x-www-form-urlencoded'
-CONTENT_TYPE_MULTI_PART = 'multipart/form-data'
+CONTENT_TYPE_FORM_URLENCODED = "application/x-www-form-urlencoded"
+CONTENT_TYPE_MULTI_PART = "multipart/form-data"
 
 
 def _basic_auth_str(username, password):
@@ -57,23 +54,23 @@ def _basic_auth_str(username, password):
     # -- End Removal --
 
     if isinstance(username, str):
-        username = username.encode('latin1')
+        username = username.encode("latin1")
 
     if isinstance(password, str):
-        password = password.encode('latin1')
+        password = password.encode("latin1")
 
-    authstr = 'Basic ' + to_native_string(
-        b64encode(b':'.join((username, password))).strip()
+    authstr = "Basic " + to_native_string(
+        b64encode(b":".join((username, password))).strip()
     )
 
     return authstr
 
 
-class AuthBase(object):
+class AuthBase:
     """Base class that all auth implementations derive from"""
 
     def __call__(self, r):
-        raise NotImplementedError('Auth hooks must be callable.')
+        raise NotImplementedError("Auth hooks must be callable.")
 
 
 class HTTPBasicAuth(AuthBase):
@@ -84,16 +81,18 @@ class HTTPBasicAuth(AuthBase):
         self.password = password
 
     def __eq__(self, other):
-        return all([
-            self.username == getattr(other, 'username', None),
-            self.password == getattr(other, 'password', None)
-        ])
+        return all(
+            [
+                self.username == getattr(other, "username", None),
+                self.password == getattr(other, "password", None),
+            ]
+        )
 
     def __ne__(self, other):
         return not self == other
 
     def __call__(self, r):
-        r.headers['Authorization'] = _basic_auth_str(self.username, self.password)
+        r.headers["Authorization"] = _basic_auth_str(self.username, self.password)
         return r
 
 
@@ -101,7 +100,7 @@ class HTTPProxyAuth(HTTPBasicAuth):
     """Attaches HTTP Proxy Authentication to a given Request object."""
 
     def __call__(self, r):
-        r.headers['Proxy-Authorization'] = _basic_auth_str(self.username, self.password)
+        r.headers["Proxy-Authorization"] = _basic_auth_str(self.username, self.password)
         return r
 
 
@@ -116,9 +115,9 @@ class HTTPDigestAuth(AuthBase):
 
     def init_per_thread_state(self):
         # Ensure state is initialized just once per-thread
-        if not hasattr(self._thread_local, 'init'):
+        if not hasattr(self._thread_local, "init"):
             self._thread_local.init = True
-            self._thread_local.last_nonce = ''
+            self._thread_local.last_nonce = ""
             self._thread_local.nonce_count = 0
             self._thread_local.chal = {}
             self._thread_local.pos = None
@@ -129,44 +128,52 @@ class HTTPDigestAuth(AuthBase):
         :rtype: str
         """
 
-        realm = self._thread_local.chal['realm']
-        nonce = self._thread_local.chal['nonce']
-        qop = self._thread_local.chal.get('qop')
-        algorithm = self._thread_local.chal.get('algorithm')
-        opaque = self._thread_local.chal.get('opaque')
+        realm = self._thread_local.chal["realm"]
+        nonce = self._thread_local.chal["nonce"]
+        qop = self._thread_local.chal.get("qop")
+        algorithm = self._thread_local.chal.get("algorithm")
+        opaque = self._thread_local.chal.get("opaque")
         hash_utf8 = None
 
         if algorithm is None:
-            _algorithm = 'MD5'
+            _algorithm = "MD5"
         else:
             _algorithm = algorithm.upper()
         # lambdas assume digest modules are imported at the top level
-        if _algorithm == 'MD5' or _algorithm == 'MD5-SESS':
+        if _algorithm == "MD5" or _algorithm == "MD5-SESS":
+
             def md5_utf8(x):
                 if isinstance(x, str):
-                    x = x.encode('utf-8')
+                    x = x.encode("utf-8")
                 return hashlib.md5(x).hexdigest()
+
             hash_utf8 = md5_utf8
-        elif _algorithm == 'SHA':
+        elif _algorithm == "SHA":
+
             def sha_utf8(x):
                 if isinstance(x, str):
-                    x = x.encode('utf-8')
+                    x = x.encode("utf-8")
                 return hashlib.sha1(x).hexdigest()
+
             hash_utf8 = sha_utf8
-        elif _algorithm == 'SHA-256':
+        elif _algorithm == "SHA-256":
+
             def sha256_utf8(x):
                 if isinstance(x, str):
-                    x = x.encode('utf-8')
+                    x = x.encode("utf-8")
                 return hashlib.sha256(x).hexdigest()
+
             hash_utf8 = sha256_utf8
-        elif _algorithm == 'SHA-512':
+        elif _algorithm == "SHA-512":
+
             def sha512_utf8(x):
                 if isinstance(x, str):
-                    x = x.encode('utf-8')
+                    x = x.encode("utf-8")
                 return hashlib.sha512(x).hexdigest()
+
             hash_utf8 = sha512_utf8
 
-        KD = lambda s, d: hash_utf8("%s:%s" % (s, d))
+        KD = lambda s, d: hash_utf8(f"{s}:{d}")  # noqa:E731
 
         if hash_utf8 is None:
             return None
@@ -177,10 +184,10 @@ class HTTPDigestAuth(AuthBase):
         #: path is request-uri defined in RFC 2616 which should not be empty
         path = p_parsed.path or "/"
         if p_parsed.query:
-            path += '?' + p_parsed.query
+            path += f"?{p_parsed.query}"
 
-        A1 = '%s:%s:%s' % (self.username, realm, self.password)
-        A2 = '%s:%s' % (method, path)
+        A1 = f"{self.username}:{realm}:{self.password}"
+        A2 = f"{method}:{path}"
 
         HA1 = hash_utf8(A1)
         HA2 = hash_utf8(A2)
@@ -189,22 +196,20 @@ class HTTPDigestAuth(AuthBase):
             self._thread_local.nonce_count += 1
         else:
             self._thread_local.nonce_count = 1
-        ncvalue = '%08x' % self._thread_local.nonce_count
-        s = str(self._thread_local.nonce_count).encode('utf-8')
-        s += nonce.encode('utf-8')
-        s += time.ctime().encode('utf-8')
+        ncvalue = f"{self._thread_local.nonce_count:08x}"
+        s = str(self._thread_local.nonce_count).encode("utf-8")
+        s += nonce.encode("utf-8")
+        s += time.ctime().encode("utf-8")
         s += os.urandom(8)
 
-        cnonce = (hashlib.sha1(s).hexdigest()[:16])
-        if _algorithm == 'MD5-SESS':
-            HA1 = hash_utf8('%s:%s:%s' % (HA1, nonce, cnonce))
+        cnonce = hashlib.sha1(s).hexdigest()[:16]
+        if _algorithm == "MD5-SESS":
+            HA1 = hash_utf8(f"{HA1}:{nonce}:{cnonce}")
 
         if not qop:
-            respdig = KD(HA1, "%s:%s" % (nonce, HA2))
-        elif qop == 'auth' or 'auth' in qop.split(','):
-            noncebit = "%s:%s:%s:%s:%s" % (
-                nonce, ncvalue, cnonce, 'auth', HA2
-            )
+            respdig = KD(HA1, f"{nonce}:{HA2}")
+        elif qop == "auth" or "auth" in qop.split(","):
+            noncebit = f"{nonce}:{ncvalue}:{cnonce}:auth:{HA2}"
             respdig = KD(HA1, noncebit)
         else:
             # XXX handle auth-int.
@@ -213,18 +218,20 @@ class HTTPDigestAuth(AuthBase):
         self._thread_local.last_nonce = nonce
 
         # XXX should the partial digests be encoded too?
-        base = 'username="%s", realm="%s", nonce="%s", uri="%s", ' \
-               'response="%s"' % (self.username, realm, nonce, path, respdig)
+        base = (
+            f'username="{self.username}", realm="{realm}", nonce="{nonce}", '
+            f'uri="{path}", response="{respdig}"'
+        )
         if opaque:
-            base += ', opaque="%s"' % opaque
+            base += f', opaque="{opaque}"'
         if algorithm:
-            base += ', algorithm="%s"' % algorithm
+            base += f', algorithm="{algorithm}"'
         if entdig:
-            base += ', digest="%s"' % entdig
+            base += f', digest="{entdig}"'
         if qop:
-            base += ', qop="auth", nc=%s, cnonce="%s"' % (ncvalue, cnonce)
+            base += f', qop="auth", nc={ncvalue}, cnonce="{cnonce}"'
 
-        return 'Digest %s' % (base)
+        return f"Digest {base}"
 
     def handle_redirect(self, r, **kwargs):
         """Reset num_401_calls counter on redirects."""
@@ -248,13 +255,13 @@ class HTTPDigestAuth(AuthBase):
             # Rewind the file position indicator of the body to where
             # it was to resend the request.
             r.request.body.seek(self._thread_local.pos)
-        s_auth = r.headers.get('www-authenticate', '')
+        s_auth = r.headers.get("www-authenticate", "")
 
-        if 'digest' in s_auth.lower() and self._thread_local.num_401_calls < 2:
+        if "digest" in s_auth.lower() and self._thread_local.num_401_calls < 2:
 
             self._thread_local.num_401_calls += 1
-            pat = re.compile(r'digest ', flags=re.IGNORECASE)
-            self._thread_local.chal = parse_dict_header(pat.sub('', s_auth, count=1))
+            pat = re.compile(r"digest ", flags=re.IGNORECASE)
+            self._thread_local.chal = parse_dict_header(pat.sub("", s_auth, count=1))
 
             # Consume content and release the original connection
             # to allow our new request to reuse the same one.
@@ -264,8 +271,9 @@ class HTTPDigestAuth(AuthBase):
             extract_cookies_to_jar(prep._cookies, r.request, r.raw)
             prep.prepare_cookies(prep._cookies)
 
-            prep.headers['Authorization'] = self.build_digest_header(
-                prep.method, prep.url)
+            prep.headers["Authorization"] = self.build_digest_header(
+                prep.method, prep.url
+            )
             _r = r.connection.send(prep, **kwargs)
             _r.history.append(r)
             _r.request = prep
@@ -280,7 +288,7 @@ class HTTPDigestAuth(AuthBase):
         self.init_per_thread_state()
         # If we have a saved nonce, skip the 401
         if self._thread_local.last_nonce:
-            r.headers['Authorization'] = self.build_digest_header(r.method, r.url)
+            r.headers["Authorization"] = self.build_digest_header(r.method, r.url)
         try:
             self._thread_local.pos = r.body.tell()
         except AttributeError:
@@ -289,17 +297,19 @@ class HTTPDigestAuth(AuthBase):
             # file position of the previous body. Ensure it's set to
             # None.
             self._thread_local.pos = None
-        r.register_hook('response', self.handle_401)
-        r.register_hook('response', self.handle_redirect)
+        r.register_hook("response", self.handle_401)
+        r.register_hook("response", self.handle_redirect)
         self._thread_local.num_401_calls = 1
 
         return r
 
     def __eq__(self, other):
-        return all([
-            self.username == getattr(other, 'username', None),
-            self.password == getattr(other, 'password', None)
-        ])
+        return all(
+            [
+                self.username == getattr(other, "username", None),
+                self.password == getattr(other, "password", None),
+            ]
+        )
 
     def __ne__(self, other):
         return not self == other
diff --git a/env/Lib/site-packages/pip/_vendor/requests/certs.py b/env/Lib/site-packages/pip/_vendor/requests/certs.py
index 06a594e5..38696a1f 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/certs.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/certs.py
@@ -1,5 +1,4 @@
 #!/usr/bin/env python
-# -*- coding: utf-8 -*-
 
 """
 requests.certs
@@ -12,7 +11,14 @@ If you are packaging Requests, e.g., for a Linux distribution or a managed
 environment, you can change the definition of where() to return a separately
 packaged CA bundle.
 """
-from pip._vendor.certifi import where
 
-if __name__ == '__main__':
+import os
+
+if "_PIP_STANDALONE_CERT" not in os.environ:
+    from pip._vendor.certifi import where
+else:
+    def where():
+        return os.environ["_PIP_STANDALONE_CERT"]
+
+if __name__ == "__main__":
     print(where())
diff --git a/env/Lib/site-packages/pip/_vendor/requests/compat.py b/env/Lib/site-packages/pip/_vendor/requests/compat.py
index 9e293716..9ab2bb48 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/compat.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/compat.py
@@ -1,11 +1,10 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.compat
 ~~~~~~~~~~~~~~~
 
-This module handles import compatibility issues between Python 2 and
-Python 3.
+This module previously handled import compatibility issues
+between Python 2 and Python 3. It remains for backwards
+compatibility until the next major version.
 """
 
 from pip._vendor import chardet
@@ -20,57 +19,49 @@ import sys
 _ver = sys.version_info
 
 #: Python 2.x?
-is_py2 = (_ver[0] == 2)
+is_py2 = _ver[0] == 2
 
 #: Python 3.x?
-is_py3 = (_ver[0] == 3)
+is_py3 = _ver[0] == 3
 
 # Note: We've patched out simplejson support in pip because it prevents
 #       upgrading simplejson on Windows.
-# try:
-#     import simplejson as json
-# except (ImportError, SyntaxError):
-#     # simplejson does not support Python 3.2, it throws a SyntaxError
-#     # because of u'...' Unicode literals.
 import json
+from json import JSONDecodeError
 
-# ---------
-# Specifics
-# ---------
-
-if is_py2:
-    from urllib import (
-        quote, unquote, quote_plus, unquote_plus, urlencode, getproxies,
-        proxy_bypass, proxy_bypass_environment, getproxies_environment)
-    from urlparse import urlparse, urlunparse, urljoin, urlsplit, urldefrag
-    from urllib2 import parse_http_list
-    import cookielib
-    from Cookie import Morsel
-    from StringIO import StringIO
-    # Keep OrderedDict for backwards compatibility.
-    from collections import Callable, Mapping, MutableMapping, OrderedDict
-
-
-    builtin_str = str
-    bytes = str
-    str = unicode
-    basestring = basestring
-    numeric_types = (int, long, float)
-    integer_types = (int, long)
+# Keep OrderedDict for backwards compatibility.
+from collections import OrderedDict
+from collections.abc import Callable, Mapping, MutableMapping
+from http import cookiejar as cookielib
+from http.cookies import Morsel
+from io import StringIO
 
-elif is_py3:
-    from urllib.parse import urlparse, urlunparse, urljoin, urlsplit, urlencode, quote, unquote, quote_plus, unquote_plus, urldefrag
-    from urllib.request import parse_http_list, getproxies, proxy_bypass, proxy_bypass_environment, getproxies_environment
-    from http import cookiejar as cookielib
-    from http.cookies import Morsel
-    from io import StringIO
-    # Keep OrderedDict for backwards compatibility.
-    from collections import OrderedDict
-    from collections.abc import Callable, Mapping, MutableMapping
+# --------------
+# Legacy Imports
+# --------------
+from urllib.parse import (
+    quote,
+    quote_plus,
+    unquote,
+    unquote_plus,
+    urldefrag,
+    urlencode,
+    urljoin,
+    urlparse,
+    urlsplit,
+    urlunparse,
+)
+from urllib.request import (
+    getproxies,
+    getproxies_environment,
+    parse_http_list,
+    proxy_bypass,
+    proxy_bypass_environment,
+)
 
-    builtin_str = str
-    str = str
-    bytes = bytes
-    basestring = (str, bytes)
-    numeric_types = (int, float)
-    integer_types = (int,)
+builtin_str = str
+str = str
+bytes = bytes
+basestring = (str, bytes)
+numeric_types = (int, float)
+integer_types = (int,)
diff --git a/env/Lib/site-packages/pip/_vendor/requests/cookies.py b/env/Lib/site-packages/pip/_vendor/requests/cookies.py
index 56fccd9c..bf54ab23 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/cookies.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/cookies.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.cookies
 ~~~~~~~~~~~~~~~~
@@ -9,12 +7,12 @@ Compatibility code to be able to use `cookielib.CookieJar` with requests.
 requests.utils imports from here, so be careful with imports.
 """
 
+import calendar
 import copy
 import time
-import calendar
 
 from ._internal_utils import to_native_string
-from .compat import cookielib, urlparse, urlunparse, Morsel, MutableMapping
+from .compat import Morsel, MutableMapping, cookielib, urlparse, urlunparse
 
 try:
     import threading
@@ -22,7 +20,7 @@ except ImportError:
     import dummy_threading as threading
 
 
-class MockRequest(object):
+class MockRequest:
     """Wraps a `requests.Request` to mimic a `urllib2.Request`.
 
     The code in `cookielib.CookieJar` expects this interface in order to correctly
@@ -51,16 +49,22 @@ class MockRequest(object):
     def get_full_url(self):
         # Only return the response's URL if the user hadn't set the Host
         # header
-        if not self._r.headers.get('Host'):
+        if not self._r.headers.get("Host"):
             return self._r.url
         # If they did set it, retrieve it and reconstruct the expected domain
-        host = to_native_string(self._r.headers['Host'], encoding='utf-8')
+        host = to_native_string(self._r.headers["Host"], encoding="utf-8")
         parsed = urlparse(self._r.url)
         # Reconstruct the URL as we expect it
-        return urlunparse([
-            parsed.scheme, host, parsed.path, parsed.params, parsed.query,
-            parsed.fragment
-        ])
+        return urlunparse(
+            [
+                parsed.scheme,
+                host,
+                parsed.path,
+                parsed.params,
+                parsed.query,
+                parsed.fragment,
+            ]
+        )
 
     def is_unverifiable(self):
         return True
@@ -73,7 +77,9 @@ class MockRequest(object):
 
     def add_header(self, key, val):
         """cookielib has no legitimate use for this method; add it back if you find one."""
-        raise NotImplementedError("Cookie headers should be added with add_unredirected_header()")
+        raise NotImplementedError(
+            "Cookie headers should be added with add_unredirected_header()"
+        )
 
     def add_unredirected_header(self, name, value):
         self._new_headers[name] = value
@@ -94,7 +100,7 @@ class MockRequest(object):
         return self.get_host()
 
 
-class MockResponse(object):
+class MockResponse:
     """Wraps a `httplib.HTTPMessage` to mimic a `urllib.addinfourl`.
 
     ...what? Basically, expose the parsed HTTP headers from the server response
@@ -122,8 +128,7 @@ def extract_cookies_to_jar(jar, request, response):
     :param request: our own requests.Request object
     :param response: urllib3.HTTPResponse object
     """
-    if not (hasattr(response, '_original_response') and
-            response._original_response):
+    if not (hasattr(response, "_original_response") and response._original_response):
         return
     # the _original_response field is the wrapped httplib.HTTPResponse object,
     req = MockRequest(request)
@@ -140,7 +145,7 @@ def get_cookie_header(jar, request):
     """
     r = MockRequest(request)
     jar.add_cookie_header(r)
-    return r.get_new_headers().get('Cookie')
+    return r.get_new_headers().get("Cookie")
 
 
 def remove_cookie_by_name(cookiejar, name, domain=None, path=None):
@@ -205,7 +210,9 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
         """
         # support client code that unsets cookies by assignment of a None value:
         if value is None:
-            remove_cookie_by_name(self, name, domain=kwargs.get('domain'), path=kwargs.get('path'))
+            remove_cookie_by_name(
+                self, name, domain=kwargs.get("domain"), path=kwargs.get("path")
+            )
             return
 
         if isinstance(value, Morsel):
@@ -305,16 +312,15 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
         """
         dictionary = {}
         for cookie in iter(self):
-            if (
-                (domain is None or cookie.domain == domain) and
-                (path is None or cookie.path == path)
+            if (domain is None or cookie.domain == domain) and (
+                path is None or cookie.path == path
             ):
                 dictionary[cookie.name] = cookie.value
         return dictionary
 
     def __contains__(self, name):
         try:
-            return super(RequestsCookieJar, self).__contains__(name)
+            return super().__contains__(name)
         except CookieConflictError:
             return True
 
@@ -341,9 +347,13 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
         remove_cookie_by_name(self, name)
 
     def set_cookie(self, cookie, *args, **kwargs):
-        if hasattr(cookie.value, 'startswith') and cookie.value.startswith('"') and cookie.value.endswith('"'):
-            cookie.value = cookie.value.replace('\\"', '')
-        return super(RequestsCookieJar, self).set_cookie(cookie, *args, **kwargs)
+        if (
+            hasattr(cookie.value, "startswith")
+            and cookie.value.startswith('"')
+            and cookie.value.endswith('"')
+        ):
+            cookie.value = cookie.value.replace('\\"', "")
+        return super().set_cookie(cookie, *args, **kwargs)
 
     def update(self, other):
         """Updates this jar with cookies from another CookieJar or dict-like"""
@@ -351,7 +361,7 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
             for cookie in other:
                 self.set_cookie(copy.copy(cookie))
         else:
-            super(RequestsCookieJar, self).update(other)
+            super().update(other)
 
     def _find(self, name, domain=None, path=None):
         """Requests uses this method internally to get cookie values.
@@ -371,7 +381,7 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
                     if path is None or cookie.path == path:
                         return cookie.value
 
-        raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path))
+        raise KeyError(f"name={name!r}, domain={domain!r}, path={path!r}")
 
     def _find_no_duplicates(self, name, domain=None, path=None):
         """Both ``__get_item__`` and ``get`` call this function: it's never
@@ -390,25 +400,29 @@ class RequestsCookieJar(cookielib.CookieJar, MutableMapping):
             if cookie.name == name:
                 if domain is None or cookie.domain == domain:
                     if path is None or cookie.path == path:
-                        if toReturn is not None:  # if there are multiple cookies that meet passed in criteria
-                            raise CookieConflictError('There are multiple cookies with name, %r' % (name))
-                        toReturn = cookie.value  # we will eventually return this as long as no cookie conflict
+                        if toReturn is not None:
+                            # if there are multiple cookies that meet passed in criteria
+                            raise CookieConflictError(
+                                f"There are multiple cookies with name, {name!r}"
+                            )
+                        # we will eventually return this as long as no cookie conflict
+                        toReturn = cookie.value
 
         if toReturn:
             return toReturn
-        raise KeyError('name=%r, domain=%r, path=%r' % (name, domain, path))
+        raise KeyError(f"name={name!r}, domain={domain!r}, path={path!r}")
 
     def __getstate__(self):
         """Unlike a normal CookieJar, this class is pickleable."""
         state = self.__dict__.copy()
         # remove the unpickleable RLock object
-        state.pop('_cookies_lock')
+        state.pop("_cookies_lock")
         return state
 
     def __setstate__(self, state):
         """Unlike a normal CookieJar, this class is pickleable."""
         self.__dict__.update(state)
-        if '_cookies_lock' not in self.__dict__:
+        if "_cookies_lock" not in self.__dict__:
             self._cookies_lock = threading.RLock()
 
     def copy(self):
@@ -427,7 +441,7 @@ def _copy_cookie_jar(jar):
     if jar is None:
         return None
 
-    if hasattr(jar, 'copy'):
+    if hasattr(jar, "copy"):
         # We're dealing with an instance of RequestsCookieJar
         return jar.copy()
     # We're dealing with a generic CookieJar instance
@@ -445,31 +459,32 @@ def create_cookie(name, value, **kwargs):
     and sent on every request (this is sometimes called a "supercookie").
     """
     result = {
-        'version': 0,
-        'name': name,
-        'value': value,
-        'port': None,
-        'domain': '',
-        'path': '/',
-        'secure': False,
-        'expires': None,
-        'discard': True,
-        'comment': None,
-        'comment_url': None,
-        'rest': {'HttpOnly': None},
-        'rfc2109': False,
+        "version": 0,
+        "name": name,
+        "value": value,
+        "port": None,
+        "domain": "",
+        "path": "/",
+        "secure": False,
+        "expires": None,
+        "discard": True,
+        "comment": None,
+        "comment_url": None,
+        "rest": {"HttpOnly": None},
+        "rfc2109": False,
     }
 
     badargs = set(kwargs) - set(result)
     if badargs:
-        err = 'create_cookie() got unexpected keyword arguments: %s'
-        raise TypeError(err % list(badargs))
+        raise TypeError(
+            f"create_cookie() got unexpected keyword arguments: {list(badargs)}"
+        )
 
     result.update(kwargs)
-    result['port_specified'] = bool(result['port'])
-    result['domain_specified'] = bool(result['domain'])
-    result['domain_initial_dot'] = result['domain'].startswith('.')
-    result['path_specified'] = bool(result['path'])
+    result["port_specified"] = bool(result["port"])
+    result["domain_specified"] = bool(result["domain"])
+    result["domain_initial_dot"] = result["domain"].startswith(".")
+    result["path_specified"] = bool(result["path"])
 
     return cookielib.Cookie(**result)
 
@@ -478,30 +493,28 @@ def morsel_to_cookie(morsel):
     """Convert a Morsel object into a Cookie containing the one k/v pair."""
 
     expires = None
-    if morsel['max-age']:
+    if morsel["max-age"]:
         try:
-            expires = int(time.time() + int(morsel['max-age']))
+            expires = int(time.time() + int(morsel["max-age"]))
         except ValueError:
-            raise TypeError('max-age: %s must be integer' % morsel['max-age'])
-    elif morsel['expires']:
-        time_template = '%a, %d-%b-%Y %H:%M:%S GMT'
-        expires = calendar.timegm(
-            time.strptime(morsel['expires'], time_template)
-        )
+            raise TypeError(f"max-age: {morsel['max-age']} must be integer")
+    elif morsel["expires"]:
+        time_template = "%a, %d-%b-%Y %H:%M:%S GMT"
+        expires = calendar.timegm(time.strptime(morsel["expires"], time_template))
     return create_cookie(
-        comment=morsel['comment'],
-        comment_url=bool(morsel['comment']),
+        comment=morsel["comment"],
+        comment_url=bool(morsel["comment"]),
         discard=False,
-        domain=morsel['domain'],
+        domain=morsel["domain"],
         expires=expires,
         name=morsel.key,
-        path=morsel['path'],
+        path=morsel["path"],
         port=None,
-        rest={'HttpOnly': morsel['httponly']},
+        rest={"HttpOnly": morsel["httponly"]},
         rfc2109=False,
-        secure=bool(morsel['secure']),
+        secure=bool(morsel["secure"]),
         value=morsel.value,
-        version=morsel['version'] or 0,
+        version=morsel["version"] or 0,
     )
 
 
@@ -534,11 +547,10 @@ def merge_cookies(cookiejar, cookies):
     :rtype: CookieJar
     """
     if not isinstance(cookiejar, cookielib.CookieJar):
-        raise ValueError('You can only merge into CookieJar')
+        raise ValueError("You can only merge into CookieJar")
 
     if isinstance(cookies, dict):
-        cookiejar = cookiejar_from_dict(
-            cookies, cookiejar=cookiejar, overwrite=False)
+        cookiejar = cookiejar_from_dict(cookies, cookiejar=cookiejar, overwrite=False)
     elif isinstance(cookies, cookielib.CookieJar):
         try:
             cookiejar.update(cookies)
diff --git a/env/Lib/site-packages/pip/_vendor/requests/exceptions.py b/env/Lib/site-packages/pip/_vendor/requests/exceptions.py
index 9ef9e6e9..168d0739 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/exceptions.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/exceptions.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.exceptions
 ~~~~~~~~~~~~~~~~~~~
@@ -8,6 +6,8 @@ This module contains the set of Requests' exceptions.
 """
 from pip._vendor.urllib3.exceptions import HTTPError as BaseHTTPError
 
+from .compat import JSONDecodeError as CompatJSONDecodeError
+
 
 class RequestException(IOError):
     """There was an ambiguous exception that occurred while handling your
@@ -16,13 +16,30 @@ class RequestException(IOError):
 
     def __init__(self, *args, **kwargs):
         """Initialize RequestException with `request` and `response` objects."""
-        response = kwargs.pop('response', None)
+        response = kwargs.pop("response", None)
         self.response = response
-        self.request = kwargs.pop('request', None)
-        if (response is not None and not self.request and
-                hasattr(response, 'request')):
+        self.request = kwargs.pop("request", None)
+        if response is not None and not self.request and hasattr(response, "request"):
             self.request = self.response.request
-        super(RequestException, self).__init__(*args, **kwargs)
+        super().__init__(*args, **kwargs)
+
+
+class InvalidJSONError(RequestException):
+    """A JSON error occurred."""
+
+
+class JSONDecodeError(InvalidJSONError, CompatJSONDecodeError):
+    """Couldn't decode the text into json"""
+
+    def __init__(self, *args, **kwargs):
+        """
+        Construct the JSONDecodeError instance first with all
+        args. Then use it's args to construct the IOError so that
+        the json specific args aren't used as IOError specific args
+        and the error message from JSONDecodeError is preserved.
+        """
+        CompatJSONDecodeError.__init__(self, *args)
+        InvalidJSONError.__init__(self, *self.args, **kwargs)
 
 
 class HTTPError(RequestException):
@@ -70,11 +87,11 @@ class TooManyRedirects(RequestException):
 
 
 class MissingSchema(RequestException, ValueError):
-    """The URL schema (e.g. http or https) is missing."""
+    """The URL scheme (e.g. http or https) is missing."""
 
 
 class InvalidSchema(RequestException, ValueError):
-    """See defaults.py for valid schemas."""
+    """The URL scheme provided is either invalid or unsupported."""
 
 
 class InvalidURL(RequestException, ValueError):
@@ -108,6 +125,7 @@ class RetryError(RequestException):
 class UnrewindableBodyError(RequestException):
     """Requests encountered an error when trying to rewind a body."""
 
+
 # Warnings
 
 
diff --git a/env/Lib/site-packages/pip/_vendor/requests/help.py b/env/Lib/site-packages/pip/_vendor/requests/help.py
index 3c3072ba..2d292c2f 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/help.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/help.py
@@ -1,17 +1,22 @@
 """Module containing bug report helper(s)."""
-from __future__ import print_function
 
 import json
 import platform
-import sys
 import ssl
+import sys
 
 from pip._vendor import idna
 from pip._vendor import urllib3
-from pip._vendor import chardet
 
 from . import __version__ as requests_version
 
+charset_normalizer = None
+
+try:
+    from pip._vendor import chardet
+except ImportError:
+    chardet = None
+
 try:
     from pip._vendor.urllib3.contrib import pyopenssl
 except ImportError:
@@ -19,16 +24,16 @@ except ImportError:
     OpenSSL = None
     cryptography = None
 else:
-    import OpenSSL
     import cryptography
+    import OpenSSL
 
 
 def _implementation():
     """Return a dict with the Python implementation and version.
 
     Provide both the name and the version of the Python implementation
-    currently running. For example, on CPython 2.7.5 it will return
-    {'name': 'CPython', 'version': '2.7.5'}.
+    currently running. For example, on CPython 3.10.3 it will return
+    {'name': 'CPython', 'version': '3.10.3'}.
 
     This function works best on CPython and PyPy: in particular, it probably
     doesn't work for Jython or IronPython. Future investigation should be done
@@ -36,76 +41,83 @@ def _implementation():
     """
     implementation = platform.python_implementation()
 
-    if implementation == 'CPython':
+    if implementation == "CPython":
         implementation_version = platform.python_version()
-    elif implementation == 'PyPy':
-        implementation_version = '%s.%s.%s' % (sys.pypy_version_info.major,
-                                               sys.pypy_version_info.minor,
-                                               sys.pypy_version_info.micro)
-        if sys.pypy_version_info.releaselevel != 'final':
-            implementation_version = ''.join([
-                implementation_version, sys.pypy_version_info.releaselevel
-            ])
-    elif implementation == 'Jython':
+    elif implementation == "PyPy":
+        implementation_version = "{}.{}.{}".format(
+            sys.pypy_version_info.major,
+            sys.pypy_version_info.minor,
+            sys.pypy_version_info.micro,
+        )
+        if sys.pypy_version_info.releaselevel != "final":
+            implementation_version = "".join(
+                [implementation_version, sys.pypy_version_info.releaselevel]
+            )
+    elif implementation == "Jython":
         implementation_version = platform.python_version()  # Complete Guess
-    elif implementation == 'IronPython':
+    elif implementation == "IronPython":
         implementation_version = platform.python_version()  # Complete Guess
     else:
-        implementation_version = 'Unknown'
+        implementation_version = "Unknown"
 
-    return {'name': implementation, 'version': implementation_version}
+    return {"name": implementation, "version": implementation_version}
 
 
 def info():
     """Generate information for a bug report."""
     try:
         platform_info = {
-            'system': platform.system(),
-            'release': platform.release(),
+            "system": platform.system(),
+            "release": platform.release(),
         }
-    except IOError:
+    except OSError:
         platform_info = {
-            'system': 'Unknown',
-            'release': 'Unknown',
+            "system": "Unknown",
+            "release": "Unknown",
         }
 
     implementation_info = _implementation()
-    urllib3_info = {'version': urllib3.__version__}
-    chardet_info = {'version': chardet.__version__}
+    urllib3_info = {"version": urllib3.__version__}
+    charset_normalizer_info = {"version": None}
+    chardet_info = {"version": None}
+    if charset_normalizer:
+        charset_normalizer_info = {"version": charset_normalizer.__version__}
+    if chardet:
+        chardet_info = {"version": chardet.__version__}
 
     pyopenssl_info = {
-        'version': None,
-        'openssl_version': '',
+        "version": None,
+        "openssl_version": "",
     }
     if OpenSSL:
         pyopenssl_info = {
-            'version': OpenSSL.__version__,
-            'openssl_version': '%x' % OpenSSL.SSL.OPENSSL_VERSION_NUMBER,
+            "version": OpenSSL.__version__,
+            "openssl_version": f"{OpenSSL.SSL.OPENSSL_VERSION_NUMBER:x}",
         }
     cryptography_info = {
-        'version': getattr(cryptography, '__version__', ''),
+        "version": getattr(cryptography, "__version__", ""),
     }
     idna_info = {
-        'version': getattr(idna, '__version__', ''),
+        "version": getattr(idna, "__version__", ""),
     }
 
     system_ssl = ssl.OPENSSL_VERSION_NUMBER
-    system_ssl_info = {
-        'version': '%x' % system_ssl if system_ssl is not None else ''
-    }
+    system_ssl_info = {"version": f"{system_ssl:x}" if system_ssl is not None else ""}
 
     return {
-        'platform': platform_info,
-        'implementation': implementation_info,
-        'system_ssl': system_ssl_info,
-        'using_pyopenssl': pyopenssl is not None,
-        'pyOpenSSL': pyopenssl_info,
-        'urllib3': urllib3_info,
-        'chardet': chardet_info,
-        'cryptography': cryptography_info,
-        'idna': idna_info,
-        'requests': {
-            'version': requests_version,
+        "platform": platform_info,
+        "implementation": implementation_info,
+        "system_ssl": system_ssl_info,
+        "using_pyopenssl": pyopenssl is not None,
+        "using_charset_normalizer": chardet is None,
+        "pyOpenSSL": pyopenssl_info,
+        "urllib3": urllib3_info,
+        "chardet": chardet_info,
+        "charset_normalizer": charset_normalizer_info,
+        "cryptography": cryptography_info,
+        "idna": idna_info,
+        "requests": {
+            "version": requests_version,
         },
     }
 
@@ -115,5 +127,5 @@ def main():
     print(json.dumps(info(), sort_keys=True, indent=2))
 
 
-if __name__ == '__main__':
+if __name__ == "__main__":
     main()
diff --git a/env/Lib/site-packages/pip/_vendor/requests/hooks.py b/env/Lib/site-packages/pip/_vendor/requests/hooks.py
index 7a51f212..d181ba2e 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/hooks.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/hooks.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.hooks
 ~~~~~~~~~~~~~~
@@ -11,12 +9,13 @@ Available hooks:
 ``response``:
     The response generated from a Request.
 """
-HOOKS = ['response']
+HOOKS = ["response"]
 
 
 def default_hooks():
     return {event: [] for event in HOOKS}
 
+
 # TODO: response is the only one
 
 
@@ -25,7 +24,7 @@ def dispatch_hook(key, hooks, hook_data, **kwargs):
     hooks = hooks or {}
     hooks = hooks.get(key)
     if hooks:
-        if hasattr(hooks, '__call__'):
+        if hasattr(hooks, "__call__"):
             hooks = [hooks]
         for hook in hooks:
             _hook_data = hook(hook_data, **kwargs)
diff --git a/env/Lib/site-packages/pip/_vendor/requests/models.py b/env/Lib/site-packages/pip/_vendor/requests/models.py
index b0ce2950..76e6f199 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/models.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/models.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.models
 ~~~~~~~~~~~~~~~
@@ -8,46 +6,72 @@ This module contains the primary objects that power Requests.
 """
 
 import datetime
-import sys
 
 # Import encoding now, to avoid implicit import later.
 # Implicit import within threads may cause LookupError when standard library is in a ZIP,
 # such as in Embedded Python. See https://github.com/psf/requests/issues/3578.
-import encodings.idna
+import encodings.idna  # noqa: F401
+from io import UnsupportedOperation
 
+from pip._vendor.urllib3.exceptions import (
+    DecodeError,
+    LocationParseError,
+    ProtocolError,
+    ReadTimeoutError,
+    SSLError,
+)
 from pip._vendor.urllib3.fields import RequestField
 from pip._vendor.urllib3.filepost import encode_multipart_formdata
 from pip._vendor.urllib3.util import parse_url
-from pip._vendor.urllib3.exceptions import (
-    DecodeError, ReadTimeoutError, ProtocolError, LocationParseError)
 
-from io import UnsupportedOperation
-from .hooks import default_hooks
-from .structures import CaseInsensitiveDict
-
-from .auth import HTTPBasicAuth
-from .cookies import cookiejar_from_dict, get_cookie_header, _copy_cookie_jar
-from .exceptions import (
-    HTTPError, MissingSchema, InvalidURL, ChunkedEncodingError,
-    ContentDecodingError, ConnectionError, StreamConsumedError)
 from ._internal_utils import to_native_string, unicode_is_ascii
-from .utils import (
-    guess_filename, get_auth_from_url, requote_uri,
-    stream_decode_response_unicode, to_key_val_list, parse_header_links,
-    iter_slices, guess_json_utf, super_len, check_header_validity)
+from .auth import HTTPBasicAuth
 from .compat import (
-    Callable, Mapping,
-    cookielib, urlunparse, urlsplit, urlencode, str, bytes,
-    is_py2, chardet, builtin_str, basestring)
+    Callable,
+    JSONDecodeError,
+    Mapping,
+    basestring,
+    builtin_str,
+    chardet,
+    cookielib,
+)
 from .compat import json as complexjson
+from .compat import urlencode, urlsplit, urlunparse
+from .cookies import _copy_cookie_jar, cookiejar_from_dict, get_cookie_header
+from .exceptions import (
+    ChunkedEncodingError,
+    ConnectionError,
+    ContentDecodingError,
+    HTTPError,
+    InvalidJSONError,
+    InvalidURL,
+)
+from .exceptions import JSONDecodeError as RequestsJSONDecodeError
+from .exceptions import MissingSchema
+from .exceptions import SSLError as RequestsSSLError
+from .exceptions import StreamConsumedError
+from .hooks import default_hooks
 from .status_codes import codes
+from .structures import CaseInsensitiveDict
+from .utils import (
+    check_header_validity,
+    get_auth_from_url,
+    guess_filename,
+    guess_json_utf,
+    iter_slices,
+    parse_header_links,
+    requote_uri,
+    stream_decode_response_unicode,
+    super_len,
+    to_key_val_list,
+)
 
 #: The set of HTTP status codes that indicate an automatically
 #: processable redirect.
 REDIRECT_STATI = (
-    codes.moved,               # 301
-    codes.found,               # 302
-    codes.other,               # 303
+    codes.moved,  # 301
+    codes.found,  # 302
+    codes.other,  # 303
     codes.temporary_redirect,  # 307
     codes.permanent_redirect,  # 308
 )
@@ -57,7 +81,7 @@ CONTENT_CHUNK_SIZE = 10 * 1024
 ITER_CHUNK_SIZE = 512
 
 
-class RequestEncodingMixin(object):
+class RequestEncodingMixin:
     @property
     def path_url(self):
         """Build the path URL to use."""
@@ -68,16 +92,16 @@ class RequestEncodingMixin(object):
 
         path = p.path
         if not path:
-            path = '/'
+            path = "/"
 
         url.append(path)
 
         query = p.query
         if query:
-            url.append('?')
+            url.append("?")
             url.append(query)
 
-        return ''.join(url)
+        return "".join(url)
 
     @staticmethod
     def _encode_params(data):
@@ -90,18 +114,21 @@ class RequestEncodingMixin(object):
 
         if isinstance(data, (str, bytes)):
             return data
-        elif hasattr(data, 'read'):
+        elif hasattr(data, "read"):
             return data
-        elif hasattr(data, '__iter__'):
+        elif hasattr(data, "__iter__"):
             result = []
             for k, vs in to_key_val_list(data):
-                if isinstance(vs, basestring) or not hasattr(vs, '__iter__'):
+                if isinstance(vs, basestring) or not hasattr(vs, "__iter__"):
                     vs = [vs]
                 for v in vs:
                     if v is not None:
                         result.append(
-                            (k.encode('utf-8') if isinstance(k, str) else k,
-                             v.encode('utf-8') if isinstance(v, str) else v))
+                            (
+                                k.encode("utf-8") if isinstance(k, str) else k,
+                                v.encode("utf-8") if isinstance(v, str) else v,
+                            )
+                        )
             return urlencode(result, doseq=True)
         else:
             return data
@@ -116,7 +143,7 @@ class RequestEncodingMixin(object):
         The tuples may be 2-tuples (filename, fileobj), 3-tuples (filename, fileobj, contentype)
         or 4-tuples (filename, fileobj, contentype, custom_headers).
         """
-        if (not files):
+        if not files:
             raise ValueError("Files must be provided.")
         elif isinstance(data, basestring):
             raise ValueError("Data must not be a string.")
@@ -126,7 +153,7 @@ class RequestEncodingMixin(object):
         files = to_key_val_list(files or {})
 
         for field, val in fields:
-            if isinstance(val, basestring) or not hasattr(val, '__iter__'):
+            if isinstance(val, basestring) or not hasattr(val, "__iter__"):
                 val = [val]
             for v in val:
                 if v is not None:
@@ -135,8 +162,13 @@ class RequestEncodingMixin(object):
                         v = str(v)
 
                     new_fields.append(
-                        (field.decode('utf-8') if isinstance(field, bytes) else field,
-                         v.encode('utf-8') if isinstance(v, str) else v))
+                        (
+                            field.decode("utf-8")
+                            if isinstance(field, bytes)
+                            else field,
+                            v.encode("utf-8") if isinstance(v, str) else v,
+                        )
+                    )
 
         for (k, v) in files:
             # support for explicit filename
@@ -155,7 +187,7 @@ class RequestEncodingMixin(object):
 
             if isinstance(fp, (str, bytes, bytearray)):
                 fdata = fp
-            elif hasattr(fp, 'read'):
+            elif hasattr(fp, "read"):
                 fdata = fp.read()
             elif fp is None:
                 continue
@@ -171,16 +203,16 @@ class RequestEncodingMixin(object):
         return body, content_type
 
 
-class RequestHooksMixin(object):
+class RequestHooksMixin:
     def register_hook(self, event, hook):
         """Properly register a hook."""
 
         if event not in self.hooks:
-            raise ValueError('Unsupported event specified, with event name "%s"' % (event))
+            raise ValueError(f'Unsupported event specified, with event name "{event}"')
 
         if isinstance(hook, Callable):
             self.hooks[event].append(hook)
-        elif hasattr(hook, '__iter__'):
+        elif hasattr(hook, "__iter__"):
             self.hooks[event].extend(h for h in hook if isinstance(h, Callable))
 
     def deregister_hook(self, event, hook):
@@ -223,9 +255,19 @@ class Request(RequestHooksMixin):
       <PreparedRequest [GET]>
     """
 
-    def __init__(self,
-            method=None, url=None, headers=None, files=None, data=None,
-            params=None, auth=None, cookies=None, hooks=None, json=None):
+    def __init__(
+        self,
+        method=None,
+        url=None,
+        headers=None,
+        files=None,
+        data=None,
+        params=None,
+        auth=None,
+        cookies=None,
+        hooks=None,
+        json=None,
+    ):
 
         # Default empty dicts for dict params.
         data = [] if data is None else data
@@ -249,7 +291,7 @@ class Request(RequestHooksMixin):
         self.cookies = cookies
 
     def __repr__(self):
-        return '<Request [%s]>' % (self.method)
+        return f"<Request [{self.method}]>"
 
     def prepare(self):
         """Constructs a :class:`PreparedRequest <PreparedRequest>` for transmission and returns it."""
@@ -307,9 +349,19 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         #: integer denoting starting position of a readable file-like body.
         self._body_position = None
 
-    def prepare(self,
-            method=None, url=None, headers=None, files=None, data=None,
-            params=None, auth=None, cookies=None, hooks=None, json=None):
+    def prepare(
+        self,
+        method=None,
+        url=None,
+        headers=None,
+        files=None,
+        data=None,
+        params=None,
+        auth=None,
+        cookies=None,
+        hooks=None,
+        json=None,
+    ):
         """Prepares the entire request with the given parameters."""
 
         self.prepare_method(method)
@@ -326,7 +378,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         self.prepare_hooks(hooks)
 
     def __repr__(self):
-        return '<PreparedRequest [%s]>' % (self.method)
+        return f"<PreparedRequest [{self.method}]>"
 
     def copy(self):
         p = PreparedRequest()
@@ -350,7 +402,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         from pip._vendor import idna
 
         try:
-            host = idna.encode(host, uts46=True).decode('utf-8')
+            host = idna.encode(host, uts46=True).decode("utf-8")
         except idna.IDNAError:
             raise UnicodeError
         return host
@@ -363,9 +415,9 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         #: on python 3.x.
         #: https://github.com/psf/requests/pull/2238
         if isinstance(url, bytes):
-            url = url.decode('utf8')
+            url = url.decode("utf8")
         else:
-            url = unicode(url) if is_py2 else str(url)
+            url = str(url)
 
         # Remove leading whitespaces from url
         url = url.lstrip()
@@ -373,7 +425,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         # Don't do any URL preparation for non-HTTP schemes like `mailto`,
         # `data` etc to work around exceptions from `url_parse`, which
         # handles RFC 3986 only.
-        if ':' in url and not url.lower().startswith('http'):
+        if ":" in url and not url.lower().startswith("http"):
             self.url = url
             return
 
@@ -384,13 +436,13 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
             raise InvalidURL(*e.args)
 
         if not scheme:
-            error = ("Invalid URL {0!r}: No schema supplied. Perhaps you meant http://{0}?")
-            error = error.format(to_native_string(url, 'utf8'))
-
-            raise MissingSchema(error)
+            raise MissingSchema(
+                f"Invalid URL {url!r}: No scheme supplied. "
+                f"Perhaps you meant https://{url}?"
+            )
 
         if not host:
-            raise InvalidURL("Invalid URL %r: No host supplied" % url)
+            raise InvalidURL(f"Invalid URL {url!r}: No host supplied")
 
         # In general, we want to try IDNA encoding the hostname if the string contains
         # non-ASCII characters. This allows users to automatically get the correct IDNA
@@ -400,33 +452,21 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
             try:
                 host = self._get_idna_encoded_host(host)
             except UnicodeError:
-                raise InvalidURL('URL has an invalid label.')
-        elif host.startswith(u'*'):
-            raise InvalidURL('URL has an invalid label.')
+                raise InvalidURL("URL has an invalid label.")
+        elif host.startswith(("*", ".")):
+            raise InvalidURL("URL has an invalid label.")
 
         # Carefully reconstruct the network location
-        netloc = auth or ''
+        netloc = auth or ""
         if netloc:
-            netloc += '@'
+            netloc += "@"
         netloc += host
         if port:
-            netloc += ':' + str(port)
+            netloc += f":{port}"
 
         # Bare domains aren't valid URLs.
         if not path:
-            path = '/'
-
-        if is_py2:
-            if isinstance(scheme, str):
-                scheme = scheme.encode('utf-8')
-            if isinstance(netloc, str):
-                netloc = netloc.encode('utf-8')
-            if isinstance(path, str):
-                path = path.encode('utf-8')
-            if isinstance(query, str):
-                query = query.encode('utf-8')
-            if isinstance(fragment, str):
-                fragment = fragment.encode('utf-8')
+            path = "/"
 
         if isinstance(params, (str, bytes)):
             params = to_native_string(params)
@@ -434,7 +474,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         enc_params = self._encode_params(params)
         if enc_params:
             if query:
-                query = '%s&%s' % (query, enc_params)
+                query = f"{query}&{enc_params}"
             else:
                 query = enc_params
 
@@ -465,15 +505,22 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
         if not data and json is not None:
             # urllib3 requires a bytes-like body. Python 2's json.dumps
             # provides this natively, but Python 3 gives a Unicode string.
-            content_type = 'application/json'
-            body = complexjson.dumps(json)
+            content_type = "application/json"
+
+            try:
+                body = complexjson.dumps(json, allow_nan=False)
+            except ValueError as ve:
+                raise InvalidJSONError(ve, request=self)
+
             if not isinstance(body, bytes):
-                body = body.encode('utf-8')
+                body = body.encode("utf-8")
 
-        is_stream = all([
-            hasattr(data, '__iter__'),
-            not isinstance(data, (basestring, list, tuple, Mapping))
-        ])
+        is_stream = all(
+            [
+                hasattr(data, "__iter__"),
+                not isinstance(data, (basestring, list, tuple, Mapping)),
+            ]
+        )
 
         if is_stream:
             try:
@@ -483,24 +530,26 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
 
             body = data
 
-            if getattr(body, 'tell', None) is not None:
+            if getattr(body, "tell", None) is not None:
                 # Record the current file position before reading.
                 # This will allow us to rewind a file in the event
                 # of a redirect.
                 try:
                     self._body_position = body.tell()
-                except (IOError, OSError):
+                except OSError:
                     # This differentiates from None, allowing us to catch
                     # a failed `tell()` later when trying to rewind the body
                     self._body_position = object()
 
             if files:
-                raise NotImplementedError('Streamed bodies and files are mutually exclusive.')
+                raise NotImplementedError(
+                    "Streamed bodies and files are mutually exclusive."
+                )
 
             if length:
-                self.headers['Content-Length'] = builtin_str(length)
+                self.headers["Content-Length"] = builtin_str(length)
             else:
-                self.headers['Transfer-Encoding'] = 'chunked'
+                self.headers["Transfer-Encoding"] = "chunked"
         else:
             # Multi-part file uploads.
             if files:
@@ -508,16 +557,16 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
             else:
                 if data:
                     body = self._encode_params(data)
-                    if isinstance(data, basestring) or hasattr(data, 'read'):
+                    if isinstance(data, basestring) or hasattr(data, "read"):
                         content_type = None
                     else:
-                        content_type = 'application/x-www-form-urlencoded'
+                        content_type = "application/x-www-form-urlencoded"
 
             self.prepare_content_length(body)
 
             # Add content-type if it wasn't explicitly provided.
-            if content_type and ('content-type' not in self.headers):
-                self.headers['Content-Type'] = content_type
+            if content_type and ("content-type" not in self.headers):
+                self.headers["Content-Type"] = content_type
 
         self.body = body
 
@@ -528,13 +577,16 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
             if length:
                 # If length exists, set it. Otherwise, we fallback
                 # to Transfer-Encoding: chunked.
-                self.headers['Content-Length'] = builtin_str(length)
-        elif self.method not in ('GET', 'HEAD') and self.headers.get('Content-Length') is None:
+                self.headers["Content-Length"] = builtin_str(length)
+        elif (
+            self.method not in ("GET", "HEAD")
+            and self.headers.get("Content-Length") is None
+        ):
             # Set Content-Length to 0 for methods that can have a body
             # but don't provide one. (i.e. not GET or HEAD)
-            self.headers['Content-Length'] = '0'
+            self.headers["Content-Length"] = "0"
 
-    def prepare_auth(self, auth, url=''):
+    def prepare_auth(self, auth, url=""):
         """Prepares the given HTTP auth data."""
 
         # If no Auth is explicitly provided, extract it from the URL first.
@@ -574,7 +626,7 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
 
         cookie_header = get_cookie_header(self._cookies, self)
         if cookie_header is not None:
-            self.headers['Cookie'] = cookie_header
+            self.headers["Cookie"] = cookie_header
 
     def prepare_hooks(self, hooks):
         """Prepares the given hooks."""
@@ -586,14 +638,22 @@ class PreparedRequest(RequestEncodingMixin, RequestHooksMixin):
             self.register_hook(event, hooks[event])
 
 
-class Response(object):
+class Response:
     """The :class:`Response <Response>` object, which contains a
     server's response to an HTTP request.
     """
 
     __attrs__ = [
-        '_content', 'status_code', 'headers', 'url', 'history',
-        'encoding', 'reason', 'cookies', 'elapsed', 'request'
+        "_content",
+        "status_code",
+        "headers",
+        "url",
+        "history",
+        "encoding",
+        "reason",
+        "cookies",
+        "elapsed",
+        "request",
     ]
 
     def __init__(self):
@@ -662,11 +722,11 @@ class Response(object):
             setattr(self, name, value)
 
         # pickled objects do not have .raw
-        setattr(self, '_content_consumed', True)
-        setattr(self, 'raw', None)
+        setattr(self, "_content_consumed", True)
+        setattr(self, "raw", None)
 
     def __repr__(self):
-        return '<Response [%s]>' % (self.status_code)
+        return f"<Response [{self.status_code}]>"
 
     def __bool__(self):
         """Returns True if :attr:`status_code` is less than 400.
@@ -712,12 +772,15 @@ class Response(object):
         """True if this Response is a well-formed HTTP redirect that could have
         been processed automatically (by :meth:`Session.resolve_redirects`).
         """
-        return ('location' in self.headers and self.status_code in REDIRECT_STATI)
+        return "location" in self.headers and self.status_code in REDIRECT_STATI
 
     @property
     def is_permanent_redirect(self):
         """True if this Response one of the permanent versions of redirect."""
-        return ('location' in self.headers and self.status_code in (codes.moved_permanently, codes.permanent_redirect))
+        return "location" in self.headers and self.status_code in (
+            codes.moved_permanently,
+            codes.permanent_redirect,
+        )
 
     @property
     def next(self):
@@ -726,8 +789,8 @@ class Response(object):
 
     @property
     def apparent_encoding(self):
-        """The apparent encoding, provided by the chardet library."""
-        return chardet.detect(self.content)['encoding']
+        """The apparent encoding, provided by the charset_normalizer or chardet libraries."""
+        return chardet.detect(self.content)["encoding"]
 
     def iter_content(self, chunk_size=1, decode_unicode=False):
         """Iterates over the response data.  When stream=True is set on the
@@ -748,16 +811,17 @@ class Response(object):
 
         def generate():
             # Special case for urllib3.
-            if hasattr(self.raw, 'stream'):
+            if hasattr(self.raw, "stream"):
                 try:
-                    for chunk in self.raw.stream(chunk_size, decode_content=True):
-                        yield chunk
+                    yield from self.raw.stream(chunk_size, decode_content=True)
                 except ProtocolError as e:
                     raise ChunkedEncodingError(e)
                 except DecodeError as e:
                     raise ContentDecodingError(e)
                 except ReadTimeoutError as e:
                     raise ConnectionError(e)
+                except SSLError as e:
+                    raise RequestsSSLError(e)
             else:
                 # Standard file-like object.
                 while True:
@@ -771,7 +835,9 @@ class Response(object):
         if self._content_consumed and isinstance(self._content, bool):
             raise StreamConsumedError()
         elif chunk_size is not None and not isinstance(chunk_size, int):
-            raise TypeError("chunk_size must be an int, it is instead a %s." % type(chunk_size))
+            raise TypeError(
+                f"chunk_size must be an int, it is instead a {type(chunk_size)}."
+            )
         # simulate reading small chunks of the content
         reused_chunks = iter_slices(self._content, chunk_size)
 
@@ -784,7 +850,9 @@ class Response(object):
 
         return chunks
 
-    def iter_lines(self, chunk_size=ITER_CHUNK_SIZE, decode_unicode=False, delimiter=None):
+    def iter_lines(
+        self, chunk_size=ITER_CHUNK_SIZE, decode_unicode=False, delimiter=None
+    ):
         """Iterates over the response data, one line at a time.  When
         stream=True is set on the request, this avoids reading the
         content at once into memory for large responses.
@@ -794,7 +862,9 @@ class Response(object):
 
         pending = None
 
-        for chunk in self.iter_content(chunk_size=chunk_size, decode_unicode=decode_unicode):
+        for chunk in self.iter_content(
+            chunk_size=chunk_size, decode_unicode=decode_unicode
+        ):
 
             if pending is not None:
                 chunk = pending + chunk
@@ -809,8 +879,7 @@ class Response(object):
             else:
                 pending = None
 
-            for line in lines:
-                yield line
+            yield from lines
 
         if pending is not None:
             yield pending
@@ -822,13 +891,12 @@ class Response(object):
         if self._content is False:
             # Read the contents.
             if self._content_consumed:
-                raise RuntimeError(
-                    'The content for this response was already consumed')
+                raise RuntimeError("The content for this response was already consumed")
 
             if self.status_code == 0 or self.raw is None:
                 self._content = None
             else:
-                self._content = b''.join(self.iter_content(CONTENT_CHUNK_SIZE)) or b''
+                self._content = b"".join(self.iter_content(CONTENT_CHUNK_SIZE)) or b""
 
         self._content_consumed = True
         # don't need to release the connection; that's been handled by urllib3
@@ -840,7 +908,7 @@ class Response(object):
         """Content of the response, in unicode.
 
         If Response.encoding is None, encoding will be guessed using
-        ``chardet``.
+        ``charset_normalizer`` or ``chardet``.
 
         The encoding of the response content is determined based solely on HTTP
         headers, following RFC 2616 to the letter. If you can take advantage of
@@ -853,7 +921,7 @@ class Response(object):
         encoding = self.encoding
 
         if not self.content:
-            return str('')
+            return ""
 
         # Fallback to auto-detected encoding.
         if self.encoding is None:
@@ -861,7 +929,7 @@ class Response(object):
 
         # Decode unicode from given encoding.
         try:
-            content = str(self.content, encoding, errors='replace')
+            content = str(self.content, encoding, errors="replace")
         except (LookupError, TypeError):
             # A LookupError is raised if the encoding was not found which could
             # indicate a misspelling or similar mistake.
@@ -869,7 +937,7 @@ class Response(object):
             # A TypeError can be raised if encoding is None
             #
             # So we try blindly encoding.
-            content = str(self.content, errors='replace')
+            content = str(self.content, errors="replace")
 
         return content
 
@@ -877,67 +945,77 @@ class Response(object):
         r"""Returns the json-encoded content of a response, if any.
 
         :param \*\*kwargs: Optional arguments that ``json.loads`` takes.
-        :raises ValueError: If the response body does not contain valid json.
+        :raises requests.exceptions.JSONDecodeError: If the response body does not
+            contain valid json.
         """
 
         if not self.encoding and self.content and len(self.content) > 3:
             # No encoding set. JSON RFC 4627 section 3 states we should expect
             # UTF-8, -16 or -32. Detect which one to use; If the detection or
-            # decoding fails, fall back to `self.text` (using chardet to make
+            # decoding fails, fall back to `self.text` (using charset_normalizer to make
             # a best guess).
             encoding = guess_json_utf(self.content)
             if encoding is not None:
                 try:
-                    return complexjson.loads(
-                        self.content.decode(encoding), **kwargs
-                    )
+                    return complexjson.loads(self.content.decode(encoding), **kwargs)
                 except UnicodeDecodeError:
                     # Wrong UTF codec detected; usually because it's not UTF-8
                     # but some other 8-bit codec.  This is an RFC violation,
                     # and the server didn't bother to tell us what codec *was*
                     # used.
                     pass
-        return complexjson.loads(self.text, **kwargs)
+                except JSONDecodeError as e:
+                    raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)
+
+        try:
+            return complexjson.loads(self.text, **kwargs)
+        except JSONDecodeError as e:
+            # Catch JSON-related errors and raise as requests.JSONDecodeError
+            # This aliases json.JSONDecodeError and simplejson.JSONDecodeError
+            raise RequestsJSONDecodeError(e.msg, e.doc, e.pos)
 
     @property
     def links(self):
         """Returns the parsed header links of the response, if any."""
 
-        header = self.headers.get('link')
+        header = self.headers.get("link")
 
-        # l = MultiDict()
-        l = {}
+        resolved_links = {}
 
         if header:
             links = parse_header_links(header)
 
             for link in links:
-                key = link.get('rel') or link.get('url')
-                l[key] = link
+                key = link.get("rel") or link.get("url")
+                resolved_links[key] = link
 
-        return l
+        return resolved_links
 
     def raise_for_status(self):
         """Raises :class:`HTTPError`, if one occurred."""
 
-        http_error_msg = ''
+        http_error_msg = ""
         if isinstance(self.reason, bytes):
             # We attempt to decode utf-8 first because some servers
             # choose to localize their reason strings. If the string
             # isn't utf-8, we fall back to iso-8859-1 for all other
             # encodings. (See PR #3538)
             try:
-                reason = self.reason.decode('utf-8')
+                reason = self.reason.decode("utf-8")
             except UnicodeDecodeError:
-                reason = self.reason.decode('iso-8859-1')
+                reason = self.reason.decode("iso-8859-1")
         else:
             reason = self.reason
 
         if 400 <= self.status_code < 500:
-            http_error_msg = u'%s Client Error: %s for url: %s' % (self.status_code, reason, self.url)
+            http_error_msg = (
+                f"{self.status_code} Client Error: {reason} for url: {self.url}"
+            )
 
         elif 500 <= self.status_code < 600:
-            http_error_msg = u'%s Server Error: %s for url: %s' % (self.status_code, reason, self.url)
+            http_error_msg = (
+                f"{self.status_code} Server Error: {reason} for url: {self.url}"
+            )
 
         if http_error_msg:
             raise HTTPError(http_error_msg, response=self)
@@ -951,6 +1029,6 @@ class Response(object):
         if not self._content_consumed:
             self.raw.close()
 
-        release_conn = getattr(self.raw, 'release_conn', None)
+        release_conn = getattr(self.raw, "release_conn", None)
         if release_conn is not None:
             release_conn()
diff --git a/env/Lib/site-packages/pip/_vendor/requests/sessions.py b/env/Lib/site-packages/pip/_vendor/requests/sessions.py
index 45ab8a5d..dbcf2a7b 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/sessions.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/sessions.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.sessions
 ~~~~~~~~~~~~~~~~~
@@ -10,39 +8,52 @@ requests (cookies, auth, proxies).
 import os
 import sys
 import time
-from datetime import timedelta
 from collections import OrderedDict
+from datetime import timedelta
 
+from ._internal_utils import to_native_string
+from .adapters import HTTPAdapter
 from .auth import _basic_auth_str
-from .compat import cookielib, is_py3, urljoin, urlparse, Mapping
+from .compat import Mapping, cookielib, urljoin, urlparse
 from .cookies import (
-    cookiejar_from_dict, extract_cookies_to_jar, RequestsCookieJar, merge_cookies)
-from .models import Request, PreparedRequest, DEFAULT_REDIRECT_LIMIT
-from .hooks import default_hooks, dispatch_hook
-from ._internal_utils import to_native_string
-from .utils import to_key_val_list, default_headers, DEFAULT_PORTS
+    RequestsCookieJar,
+    cookiejar_from_dict,
+    extract_cookies_to_jar,
+    merge_cookies,
+)
 from .exceptions import (
-    TooManyRedirects, InvalidSchema, ChunkedEncodingError, ContentDecodingError)
-
-from .structures import CaseInsensitiveDict
-from .adapters import HTTPAdapter
-
-from .utils import (
-    requote_uri, get_environ_proxies, get_netrc_auth, should_bypass_proxies,
-    get_auth_from_url, rewind_body
+    ChunkedEncodingError,
+    ContentDecodingError,
+    InvalidSchema,
+    TooManyRedirects,
 )
-
-from .status_codes import codes
+from .hooks import default_hooks, dispatch_hook
 
 # formerly defined here, reexposed here for backward compatibility
-from .models import REDIRECT_STATI
+from .models import (  # noqa: F401
+    DEFAULT_REDIRECT_LIMIT,
+    REDIRECT_STATI,
+    PreparedRequest,
+    Request,
+)
+from .status_codes import codes
+from .structures import CaseInsensitiveDict
+from .utils import (  # noqa: F401
+    DEFAULT_PORTS,
+    default_headers,
+    get_auth_from_url,
+    get_environ_proxies,
+    get_netrc_auth,
+    requote_uri,
+    resolve_proxies,
+    rewind_body,
+    should_bypass_proxies,
+    to_key_val_list,
+)
 
 # Preferred clock, based on which one is more accurate on a given system.
-if sys.platform == 'win32':
-    try:  # Python 3.4+
-        preferred_clock = time.perf_counter
-    except AttributeError:  # Earlier than Python 3.
-        preferred_clock = time.clock
+if sys.platform == "win32":
+    preferred_clock = time.perf_counter
 else:
     preferred_clock = time.time
 
@@ -61,8 +72,7 @@ def merge_setting(request_setting, session_setting, dict_class=OrderedDict):
 
     # Bypass if not a dictionary (e.g. verify)
     if not (
-            isinstance(session_setting, Mapping) and
-            isinstance(request_setting, Mapping)
+        isinstance(session_setting, Mapping) and isinstance(request_setting, Mapping)
     ):
         return request_setting
 
@@ -84,17 +94,16 @@ def merge_hooks(request_hooks, session_hooks, dict_class=OrderedDict):
     This is necessary because when request_hooks == {'response': []}, the
     merge breaks Session hooks entirely.
     """
-    if session_hooks is None or session_hooks.get('response') == []:
+    if session_hooks is None or session_hooks.get("response") == []:
         return request_hooks
 
-    if request_hooks is None or request_hooks.get('response') == []:
+    if request_hooks is None or request_hooks.get("response") == []:
         return session_hooks
 
     return merge_setting(request_hooks, session_hooks, dict_class)
 
 
-class SessionRedirectMixin(object):
-
+class SessionRedirectMixin:
     def get_redirect_target(self, resp):
         """Receives a Response. Returns a redirect URI or ``None``"""
         # Due to the nature of how requests processes redirects this method will
@@ -104,16 +113,15 @@ class SessionRedirectMixin(object):
         # to cache the redirect location onto the response object as a private
         # attribute.
         if resp.is_redirect:
-            location = resp.headers['location']
+            location = resp.headers["location"]
             # Currently the underlying http module on py3 decode headers
             # in latin1, but empirical evidence suggests that latin1 is very
             # rarely used with non-ASCII characters in HTTP headers.
             # It is more likely to get UTF8 header rather than latin1.
             # This causes incorrect handling of UTF8 encoded location headers.
             # To solve this, we re-encode the location in latin1.
-            if is_py3:
-                location = location.encode('latin1')
-            return to_native_string(location, 'utf8')
+            location = location.encode("latin1")
+            return to_native_string(location, "utf8")
         return None
 
     def should_strip_auth(self, old_url, new_url):
@@ -126,23 +134,40 @@ class SessionRedirectMixin(object):
         # ports. This isn't specified by RFC 7235, but is kept to avoid
         # breaking backwards compatibility with older versions of requests
         # that allowed any redirects on the same host.
-        if (old_parsed.scheme == 'http' and old_parsed.port in (80, None)
-                and new_parsed.scheme == 'https' and new_parsed.port in (443, None)):
+        if (
+            old_parsed.scheme == "http"
+            and old_parsed.port in (80, None)
+            and new_parsed.scheme == "https"
+            and new_parsed.port in (443, None)
+        ):
             return False
 
         # Handle default port usage corresponding to scheme.
         changed_port = old_parsed.port != new_parsed.port
         changed_scheme = old_parsed.scheme != new_parsed.scheme
         default_port = (DEFAULT_PORTS.get(old_parsed.scheme, None), None)
-        if (not changed_scheme and old_parsed.port in default_port
-                and new_parsed.port in default_port):
+        if (
+            not changed_scheme
+            and old_parsed.port in default_port
+            and new_parsed.port in default_port
+        ):
             return False
 
         # Standard case: root URI must match
         return changed_port or changed_scheme
 
-    def resolve_redirects(self, resp, req, stream=False, timeout=None,
-                          verify=True, cert=None, proxies=None, yield_requests=False, **adapter_kwargs):
+    def resolve_redirects(
+        self,
+        resp,
+        req,
+        stream=False,
+        timeout=None,
+        verify=True,
+        cert=None,
+        proxies=None,
+        yield_requests=False,
+        **adapter_kwargs,
+    ):
         """Receives a Response. Returns a generator of Responses or Requests."""
 
         hist = []  # keep track of history
@@ -163,19 +188,21 @@ class SessionRedirectMixin(object):
                 resp.raw.read(decode_content=False)
 
             if len(resp.history) >= self.max_redirects:
-                raise TooManyRedirects('Exceeded {} redirects.'.format(self.max_redirects), response=resp)
+                raise TooManyRedirects(
+                    f"Exceeded {self.max_redirects} redirects.", response=resp
+                )
 
             # Release the connection back into the pool.
             resp.close()
 
             # Handle redirection without scheme (see: RFC 1808 Section 4)
-            if url.startswith('//'):
+            if url.startswith("//"):
                 parsed_rurl = urlparse(resp.url)
-                url = ':'.join([to_native_string(parsed_rurl.scheme), url])
+                url = ":".join([to_native_string(parsed_rurl.scheme), url])
 
             # Normalize url case and attach previous fragment if needed (RFC 7231 7.1.2)
             parsed = urlparse(url)
-            if parsed.fragment == '' and previous_fragment:
+            if parsed.fragment == "" and previous_fragment:
                 parsed = parsed._replace(fragment=previous_fragment)
             elif parsed.fragment:
                 previous_fragment = parsed.fragment
@@ -194,15 +221,18 @@ class SessionRedirectMixin(object):
             self.rebuild_method(prepared_request, resp)
 
             # https://github.com/psf/requests/issues/1084
-            if resp.status_code not in (codes.temporary_redirect, codes.permanent_redirect):
+            if resp.status_code not in (
+                codes.temporary_redirect,
+                codes.permanent_redirect,
+            ):
                 # https://github.com/psf/requests/issues/3490
-                purged_headers = ('Content-Length', 'Content-Type', 'Transfer-Encoding')
+                purged_headers = ("Content-Length", "Content-Type", "Transfer-Encoding")
                 for header in purged_headers:
                     prepared_request.headers.pop(header, None)
                 prepared_request.body = None
 
             headers = prepared_request.headers
-            headers.pop('Cookie', None)
+            headers.pop("Cookie", None)
 
             # Extract any cookies sent on the response to the cookiejar
             # in the new request. Because we've mutated our copied prepared
@@ -218,9 +248,8 @@ class SessionRedirectMixin(object):
             # A failed tell() sets `_body_position` to `object()`. This non-None
             # value ensures `rewindable` will be True, allowing us to raise an
             # UnrewindableBodyError, instead of hanging the connection.
-            rewindable = (
-                prepared_request._body_position is not None and
-                ('Content-Length' in headers or 'Transfer-Encoding' in headers)
+            rewindable = prepared_request._body_position is not None and (
+                "Content-Length" in headers or "Transfer-Encoding" in headers
             )
 
             # Attempt to rewind consumed file-like object.
@@ -242,7 +271,7 @@ class SessionRedirectMixin(object):
                     cert=cert,
                     proxies=proxies,
                     allow_redirects=False,
-                    **adapter_kwargs
+                    **adapter_kwargs,
                 )
 
                 extract_cookies_to_jar(self.cookies, prepared_request, resp.raw)
@@ -259,17 +288,18 @@ class SessionRedirectMixin(object):
         headers = prepared_request.headers
         url = prepared_request.url
 
-        if 'Authorization' in headers and self.should_strip_auth(response.request.url, url):
+        if "Authorization" in headers and self.should_strip_auth(
+            response.request.url, url
+        ):
             # If we get redirected to a new host, we should strip out any
             # authentication headers.
-            del headers['Authorization']
+            del headers["Authorization"]
 
         # .netrc might have more auth for us on our new host.
         new_auth = get_netrc_auth(url) if self.trust_env else None
         if new_auth is not None:
             prepared_request.prepare_auth(new_auth)
 
-
     def rebuild_proxies(self, prepared_request, proxies):
         """This method re-evaluates the proxy configuration by considering the
         environment variables. If we are redirected to a URL covered by
@@ -282,32 +312,22 @@ class SessionRedirectMixin(object):
 
         :rtype: dict
         """
-        proxies = proxies if proxies is not None else {}
         headers = prepared_request.headers
-        url = prepared_request.url
-        scheme = urlparse(url).scheme
-        new_proxies = proxies.copy()
-        no_proxy = proxies.get('no_proxy')
+        scheme = urlparse(prepared_request.url).scheme
+        new_proxies = resolve_proxies(prepared_request, proxies, self.trust_env)
 
-        bypass_proxy = should_bypass_proxies(url, no_proxy=no_proxy)
-        if self.trust_env and not bypass_proxy:
-            environ_proxies = get_environ_proxies(url, no_proxy=no_proxy)
-
-            proxy = environ_proxies.get(scheme, environ_proxies.get('all'))
-
-            if proxy:
-                new_proxies.setdefault(scheme, proxy)
-
-        if 'Proxy-Authorization' in headers:
-            del headers['Proxy-Authorization']
+        if "Proxy-Authorization" in headers:
+            del headers["Proxy-Authorization"]
 
         try:
             username, password = get_auth_from_url(new_proxies[scheme])
         except KeyError:
             username, password = None, None
 
-        if username and password:
-            headers['Proxy-Authorization'] = _basic_auth_str(username, password)
+        # urllib3 handles proxy authorization for us in the standard adapter.
+        # Avoid appending this to TLS tunneled requests where it may be leaked.
+        if not scheme.startswith('https') and username and password:
+            headers["Proxy-Authorization"] = _basic_auth_str(username, password)
 
         return new_proxies
 
@@ -318,18 +338,18 @@ class SessionRedirectMixin(object):
         method = prepared_request.method
 
         # https://tools.ietf.org/html/rfc7231#section-6.4.4
-        if response.status_code == codes.see_other and method != 'HEAD':
-            method = 'GET'
+        if response.status_code == codes.see_other and method != "HEAD":
+            method = "GET"
 
         # Do what the browsers do, despite standards...
         # First, turn 302s into GETs.
-        if response.status_code == codes.found and method != 'HEAD':
-            method = 'GET'
+        if response.status_code == codes.found and method != "HEAD":
+            method = "GET"
 
         # Second, if a POST is responded to with a 301, turn it into a GET.
         # This bizarre behaviour is explained in Issue 1704.
-        if response.status_code == codes.moved and method == 'POST':
-            method = 'GET'
+        if response.status_code == codes.moved and method == "POST":
+            method = "GET"
 
         prepared_request.method = method
 
@@ -354,9 +374,18 @@ class Session(SessionRedirectMixin):
     """
 
     __attrs__ = [
-        'headers', 'cookies', 'auth', 'proxies', 'hooks', 'params', 'verify',
-        'cert', 'adapters', 'stream', 'trust_env',
-        'max_redirects',
+        "headers",
+        "cookies",
+        "auth",
+        "proxies",
+        "hooks",
+        "params",
+        "verify",
+        "cert",
+        "adapters",
+        "stream",
+        "trust_env",
+        "max_redirects",
     ]
 
     def __init__(self):
@@ -418,8 +447,8 @@ class Session(SessionRedirectMixin):
 
         # Default connection adapters.
         self.adapters = OrderedDict()
-        self.mount('https://', HTTPAdapter())
-        self.mount('http://', HTTPAdapter())
+        self.mount("https://", HTTPAdapter())
+        self.mount("http://", HTTPAdapter())
 
     def __enter__(self):
         return self
@@ -445,7 +474,8 @@ class Session(SessionRedirectMixin):
 
         # Merge with session cookies
         merged_cookies = merge_cookies(
-            merge_cookies(RequestsCookieJar(), self.cookies), cookies)
+            merge_cookies(RequestsCookieJar(), self.cookies), cookies
+        )
 
         # Set environment's basic authentication if not explicitly set.
         auth = request.auth
@@ -459,7 +489,9 @@ class Session(SessionRedirectMixin):
             files=request.files,
             data=request.data,
             json=request.json,
-            headers=merge_setting(request.headers, self.headers, dict_class=CaseInsensitiveDict),
+            headers=merge_setting(
+                request.headers, self.headers, dict_class=CaseInsensitiveDict
+            ),
             params=merge_setting(request.params, self.params),
             auth=merge_setting(auth, self.auth),
             cookies=merged_cookies,
@@ -467,10 +499,25 @@ class Session(SessionRedirectMixin):
         )
         return p
 
-    def request(self, method, url,
-            params=None, data=None, headers=None, cookies=None, files=None,
-            auth=None, timeout=None, allow_redirects=True, proxies=None,
-            hooks=None, stream=None, verify=None, cert=None, json=None):
+    def request(
+        self,
+        method,
+        url,
+        params=None,
+        data=None,
+        headers=None,
+        cookies=None,
+        files=None,
+        auth=None,
+        timeout=None,
+        allow_redirects=True,
+        proxies=None,
+        hooks=None,
+        stream=None,
+        verify=None,
+        cert=None,
+        json=None,
+    ):
         """Constructs a :class:`Request <Request>`, prepares it and sends it.
         Returns :class:`Response <Response>` object.
 
@@ -506,7 +553,7 @@ class Session(SessionRedirectMixin):
             ``False``, requests will accept any TLS certificate presented by
             the server, and will ignore hostname mismatches and/or expired
             certificates, which will make your application vulnerable to
-            man-in-the-middle (MitM) attacks. Setting verify to ``False`` 
+            man-in-the-middle (MitM) attacks. Setting verify to ``False``
             may be useful during local development or testing.
         :param cert: (optional) if String, path to ssl client cert file (.pem).
             If Tuple, ('cert', 'key') pair.
@@ -535,8 +582,8 @@ class Session(SessionRedirectMixin):
 
         # Send the request.
         send_kwargs = {
-            'timeout': timeout,
-            'allow_redirects': allow_redirects,
+            "timeout": timeout,
+            "allow_redirects": allow_redirects,
         }
         send_kwargs.update(settings)
         resp = self.send(prep, **send_kwargs)
@@ -551,8 +598,8 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        kwargs.setdefault('allow_redirects', True)
-        return self.request('GET', url, **kwargs)
+        kwargs.setdefault("allow_redirects", True)
+        return self.request("GET", url, **kwargs)
 
     def options(self, url, **kwargs):
         r"""Sends a OPTIONS request. Returns :class:`Response` object.
@@ -562,8 +609,8 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        kwargs.setdefault('allow_redirects', True)
-        return self.request('OPTIONS', url, **kwargs)
+        kwargs.setdefault("allow_redirects", True)
+        return self.request("OPTIONS", url, **kwargs)
 
     def head(self, url, **kwargs):
         r"""Sends a HEAD request. Returns :class:`Response` object.
@@ -573,8 +620,8 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        kwargs.setdefault('allow_redirects', False)
-        return self.request('HEAD', url, **kwargs)
+        kwargs.setdefault("allow_redirects", False)
+        return self.request("HEAD", url, **kwargs)
 
     def post(self, url, data=None, json=None, **kwargs):
         r"""Sends a POST request. Returns :class:`Response` object.
@@ -587,7 +634,7 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        return self.request('POST', url, data=data, json=json, **kwargs)
+        return self.request("POST", url, data=data, json=json, **kwargs)
 
     def put(self, url, data=None, **kwargs):
         r"""Sends a PUT request. Returns :class:`Response` object.
@@ -599,7 +646,7 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        return self.request('PUT', url, data=data, **kwargs)
+        return self.request("PUT", url, data=data, **kwargs)
 
     def patch(self, url, data=None, **kwargs):
         r"""Sends a PATCH request. Returns :class:`Response` object.
@@ -611,7 +658,7 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        return self.request('PATCH', url, data=data, **kwargs)
+        return self.request("PATCH", url, data=data, **kwargs)
 
     def delete(self, url, **kwargs):
         r"""Sends a DELETE request. Returns :class:`Response` object.
@@ -621,7 +668,7 @@ class Session(SessionRedirectMixin):
         :rtype: requests.Response
         """
 
-        return self.request('DELETE', url, **kwargs)
+        return self.request("DELETE", url, **kwargs)
 
     def send(self, request, **kwargs):
         """Send a given PreparedRequest.
@@ -630,19 +677,20 @@ class Session(SessionRedirectMixin):
         """
         # Set defaults that the hooks can utilize to ensure they always have
         # the correct parameters to reproduce the previous request.
-        kwargs.setdefault('stream', self.stream)
-        kwargs.setdefault('verify', self.verify)
-        kwargs.setdefault('cert', self.cert)
-        kwargs.setdefault('proxies', self.proxies)
+        kwargs.setdefault("stream", self.stream)
+        kwargs.setdefault("verify", self.verify)
+        kwargs.setdefault("cert", self.cert)
+        if "proxies" not in kwargs:
+            kwargs["proxies"] = resolve_proxies(request, self.proxies, self.trust_env)
 
         # It's possible that users might accidentally send a Request object.
         # Guard against that specific failure case.
         if isinstance(request, Request):
-            raise ValueError('You can only send PreparedRequests.')
+            raise ValueError("You can only send PreparedRequests.")
 
         # Set up variables needed for resolve_redirects and dispatching of hooks
-        allow_redirects = kwargs.pop('allow_redirects', True)
-        stream = kwargs.get('stream')
+        allow_redirects = kwargs.pop("allow_redirects", True)
+        stream = kwargs.get("stream")
         hooks = request.hooks
 
         # Get the appropriate adapter to use
@@ -659,7 +707,7 @@ class Session(SessionRedirectMixin):
         r.elapsed = timedelta(seconds=elapsed)
 
         # Response manipulation hooks
-        r = dispatch_hook('response', hooks, r, **kwargs)
+        r = dispatch_hook("response", hooks, r, **kwargs)
 
         # Persist cookies
         if r.history:
@@ -689,7 +737,9 @@ class Session(SessionRedirectMixin):
         # If redirects aren't being followed, store the response on the Request for Response.next().
         if not allow_redirects:
             try:
-                r._next = next(self.resolve_redirects(r, request, yield_requests=True, **kwargs))
+                r._next = next(
+                    self.resolve_redirects(r, request, yield_requests=True, **kwargs)
+                )
             except StopIteration:
                 pass
 
@@ -707,16 +757,19 @@ class Session(SessionRedirectMixin):
         # Gather clues from the surrounding environment.
         if self.trust_env:
             # Set environment's proxies.
-            no_proxy = proxies.get('no_proxy') if proxies is not None else None
+            no_proxy = proxies.get("no_proxy") if proxies is not None else None
             env_proxies = get_environ_proxies(url, no_proxy=no_proxy)
             for (k, v) in env_proxies.items():
                 proxies.setdefault(k, v)
 
-            # Look for requests environment configuration and be compatible
-            # with cURL.
+            # Look for requests environment configuration
+            # and be compatible with cURL.
             if verify is True or verify is None:
-                verify = (os.environ.get('REQUESTS_CA_BUNDLE') or
-                          os.environ.get('CURL_CA_BUNDLE'))
+                verify = (
+                    os.environ.get("REQUESTS_CA_BUNDLE")
+                    or os.environ.get("CURL_CA_BUNDLE")
+                    or verify
+                )
 
         # Merge all the kwargs.
         proxies = merge_setting(proxies, self.proxies)
@@ -724,8 +777,7 @@ class Session(SessionRedirectMixin):
         verify = merge_setting(verify, self.verify)
         cert = merge_setting(cert, self.cert)
 
-        return {'verify': verify, 'proxies': proxies, 'stream': stream,
-                'cert': cert}
+        return {"proxies": proxies, "stream": stream, "verify": verify, "cert": cert}
 
     def get_adapter(self, url):
         """
@@ -739,7 +791,7 @@ class Session(SessionRedirectMixin):
                 return adapter
 
         # Nothing matches :-/
-        raise InvalidSchema("No connection adapters were found for {!r}".format(url))
+        raise InvalidSchema(f"No connection adapters were found for {url!r}")
 
     def close(self):
         """Closes all adapters and as such the session"""
diff --git a/env/Lib/site-packages/pip/_vendor/requests/status_codes.py b/env/Lib/site-packages/pip/_vendor/requests/status_codes.py
index d80a7cd4..4bd072be 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/status_codes.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/status_codes.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 r"""
 The ``codes`` object defines a mapping from common names for HTTP statuses
 to their numerical codes, accessible either as attributes or as dictionary
@@ -23,101 +21,108 @@ the names are allowed. For example, ``codes.ok``, ``codes.OK``, and
 from .structures import LookupDict
 
 _codes = {
-
     # Informational.
-    100: ('continue',),
-    101: ('switching_protocols',),
-    102: ('processing',),
-    103: ('checkpoint',),
-    122: ('uri_too_long', 'request_uri_too_long'),
-    200: ('ok', 'okay', 'all_ok', 'all_okay', 'all_good', '\\o/', '✓'),
-    201: ('created',),
-    202: ('accepted',),
-    203: ('non_authoritative_info', 'non_authoritative_information'),
-    204: ('no_content',),
-    205: ('reset_content', 'reset'),
-    206: ('partial_content', 'partial'),
-    207: ('multi_status', 'multiple_status', 'multi_stati', 'multiple_stati'),
-    208: ('already_reported',),
-    226: ('im_used',),
-
+    100: ("continue",),
+    101: ("switching_protocols",),
+    102: ("processing",),
+    103: ("checkpoint",),
+    122: ("uri_too_long", "request_uri_too_long"),
+    200: ("ok", "okay", "all_ok", "all_okay", "all_good", "\\o/", "✓"),
+    201: ("created",),
+    202: ("accepted",),
+    203: ("non_authoritative_info", "non_authoritative_information"),
+    204: ("no_content",),
+    205: ("reset_content", "reset"),
+    206: ("partial_content", "partial"),
+    207: ("multi_status", "multiple_status", "multi_stati", "multiple_stati"),
+    208: ("already_reported",),
+    226: ("im_used",),
     # Redirection.
-    300: ('multiple_choices',),
-    301: ('moved_permanently', 'moved', '\\o-'),
-    302: ('found',),
-    303: ('see_other', 'other'),
-    304: ('not_modified',),
-    305: ('use_proxy',),
-    306: ('switch_proxy',),
-    307: ('temporary_redirect', 'temporary_moved', 'temporary'),
-    308: ('permanent_redirect',
-          'resume_incomplete', 'resume',),  # These 2 to be removed in 3.0
-
+    300: ("multiple_choices",),
+    301: ("moved_permanently", "moved", "\\o-"),
+    302: ("found",),
+    303: ("see_other", "other"),
+    304: ("not_modified",),
+    305: ("use_proxy",),
+    306: ("switch_proxy",),
+    307: ("temporary_redirect", "temporary_moved", "temporary"),
+    308: (
+        "permanent_redirect",
+        "resume_incomplete",
+        "resume",
+    ),  # "resume" and "resume_incomplete" to be removed in 3.0
     # Client Error.
-    400: ('bad_request', 'bad'),
-    401: ('unauthorized',),
-    402: ('payment_required', 'payment'),
-    403: ('forbidden',),
-    404: ('not_found', '-o-'),
-    405: ('method_not_allowed', 'not_allowed'),
-    406: ('not_acceptable',),
-    407: ('proxy_authentication_required', 'proxy_auth', 'proxy_authentication'),
-    408: ('request_timeout', 'timeout'),
-    409: ('conflict',),
-    410: ('gone',),
-    411: ('length_required',),
-    412: ('precondition_failed', 'precondition'),
-    413: ('request_entity_too_large',),
-    414: ('request_uri_too_large',),
-    415: ('unsupported_media_type', 'unsupported_media', 'media_type'),
-    416: ('requested_range_not_satisfiable', 'requested_range', 'range_not_satisfiable'),
-    417: ('expectation_failed',),
-    418: ('im_a_teapot', 'teapot', 'i_am_a_teapot'),
-    421: ('misdirected_request',),
-    422: ('unprocessable_entity', 'unprocessable'),
-    423: ('locked',),
-    424: ('failed_dependency', 'dependency'),
-    425: ('unordered_collection', 'unordered'),
-    426: ('upgrade_required', 'upgrade'),
-    428: ('precondition_required', 'precondition'),
-    429: ('too_many_requests', 'too_many'),
-    431: ('header_fields_too_large', 'fields_too_large'),
-    444: ('no_response', 'none'),
-    449: ('retry_with', 'retry'),
-    450: ('blocked_by_windows_parental_controls', 'parental_controls'),
-    451: ('unavailable_for_legal_reasons', 'legal_reasons'),
-    499: ('client_closed_request',),
-
+    400: ("bad_request", "bad"),
+    401: ("unauthorized",),
+    402: ("payment_required", "payment"),
+    403: ("forbidden",),
+    404: ("not_found", "-o-"),
+    405: ("method_not_allowed", "not_allowed"),
+    406: ("not_acceptable",),
+    407: ("proxy_authentication_required", "proxy_auth", "proxy_authentication"),
+    408: ("request_timeout", "timeout"),
+    409: ("conflict",),
+    410: ("gone",),
+    411: ("length_required",),
+    412: ("precondition_failed", "precondition"),
+    413: ("request_entity_too_large",),
+    414: ("request_uri_too_large",),
+    415: ("unsupported_media_type", "unsupported_media", "media_type"),
+    416: (
+        "requested_range_not_satisfiable",
+        "requested_range",
+        "range_not_satisfiable",
+    ),
+    417: ("expectation_failed",),
+    418: ("im_a_teapot", "teapot", "i_am_a_teapot"),
+    421: ("misdirected_request",),
+    422: ("unprocessable_entity", "unprocessable"),
+    423: ("locked",),
+    424: ("failed_dependency", "dependency"),
+    425: ("unordered_collection", "unordered"),
+    426: ("upgrade_required", "upgrade"),
+    428: ("precondition_required", "precondition"),
+    429: ("too_many_requests", "too_many"),
+    431: ("header_fields_too_large", "fields_too_large"),
+    444: ("no_response", "none"),
+    449: ("retry_with", "retry"),
+    450: ("blocked_by_windows_parental_controls", "parental_controls"),
+    451: ("unavailable_for_legal_reasons", "legal_reasons"),
+    499: ("client_closed_request",),
     # Server Error.
-    500: ('internal_server_error', 'server_error', '/o\\', '✗'),
-    501: ('not_implemented',),
-    502: ('bad_gateway',),
-    503: ('service_unavailable', 'unavailable'),
-    504: ('gateway_timeout',),
-    505: ('http_version_not_supported', 'http_version'),
-    506: ('variant_also_negotiates',),
-    507: ('insufficient_storage',),
-    509: ('bandwidth_limit_exceeded', 'bandwidth'),
-    510: ('not_extended',),
-    511: ('network_authentication_required', 'network_auth', 'network_authentication'),
+    500: ("internal_server_error", "server_error", "/o\\", "✗"),
+    501: ("not_implemented",),
+    502: ("bad_gateway",),
+    503: ("service_unavailable", "unavailable"),
+    504: ("gateway_timeout",),
+    505: ("http_version_not_supported", "http_version"),
+    506: ("variant_also_negotiates",),
+    507: ("insufficient_storage",),
+    509: ("bandwidth_limit_exceeded", "bandwidth"),
+    510: ("not_extended",),
+    511: ("network_authentication_required", "network_auth", "network_authentication"),
 }
 
-codes = LookupDict(name='status_codes')
+codes = LookupDict(name="status_codes")
+
 
 def _init():
     for code, titles in _codes.items():
         for title in titles:
             setattr(codes, title, code)
-            if not title.startswith(('\\', '/')):
+            if not title.startswith(("\\", "/")):
                 setattr(codes, title.upper(), code)
 
     def doc(code):
-        names = ', '.join('``%s``' % n for n in _codes[code])
-        return '* %d: %s' % (code, names)
+        names = ", ".join(f"``{n}``" for n in _codes[code])
+        return "* %d: %s" % (code, names)
 
     global __doc__
-    __doc__ = (__doc__ + '\n' +
-               '\n'.join(doc(code) for code in sorted(_codes))
-               if __doc__ is not None else None)
+    __doc__ = (
+        __doc__ + "\n" + "\n".join(doc(code) for code in sorted(_codes))
+        if __doc__ is not None
+        else None
+    )
+
 
 _init()
diff --git a/env/Lib/site-packages/pip/_vendor/requests/structures.py b/env/Lib/site-packages/pip/_vendor/requests/structures.py
index 8ee0ba7a..188e13e4 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/structures.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/structures.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.structures
 ~~~~~~~~~~~~~~~~~~~
@@ -64,11 +62,7 @@ class CaseInsensitiveDict(MutableMapping):
 
     def lower_items(self):
         """Like iteritems(), but with all lowercase keys."""
-        return (
-            (lowerkey, keyval[1])
-            for (lowerkey, keyval)
-            in self._store.items()
-        )
+        return ((lowerkey, keyval[1]) for (lowerkey, keyval) in self._store.items())
 
     def __eq__(self, other):
         if isinstance(other, Mapping):
@@ -91,10 +85,10 @@ class LookupDict(dict):
 
     def __init__(self, name=None):
         self.name = name
-        super(LookupDict, self).__init__()
+        super().__init__()
 
     def __repr__(self):
-        return '<lookup \'%s\'>' % (self.name)
+        return f"<lookup '{self.name}'>"
 
     def __getitem__(self, key):
         # We allow fall-through here, so values default to None
diff --git a/env/Lib/site-packages/pip/_vendor/requests/utils.py b/env/Lib/site-packages/pip/_vendor/requests/utils.py
index db67938e..36607eda 100644
--- a/env/Lib/site-packages/pip/_vendor/requests/utils.py
+++ b/env/Lib/site-packages/pip/_vendor/requests/utils.py
@@ -1,5 +1,3 @@
-# -*- coding: utf-8 -*-
-
 """
 requests.utils
 ~~~~~~~~~~~~~~
@@ -21,49 +19,76 @@ import warnings
 import zipfile
 from collections import OrderedDict
 
-from .__version__ import __version__
+from pip._vendor.urllib3.util import make_headers, parse_url
+
 from . import certs
+from .__version__ import __version__
+
 # to_native_string is unused here, but imported here for backwards compatibility
-from ._internal_utils import to_native_string
+from ._internal_utils import (  # noqa: F401
+    _HEADER_VALIDATORS_BYTE,
+    _HEADER_VALIDATORS_STR,
+    HEADER_VALIDATORS,
+    to_native_string,
+)
+from .compat import (
+    Mapping,
+    basestring,
+    bytes,
+    getproxies,
+    getproxies_environment,
+    integer_types,
+)
 from .compat import parse_http_list as _parse_list_header
 from .compat import (
-    quote, urlparse, bytes, str, unquote, getproxies,
-    proxy_bypass, urlunparse, basestring, integer_types, is_py3,
-    proxy_bypass_environment, getproxies_environment, Mapping)
+    proxy_bypass,
+    proxy_bypass_environment,
+    quote,
+    str,
+    unquote,
+    urlparse,
+    urlunparse,
+)
 from .cookies import cookiejar_from_dict
-from .structures import CaseInsensitiveDict
 from .exceptions import (
-    InvalidURL, InvalidHeader, FileModeWarning, UnrewindableBodyError)
+    FileModeWarning,
+    InvalidHeader,
+    InvalidURL,
+    UnrewindableBodyError,
+)
+from .structures import CaseInsensitiveDict
 
-NETRC_FILES = ('.netrc', '_netrc')
+NETRC_FILES = (".netrc", "_netrc")
 
 DEFAULT_CA_BUNDLE_PATH = certs.where()
 
-DEFAULT_PORTS = {'http': 80, 'https': 443}
+DEFAULT_PORTS = {"http": 80, "https": 443}
+
+# Ensure that ', ' is used to preserve previous delimiter behavior.
+DEFAULT_ACCEPT_ENCODING = ", ".join(
+    re.split(r",\s*", make_headers(accept_encoding=True)["accept-encoding"])
+)
 
 
-if sys.platform == 'win32':
+if sys.platform == "win32":
     # provide a proxy_bypass version on Windows without DNS lookups
 
     def proxy_bypass_registry(host):
         try:
-            if is_py3:
-                import winreg
-            else:
-                import _winreg as winreg
+            import winreg
         except ImportError:
             return False
 
         try:
-            internetSettings = winreg.OpenKey(winreg.HKEY_CURRENT_USER,
-                r'Software\Microsoft\Windows\CurrentVersion\Internet Settings')
+            internetSettings = winreg.OpenKey(
+                winreg.HKEY_CURRENT_USER,
+                r"Software\Microsoft\Windows\CurrentVersion\Internet Settings",
+            )
             # ProxyEnable could be REG_SZ or REG_DWORD, normalizing it
-            proxyEnable = int(winreg.QueryValueEx(internetSettings,
-                                              'ProxyEnable')[0])
+            proxyEnable = int(winreg.QueryValueEx(internetSettings, "ProxyEnable")[0])
             # ProxyOverride is almost always a string
-            proxyOverride = winreg.QueryValueEx(internetSettings,
-                                                'ProxyOverride')[0]
-        except OSError:
+            proxyOverride = winreg.QueryValueEx(internetSettings, "ProxyOverride")[0]
+        except (OSError, ValueError):
             return False
         if not proxyEnable or not proxyOverride:
             return False
@@ -71,15 +96,15 @@ if sys.platform == 'win32':
         # make a check value list from the registry entry: replace the
         # '<local>' string by the localhost entry and the corresponding
         # canonical entry.
-        proxyOverride = proxyOverride.split(';')
+        proxyOverride = proxyOverride.split(";")
         # now check if we match one of the registry values.
         for test in proxyOverride:
-            if test == '<local>':
-                if '.' not in host:
+            if test == "<local>":
+                if "." not in host:
                     return True
-            test = test.replace(".", r"\.")     # mask dots
-            test = test.replace("*", r".*")     # change glob sequence
-            test = test.replace("?", r".")      # change glob char
+            test = test.replace(".", r"\.")  # mask dots
+            test = test.replace("*", r".*")  # change glob sequence
+            test = test.replace("?", r".")  # change glob char
             if re.match(test, host, re.I):
                 return True
         return False
@@ -99,7 +124,7 @@ if sys.platform == 'win32':
 def dict_to_sequence(d):
     """Returns an internal sequence dictionary update."""
 
-    if hasattr(d, 'items'):
+    if hasattr(d, "items"):
         d = d.items()
 
     return d
@@ -109,37 +134,42 @@ def super_len(o):
     total_length = None
     current_position = 0
 
-    if hasattr(o, '__len__'):
+    if hasattr(o, "__len__"):
         total_length = len(o)
 
-    elif hasattr(o, 'len'):
+    elif hasattr(o, "len"):
         total_length = o.len
 
-    elif hasattr(o, 'fileno'):
+    elif hasattr(o, "fileno"):
         try:
             fileno = o.fileno()
-        except io.UnsupportedOperation:
+        except (io.UnsupportedOperation, AttributeError):
+            # AttributeError is a surprising exception, seeing as how we've just checked
+            # that `hasattr(o, 'fileno')`.  It happens for objects obtained via
+            # `Tarfile.extractfile()`, per issue 5229.
             pass
         else:
             total_length = os.fstat(fileno).st_size
 
             # Having used fstat to determine the file length, we need to
             # confirm that this file was opened up in binary mode.
-            if 'b' not in o.mode:
-                warnings.warn((
-                    "Requests has determined the content-length for this "
-                    "request using the binary size of the file: however, the "
-                    "file has been opened in text mode (i.e. without the 'b' "
-                    "flag in the mode). This may lead to an incorrect "
-                    "content-length. In Requests 3.0, support will be removed "
-                    "for files in text mode."),
-                    FileModeWarning
+            if "b" not in o.mode:
+                warnings.warn(
+                    (
+                        "Requests has determined the content-length for this "
+                        "request using the binary size of the file: however, the "
+                        "file has been opened in text mode (i.e. without the 'b' "
+                        "flag in the mode). This may lead to an incorrect "
+                        "content-length. In Requests 3.0, support will be removed "
+                        "for files in text mode."
+                    ),
+                    FileModeWarning,
                 )
 
-    if hasattr(o, 'tell'):
+    if hasattr(o, "tell"):
         try:
             current_position = o.tell()
-        except (OSError, IOError):
+        except OSError:
             # This can happen in some weird situations, such as when the file
             # is actually a special file descriptor like stdin. In this
             # instance, we don't know what the length is, so set it to zero and
@@ -147,8 +177,8 @@ def super_len(o):
             if total_length is not None:
                 current_position = total_length
         else:
-            if hasattr(o, 'seek') and total_length is None:
-                # StringIO and BytesIO have seek but no useable fileno
+            if hasattr(o, "seek") and total_length is None:
+                # StringIO and BytesIO have seek but no usable fileno
                 try:
                     # seek to end of file
                     o.seek(0, 2)
@@ -157,7 +187,7 @@ def super_len(o):
                     # seek back to current position to support
                     # partially read file-like objects
                     o.seek(current_position or 0)
-                except (OSError, IOError):
+                except OSError:
                     total_length = 0
 
     if total_length is None:
@@ -169,14 +199,14 @@ def super_len(o):
 def get_netrc_auth(url, raise_errors=False):
     """Returns the Requests tuple auth for a given url from netrc."""
 
-    netrc_file = os.environ.get('NETRC')
+    netrc_file = os.environ.get("NETRC")
     if netrc_file is not None:
         netrc_locations = (netrc_file,)
     else:
-        netrc_locations = ('~/{}'.format(f) for f in NETRC_FILES)
+        netrc_locations = (f"~/{f}" for f in NETRC_FILES)
 
     try:
-        from netrc import netrc, NetrcParseError
+        from netrc import NetrcParseError, netrc
 
         netrc_path = None
 
@@ -201,18 +231,18 @@ def get_netrc_auth(url, raise_errors=False):
 
         # Strip port numbers from netloc. This weird `if...encode`` dance is
         # used for Python 3.2, which doesn't support unicode literals.
-        splitstr = b':'
+        splitstr = b":"
         if isinstance(url, str):
-            splitstr = splitstr.decode('ascii')
+            splitstr = splitstr.decode("ascii")
         host = ri.netloc.split(splitstr)[0]
 
         try:
             _netrc = netrc(netrc_path).authenticators(host)
             if _netrc:
                 # Return with login / password
-                login_i = (0 if _netrc[0] else 1)
+                login_i = 0 if _netrc[0] else 1
                 return (_netrc[login_i], _netrc[2])
-        except (NetrcParseError, IOError):
+        except (NetrcParseError, OSError):
             # If there was a parsing error or a permissions issue reading the file,
             # we'll just skip netrc auth unless explicitly asked to raise errors.
             if raise_errors:
@@ -225,9 +255,8 @@ def get_netrc_auth(url, raise_errors=False):
 
 def guess_filename(obj):
     """Tries to guess the filename of the given object."""
-    name = getattr(obj, 'name', None)
-    if (name and isinstance(name, basestring) and name[0] != '<' and
-            name[-1] != '>'):
+    name = getattr(obj, "name", None)
+    if name and isinstance(name, basestring) and name[0] != "<" and name[-1] != ">":
         return os.path.basename(name)
 
 
@@ -245,7 +274,11 @@ def extract_zipped_paths(path):
     archive, member = os.path.split(path)
     while archive and not os.path.exists(archive):
         archive, prefix = os.path.split(archive)
-        member = '/'.join([prefix, member])
+        if not prefix:
+            # If we don't check for an empty prefix after the split (in other words, archive remains unchanged after the split),
+            # we _can_ end up in an infinite loop on a rare corner case affecting a small number of users
+            break
+        member = "/".join([prefix, member])
 
     if not zipfile.is_zipfile(archive):
         return path
@@ -256,13 +289,27 @@ def extract_zipped_paths(path):
 
     # we have a valid zip archive and a valid member of that archive
     tmp = tempfile.gettempdir()
-    extracted_path = os.path.join(tmp, *member.split('/'))
+    extracted_path = os.path.join(tmp, member.split("/")[-1])
     if not os.path.exists(extracted_path):
-        extracted_path = zip_file.extract(member, path=tmp)
-
+        # use read + write to avoid the creating nested folders, we only want the file, avoids mkdir racing condition
+        with atomic_open(extracted_path) as file_handler:
+            file_handler.write(zip_file.read(member))
     return extracted_path
 
 
+@contextlib.contextmanager
+def atomic_open(filename):
+    """Write a file to the disk in an atomic fashion"""
+    tmp_descriptor, tmp_name = tempfile.mkstemp(dir=os.path.dirname(filename))
+    try:
+        with os.fdopen(tmp_descriptor, "wb") as tmp_handler:
+            yield tmp_handler
+        os.replace(tmp_name, filename)
+    except BaseException:
+        os.remove(tmp_name)
+        raise
+
+
 def from_key_val_list(value):
     """Take an object and test to see if it can be represented as a
     dictionary. Unless it can not be represented as such, return an
@@ -285,7 +332,7 @@ def from_key_val_list(value):
         return None
 
     if isinstance(value, (str, bytes, bool, int)):
-        raise ValueError('cannot encode objects that are not 2-tuples')
+        raise ValueError("cannot encode objects that are not 2-tuples")
 
     return OrderedDict(value)
 
@@ -311,7 +358,7 @@ def to_key_val_list(value):
         return None
 
     if isinstance(value, (str, bytes, bool, int)):
-        raise ValueError('cannot encode objects that are not 2-tuples')
+        raise ValueError("cannot encode objects that are not 2-tuples")
 
     if isinstance(value, Mapping):
         value = value.items()
@@ -376,10 +423,10 @@ def parse_dict_header(value):
     """
     result = {}
     for item in _parse_list_header(value):
-        if '=' not in item:
+        if "=" not in item:
             result[item] = None
             continue
-        name, value = item.split('=', 1)
+        name, value = item.split("=", 1)
         if value[:1] == value[-1:] == '"':
             value = unquote_header_value(value[1:-1])
         result[name] = value
@@ -407,8 +454,8 @@ def unquote_header_value(value, is_filename=False):
         # replace sequence below on a UNC path has the effect of turning
         # the leading double slash into a single slash and then
         # _fix_ie_filename() doesn't work correctly.  See #458.
-        if not is_filename or value[:2] != '\\\\':
-            return value.replace('\\\\', '\\').replace('\\"', '"')
+        if not is_filename or value[:2] != "\\\\":
+            return value.replace("\\\\", "\\").replace('\\"', '"')
     return value
 
 
@@ -443,19 +490,24 @@ def get_encodings_from_content(content):
 
     :param content: bytestring to extract encodings from.
     """
-    warnings.warn((
-        'In requests 3.0, get_encodings_from_content will be removed. For '
-        'more information, please see the discussion on issue #2266. (This'
-        ' warning should only appear once.)'),
-        DeprecationWarning)
+    warnings.warn(
+        (
+            "In requests 3.0, get_encodings_from_content will be removed. For "
+            "more information, please see the discussion on issue #2266. (This"
+            " warning should only appear once.)"
+        ),
+        DeprecationWarning,
+    )
 
     charset_re = re.compile(r'<meta.*?charset=["\']*(.+?)["\'>]', flags=re.I)
     pragma_re = re.compile(r'<meta.*?content=["\']*;?charset=(.+?)["\'>]', flags=re.I)
     xml_re = re.compile(r'^<\?xml.*?encoding=["\']*(.+?)["\'>]')
 
-    return (charset_re.findall(content) +
-            pragma_re.findall(content) +
-            xml_re.findall(content))
+    return (
+        charset_re.findall(content)
+        + pragma_re.findall(content)
+        + xml_re.findall(content)
+    )
 
 
 def _parse_content_type_header(header):
@@ -466,7 +518,7 @@ def _parse_content_type_header(header):
          parameters
     """
 
-    tokens = header.split(';')
+    tokens = header.split(";")
     content_type, params = tokens[0].strip(), tokens[1:]
     params_dict = {}
     items_to_strip = "\"' "
@@ -478,7 +530,7 @@ def _parse_content_type_header(header):
             index_of_equals = param.find("=")
             if index_of_equals != -1:
                 key = param[:index_of_equals].strip(items_to_strip)
-                value = param[index_of_equals + 1:].strip(items_to_strip)
+                value = param[index_of_equals + 1 :].strip(items_to_strip)
             params_dict[key.lower()] = value
     return content_type, params_dict
 
@@ -490,38 +542,37 @@ def get_encoding_from_headers(headers):
     :rtype: str
     """
 
-    content_type = headers.get('content-type')
+    content_type = headers.get("content-type")
 
     if not content_type:
         return None
 
     content_type, params = _parse_content_type_header(content_type)
 
-    if 'charset' in params:
-        return params['charset'].strip("'\"")
+    if "charset" in params:
+        return params["charset"].strip("'\"")
 
-    if 'text' in content_type:
-        return 'ISO-8859-1'
+    if "text" in content_type:
+        return "ISO-8859-1"
 
-    if 'application/json' in content_type:
+    if "application/json" in content_type:
         # Assume UTF-8 based on RFC 4627: https://www.ietf.org/rfc/rfc4627.txt since the charset was unset
-        return 'utf-8'
+        return "utf-8"
 
 
 def stream_decode_response_unicode(iterator, r):
-    """Stream decodes a iterator."""
+    """Stream decodes an iterator."""
 
     if r.encoding is None:
-        for item in iterator:
-            yield item
+        yield from iterator
         return
 
-    decoder = codecs.getincrementaldecoder(r.encoding)(errors='replace')
+    decoder = codecs.getincrementaldecoder(r.encoding)(errors="replace")
     for chunk in iterator:
         rv = decoder.decode(chunk)
         if rv:
             yield rv
-    rv = decoder.decode(b'', final=True)
+    rv = decoder.decode(b"", final=True)
     if rv:
         yield rv
 
@@ -532,7 +583,7 @@ def iter_slices(string, slice_length):
     if slice_length is None or slice_length <= 0:
         slice_length = len(string)
     while pos < len(string):
-        yield string[pos:pos + slice_length]
+        yield string[pos : pos + slice_length]
         pos += slice_length
 
 
@@ -548,11 +599,14 @@ def get_unicode_from_response(r):
 
     :rtype: str
     """
-    warnings.warn((
-        'In requests 3.0, get_unicode_from_response will be removed. For '
-        'more information, please see the discussion on issue #2266. (This'
-        ' warning should only appear once.)'),
-        DeprecationWarning)
+    warnings.warn(
+        (
+            "In requests 3.0, get_unicode_from_response will be removed. For "
+            "more information, please see the discussion on issue #2266. (This"
+            " warning should only appear once.)"
+        ),
+        DeprecationWarning,
+    )
 
     tried_encodings = []
 
@@ -567,14 +621,15 @@ def get_unicode_from_response(r):
 
     # Fall back:
     try:
-        return str(r.content, encoding, errors='replace')
+        return str(r.content, encoding, errors="replace")
     except TypeError:
         return r.content
 
 
 # The unreserved URI characters (RFC 3986)
 UNRESERVED_SET = frozenset(
-    "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~")
+    "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz" + "0123456789-._~"
+)
 
 
 def unquote_unreserved(uri):
@@ -583,22 +638,22 @@ def unquote_unreserved(uri):
 
     :rtype: str
     """
-    parts = uri.split('%')
+    parts = uri.split("%")
     for i in range(1, len(parts)):
         h = parts[i][0:2]
         if len(h) == 2 and h.isalnum():
             try:
                 c = chr(int(h, 16))
             except ValueError:
-                raise InvalidURL("Invalid percent-escape sequence: '%s'" % h)
+                raise InvalidURL(f"Invalid percent-escape sequence: '{h}'")
 
             if c in UNRESERVED_SET:
                 parts[i] = c + parts[i][2:]
             else:
-                parts[i] = '%' + parts[i]
+                parts[i] = f"%{parts[i]}"
         else:
-            parts[i] = '%' + parts[i]
-    return ''.join(parts)
+            parts[i] = f"%{parts[i]}"
+    return "".join(parts)
 
 
 def requote_uri(uri):
@@ -631,10 +686,10 @@ def address_in_network(ip, net):
 
     :rtype: bool
     """
-    ipaddr = struct.unpack('=L', socket.inet_aton(ip))[0]
-    netaddr, bits = net.split('/')
-    netmask = struct.unpack('=L', socket.inet_aton(dotted_netmask(int(bits))))[0]
-    network = struct.unpack('=L', socket.inet_aton(netaddr))[0] & netmask
+    ipaddr = struct.unpack("=L", socket.inet_aton(ip))[0]
+    netaddr, bits = net.split("/")
+    netmask = struct.unpack("=L", socket.inet_aton(dotted_netmask(int(bits))))[0]
+    network = struct.unpack("=L", socket.inet_aton(netaddr))[0] & netmask
     return (ipaddr & netmask) == (network & netmask)
 
 
@@ -645,8 +700,8 @@ def dotted_netmask(mask):
 
     :rtype: str
     """
-    bits = 0xffffffff ^ (1 << 32 - mask) - 1
-    return socket.inet_ntoa(struct.pack('>I', bits))
+    bits = 0xFFFFFFFF ^ (1 << 32 - mask) - 1
+    return socket.inet_ntoa(struct.pack(">I", bits))
 
 
 def is_ipv4_address(string_ip):
@@ -655,7 +710,7 @@ def is_ipv4_address(string_ip):
     """
     try:
         socket.inet_aton(string_ip)
-    except socket.error:
+    except OSError:
         return False
     return True
 
@@ -666,9 +721,9 @@ def is_valid_cidr(string_network):
 
     :rtype: bool
     """
-    if string_network.count('/') == 1:
+    if string_network.count("/") == 1:
         try:
-            mask = int(string_network.split('/')[1])
+            mask = int(string_network.split("/")[1])
         except ValueError:
             return False
 
@@ -676,8 +731,8 @@ def is_valid_cidr(string_network):
             return False
 
         try:
-            socket.inet_aton(string_network.split('/')[0])
-        except socket.error:
+            socket.inet_aton(string_network.split("/")[0])
+        except OSError:
             return False
     else:
         return False
@@ -714,13 +769,14 @@ def should_bypass_proxies(url, no_proxy):
     """
     # Prioritize lowercase environment variables over uppercase
     # to keep a consistent behaviour with other http projects (curl, wget).
-    get_proxy = lambda k: os.environ.get(k) or os.environ.get(k.upper())
+    def get_proxy(key):
+        return os.environ.get(key) or os.environ.get(key.upper())
 
     # First check whether no_proxy is defined. If it is, check that the URL
     # we're getting isn't in the no_proxy list.
     no_proxy_arg = no_proxy
     if no_proxy is None:
-        no_proxy = get_proxy('no_proxy')
+        no_proxy = get_proxy("no_proxy")
     parsed = urlparse(url)
 
     if parsed.hostname is None:
@@ -730,9 +786,7 @@ def should_bypass_proxies(url, no_proxy):
     if no_proxy:
         # We need to check whether we match here. We need to see if we match
         # the end of the hostname, both with and without the port.
-        no_proxy = (
-            host for host in no_proxy.replace(' ', '').split(',') if host
-        )
+        no_proxy = (host for host in no_proxy.replace(" ", "").split(",") if host)
 
         if is_ipv4_address(parsed.hostname):
             for proxy_ip in no_proxy:
@@ -746,7 +800,7 @@ def should_bypass_proxies(url, no_proxy):
         else:
             host_with_port = parsed.hostname
             if parsed.port:
-                host_with_port += ':{}'.format(parsed.port)
+                host_with_port += f":{parsed.port}"
 
             for host in no_proxy:
                 if parsed.hostname.endswith(host) or host_with_port.endswith(host):
@@ -754,7 +808,7 @@ def should_bypass_proxies(url, no_proxy):
                     # to apply the proxies on this URL.
                     return True
 
-    with set_environ('no_proxy', no_proxy_arg):
+    with set_environ("no_proxy", no_proxy_arg):
         # parsed.hostname can be `None` in cases such as a file URI.
         try:
             bypass = proxy_bypass(parsed.hostname)
@@ -788,13 +842,13 @@ def select_proxy(url, proxies):
     proxies = proxies or {}
     urlparts = urlparse(url)
     if urlparts.hostname is None:
-        return proxies.get(urlparts.scheme, proxies.get('all'))
+        return proxies.get(urlparts.scheme, proxies.get("all"))
 
     proxy_keys = [
-        urlparts.scheme + '://' + urlparts.hostname,
+        urlparts.scheme + "://" + urlparts.hostname,
         urlparts.scheme,
-        'all://' + urlparts.hostname,
-        'all',
+        "all://" + urlparts.hostname,
+        "all",
     ]
     proxy = None
     for proxy_key in proxy_keys:
@@ -805,25 +859,54 @@ def select_proxy(url, proxies):
     return proxy
 
 
+def resolve_proxies(request, proxies, trust_env=True):
+    """This method takes proxy information from a request and configuration
+    input to resolve a mapping of target proxies. This will consider settings
+    such a NO_PROXY to strip proxy configurations.
+
+    :param request: Request or PreparedRequest
+    :param proxies: A dictionary of schemes or schemes and hosts to proxy URLs
+    :param trust_env: Boolean declaring whether to trust environment configs
+
+    :rtype: dict
+    """
+    proxies = proxies if proxies is not None else {}
+    url = request.url
+    scheme = urlparse(url).scheme
+    no_proxy = proxies.get("no_proxy")
+    new_proxies = proxies.copy()
+
+    if trust_env and not should_bypass_proxies(url, no_proxy=no_proxy):
+        environ_proxies = get_environ_proxies(url, no_proxy=no_proxy)
+
+        proxy = environ_proxies.get(scheme, environ_proxies.get("all"))
+
+        if proxy:
+            new_proxies.setdefault(scheme, proxy)
+    return new_proxies
+
+
 def default_user_agent(name="python-requests"):
     """
     Return a string representing the default user agent.
 
     :rtype: str
     """
-    return '%s/%s' % (name, __version__)
+    return f"{name}/{__version__}"
 
 
 def default_headers():
     """
     :rtype: requests.structures.CaseInsensitiveDict
     """
-    return CaseInsensitiveDict({
-        'User-Agent': default_user_agent(),
-        'Accept-Encoding': ', '.join(('gzip', 'deflate')),
-        'Accept': '*/*',
-        'Connection': 'keep-alive',
-    })
+    return CaseInsensitiveDict(
+        {
+            "User-Agent": default_user_agent(),
+            "Accept-Encoding": DEFAULT_ACCEPT_ENCODING,
+            "Accept": "*/*",
+            "Connection": "keep-alive",
+        }
+    )
 
 
 def parse_header_links(value):
@@ -836,23 +919,23 @@ def parse_header_links(value):
 
     links = []
 
-    replace_chars = ' \'"'
+    replace_chars = " '\""
 
     value = value.strip(replace_chars)
     if not value:
         return links
 
-    for val in re.split(', *<', value):
+    for val in re.split(", *<", value):
         try:
-            url, params = val.split(';', 1)
+            url, params = val.split(";", 1)
         except ValueError:
-            url, params = val, ''
+            url, params = val, ""
 
-        link = {'url': url.strip('<> \'"')}
+        link = {"url": url.strip("<> '\"")}
 
-        for param in params.split(';'):
+        for param in params.split(";"):
             try:
-                key, value = param.split('=')
+                key, value = param.split("=")
             except ValueError:
                 break
 
@@ -864,7 +947,7 @@ def parse_header_links(value):
 
 
 # Null bytes; no need to recreate these on each call to guess_json_utf
-_null = '\x00'.encode('ascii')  # encoding to ASCII for Python 3
+_null = "\x00".encode("ascii")  # encoding to ASCII for Python 3
 _null2 = _null * 2
 _null3 = _null * 3
 
@@ -878,25 +961,25 @@ def guess_json_utf(data):
     # determine the encoding. Also detect a BOM, if present.
     sample = data[:4]
     if sample in (codecs.BOM_UTF32_LE, codecs.BOM_UTF32_BE):
-        return 'utf-32'     # BOM included
+        return "utf-32"  # BOM included
     if sample[:3] == codecs.BOM_UTF8:
-        return 'utf-8-sig'  # BOM included, MS style (discouraged)
+        return "utf-8-sig"  # BOM included, MS style (discouraged)
     if sample[:2] in (codecs.BOM_UTF16_LE, codecs.BOM_UTF16_BE):
-        return 'utf-16'     # BOM included
+        return "utf-16"  # BOM included
     nullcount = sample.count(_null)
     if nullcount == 0:
-        return 'utf-8'
+        return "utf-8"
     if nullcount == 2:
-        if sample[::2] == _null2:   # 1st and 3rd are null
-            return 'utf-16-be'
+        if sample[::2] == _null2:  # 1st and 3rd are null
+            return "utf-16-be"
         if sample[1::2] == _null2:  # 2nd and 4th are null
-            return 'utf-16-le'
+            return "utf-16-le"
         # Did not detect 2 valid UTF-16 ascii-range characters
     if nullcount == 3:
         if sample[:3] == _null3:
-            return 'utf-32-be'
+            return "utf-32-be"
         if sample[1:] == _null3:
-            return 'utf-32-le'
+            return "utf-32-le"
         # Did not detect a valid UTF-32 ascii-range character
     return None
 
@@ -907,15 +990,27 @@ def prepend_scheme_if_needed(url, new_scheme):
 
     :rtype: str
     """
-    scheme, netloc, path, params, query, fragment = urlparse(url, new_scheme)
-
-    # urlparse is a finicky beast, and sometimes decides that there isn't a
-    # netloc present. Assume that it's being over-cautious, and switch netloc
-    # and path if urlparse decided there was no netloc.
+    parsed = parse_url(url)
+    scheme, auth, host, port, path, query, fragment = parsed
+
+    # A defect in urlparse determines that there isn't a netloc present in some
+    # urls. We previously assumed parsing was overly cautious, and swapped the
+    # netloc and path. Due to a lack of tests on the original defect, this is
+    # maintained with parse_url for backwards compatibility.
+    netloc = parsed.netloc
     if not netloc:
         netloc, path = path, netloc
 
-    return urlunparse((scheme, netloc, path, params, query, fragment))
+    if auth:
+        # parse_url doesn't provide the netloc with auth
+        # so we'll add it ourselves.
+        netloc = "@".join([auth, netloc])
+    if scheme is None:
+        scheme = new_scheme
+    if path is None:
+        path = ""
+
+    return urlunparse((scheme, netloc, path, "", query, fragment))
 
 
 def get_auth_from_url(url):
@@ -929,35 +1024,39 @@ def get_auth_from_url(url):
     try:
         auth = (unquote(parsed.username), unquote(parsed.password))
     except (AttributeError, TypeError):
-        auth = ('', '')
+        auth = ("", "")
 
     return auth
 
 
-# Moved outside of function to avoid recompile every call
-_CLEAN_HEADER_REGEX_BYTE = re.compile(b'^\\S[^\\r\\n]*$|^$')
-_CLEAN_HEADER_REGEX_STR = re.compile(r'^\S[^\r\n]*$|^$')
-
-
 def check_header_validity(header):
-    """Verifies that header value is a string which doesn't contain
-    leading whitespace or return characters. This prevents unintended
-    header injection.
+    """Verifies that header parts don't contain leading whitespace
+    reserved characters, or return characters.
 
     :param header: tuple, in the format (name, value).
     """
     name, value = header
+    _validate_header_part(header, name, 0)
+    _validate_header_part(header, value, 1)
 
-    if isinstance(value, bytes):
-        pat = _CLEAN_HEADER_REGEX_BYTE
+
+def _validate_header_part(header, header_part, header_validator_index):
+    if isinstance(header_part, str):
+        validator = _HEADER_VALIDATORS_STR[header_validator_index]
+    elif isinstance(header_part, bytes):
+        validator = _HEADER_VALIDATORS_BYTE[header_validator_index]
     else:
-        pat = _CLEAN_HEADER_REGEX_STR
-    try:
-        if not pat.match(value):
-            raise InvalidHeader("Invalid return character or leading space in header: %s" % name)
-    except TypeError:
-        raise InvalidHeader("Value for header {%s: %s} must be of type str or "
-                            "bytes, not %s" % (name, value, type(value)))
+        raise InvalidHeader(
+            f"Header part ({header_part!r}) from {header} "
+            f"must be of type str or bytes, not {type(header_part)}"
+        )
+
+    if not validator.match(header_part):
+        header_kind = "name" if header_validator_index == 0 else "value"
+        raise InvalidHeader(
+            f"Invalid leading whitespace, reserved character(s), or return"
+            f"character(s) in header {header_kind}: {header_part!r}"
+        )
 
 
 def urldefragauth(url):
@@ -972,21 +1071,24 @@ def urldefragauth(url):
     if not netloc:
         netloc, path = path, netloc
 
-    netloc = netloc.rsplit('@', 1)[-1]
+    netloc = netloc.rsplit("@", 1)[-1]
 
-    return urlunparse((scheme, netloc, path, params, query, ''))
+    return urlunparse((scheme, netloc, path, params, query, ""))
 
 
 def rewind_body(prepared_request):
     """Move file pointer back to its recorded starting position
     so it can be read again on redirect.
     """
-    body_seek = getattr(prepared_request.body, 'seek', None)
-    if body_seek is not None and isinstance(prepared_request._body_position, integer_types):
+    body_seek = getattr(prepared_request.body, "seek", None)
+    if body_seek is not None and isinstance(
+        prepared_request._body_position, integer_types
+    ):
         try:
             body_seek(prepared_request._body_position)
-        except (IOError, OSError):
-            raise UnrewindableBodyError("An error occurred when rewinding request "
-                                        "body for redirect.")
+        except OSError:
+            raise UnrewindableBodyError(
+                "An error occurred when rewinding request body for redirect."
+            )
     else:
         raise UnrewindableBodyError("Unable to rewind request body for redirect.")
diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py b/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py
index 184874d4..d92acc7b 100644
--- a/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/resolvelib/__init__.py
@@ -11,7 +11,7 @@ __all__ = [
     "ResolutionTooDeep",
 ]
 
-__version__ = "0.7.0"
+__version__ = "1.0.1"
 
 
 from .providers import AbstractProvider, AbstractResolver
@@ -19,8 +19,8 @@ from .reporters import BaseReporter
 from .resolvers import (
     InconsistentCandidate,
     RequirementsConflicted,
-    Resolver,
     ResolutionError,
     ResolutionImpossible,
     ResolutionTooDeep,
+    Resolver,
 )
diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 5a268e0cfff4e1eb6cafb28063ccd8e8d5d92873..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 634
zcmYe~<>g{vU|^UdaWGYqiGkrUh=Yuo7#J8F7#J9eeHa)R(iu`17BNOKq%cM?rZA;2
z=P>0mM=|HJM6ob3q%fth<gn(lMX`a|tU2tt98ny(oKc*)Tv1%P+)>=QJW)KkyivT2
z3@L2E44UkkT(`L6<I7TuiZk=`;^S`#I3^XB6eT8?1Qg|$Wu~MSAw+^wi}Q2JQj2c!
zI3*UR2Bj9{7nP(I-4gZ8OU}<L&MYoT%`0(E%uC5kNi0dd#Q|3?7L;08npu>Zo0?Zr
z?3|yMmXn!WlA3ahAFQIZBr`wHwWuh+=#~gVz%#cXzqmLvDJS)oAVM@GKi?%awV;aC
zK+jyy;3Xpi1A``05h!$um_cmDA{G$ER>aD{z)-{vBG^C#2Z-PV5ukAP)8xCw9v`2W
zlM^3b1Ty0mX93i+#R$W0aTY;+SPV85#E1C57{Bo=8HxlzR)L6L&CXUap~b01#WATl
zDVaqv{&}e`MVV!(3c3oRex6~jLBXCOj=>6^elGrguECy;F~P3BuE8O$K?-Iu0RcWS
zi6*)^`RSR(C7IbVsd;5FKAA}|#hE3kx&?{J*@@|?#W4k$1^V%2sd*{+MfydM7|O{^
o(vOeN%*!l^kJl@xyv1RYo1apelWGU@Y%wS>ICxo@1sHi40d9G*Z2$lO

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/providers.cpython-39.pyc
deleted file mode 100644
index 062c18f3b7919be73adeafc1122bddc10087f147..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/reporters.cpython-39.pyc
deleted file mode 100644
index a31d59288bba0543ec81a1c7891ef794f7a3dc2b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2330
zcmYe~<>g{vU|^UdaWFN6m4V?gh=Yt-7#J8F7#J9eMHm<u+!<0BQW#qpQW#Sinwg^*
zQ<#DoG?|l;)q~hfFg+d&3=F9ZQH&`JQA{a}QOqe!Da<VlQ7kDeDXc9FQLHI!DeNr_
zQEVw3DV!|~QS2#PDcmg#Q5-2eDZDKVQJg7!Df}%AQCukk!3>&$w|JZqi&KMA3-XIf
zQj4nWT~c#W(-TWl6_Rrji;ERX@)Zh-^2;()Qj0*0^rF<_Vud2G>dd@!g|z%4g_4X^
zg`(8r{G77XBE4irkXxY`#0Ft!kXJ!|PGJmY&}6F8bxzF5Nlj5mN=?fzN<|n@T9TQc
zr;wOjQks~PQ>jo~l2}wytmn6qL6h+oOL1yWS`jD^z{IZ>XRDad;?$zznADt<%%T|o
zyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<7k@w3U{A-GU{_z);1Jg!1+$od0H2sd6WyHr
z^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P#PrnSn1aj#{rIxfyp;SReW?F(GL!Tno=+_*
z)+?yI#Q}C>W?nkTcf}yrF)&t%B8R9ROhqzS78)`jHnxz7L=BnL#N-TxqWsdl6ovdW
zNFYPP2yAGv9v7Da6oh1?DrDxRq*f?o7AsVx7Uk<EB^IZq=)o2EfrCwxsfd|@f#DV_
zSS?rxLV(<Viw|sUW?p(c*iLp(w1Hg8z*r@X)lU$0$si-49%BHpvH9#Ikv>b!OF{Kl
zW--W1e*Pf}$&gf&nTDQXKzbAsOB6~nGK(R>rKb>DoT`wJnwOH9m!1F*gv>OB%KTD=
z^2EFnP|Aixr9xU}USdvWRU#<$=_wE!lFZ<cEMfx(XK_hlNh%~HK>=0-4o)73^^ic~
zMG8zwl)yw*MN}fuM-57N{(~e9a9|XdCMTyB7pIlx<W%aRM12tl0|NuPOW7c90F_3t
zL@bQOjl@KBVlN{D1Jr@#8L4>+i7B8sP)JnBOD$I@N-ZqSEK1Ey%_~vJ%qz)9#AI2j
zLUK`NNorAMB2u!pDo89!%th8_1&$z)p`hqW%t4j|#c5KiLSjKdPG)Kfh?ka`Q<7Q)
zkAF~R0R>lLSz=~RVp2}3LULkWN@hx8W=U!>BCkMgEl4a%%`1Ue2vt`CDy<SrV3rmu
zBqShtDIq~2u~;Dy#k!Q#g4Dc})V$<M9fkZN1;6~fRE5km41Jl!3Lu$$Xxh%tFF`Q{
z$&zA)g2dwD)D(rxJcYEP{9J{EgdkYy3oWKJG!qgKzJW$RB)#6^Ml$La8^nv~$w3Gd
zyr5D55nJL&$yXjFX<(`)DiNC@r;(!6tkmQZP=%5Ri;<F4g_P1FkWf-$a&}2kVsdt7
zUOF@_uY?w3obYHt_W}>HE=45AqvkziRYW=464}`huPY$C8JeUE@=H?lN-`636pHh6
z!1)sD@*+Mg*^j*-GcPYQFI@%6ogyfK3{~K#$$g6>K0YroH#I)~7FT?HZhlH>4v5VY
zA75CSm;;qzkB?8uPmYf-Vg=a-D#wdBK`c<KqzF_J6$ya2f*=B1ULgoj$yEd@z(Kee
zq>O`+g^7cigN=iogPDVigBdLAr^$4SEk6kqZD2l9_=C*?8FP!n2I4+DkXfHWH3R_M
ChG;DS

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/resolvers.cpython-39.pyc
deleted file mode 100644
index 9d6f161cfb869ef1558152154011fdc9211bdc48..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/__pycache__/structs.cpython-39.pyc
deleted file mode 100644
index 6025f29b6d2f876eeabfd334189507ebaadc5546..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 6948
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
WsCFp^iE}XVFbg;dNeajahyeh564Uem

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index f0977531d64d31c96761d816b28b8dd3c8bad8a0..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 229
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>T<S<
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk
zFVZhcEzZv=OU=nl(ofFMEl4cUkB`sH%PfhH*DI*J#bJ}1pHiBWY6o)TXOLe2C+t3?

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/resolvelib/compat/__pycache__/collections_abc.cpython-39.pyc
deleted file mode 100644
index 9f522103d7206be983e670eef634e210c2f0c811..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 403
zcmYe~<>g{vU|^UdaWHib0|Ucj5C<7^FfcGUFfcF_yD%^?q%fo~rZYt`REeZ8r7-6(
z<}yVw<uXSxGctrT<SDT*q_R}nF*1N4Se_LjAIXr%WWbQZ63n2<dW+pRv7jI`FZ~ur
zaB5*`YF={cOOTbCOht?g3=Bm~3=9l@nrye&<Kq)^a^mA}@h9i!<fJB-Waj4;>m?>7
zBb43Z_RKBFFDh{@D#|aq#f_wHB|{O&>0sj5L}#m*(Bjmh;+WK&l+2<S|GZR}qRg^X
z1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw
z)V#77pUk9~;>?m%-GapA?8Nlc;+TTW0{!^1)V!4ZBK@M&;{2Sl)SS#D{p9@Ig2WPi
lBzMIpCMD|?RNmsS$<0qG%}KQbdAS(mR1PL4MiE9HMgV7BY~TO@

diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py b/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py
index 4822d166..e99d87ee 100644
--- a/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py
+++ b/env/Lib/site-packages/pip/_vendor/resolvelib/providers.py
@@ -1,5 +1,5 @@
 class AbstractProvider(object):
-    """Delegate class to provide requirement interface for the resolver."""
+    """Delegate class to provide the required interface for the resolver."""
 
     def identify(self, requirement_or_candidate):
         """Given a requirement, return an identifier for it.
@@ -9,7 +9,14 @@ class AbstractProvider(object):
         """
         raise NotImplementedError
 
-    def get_preference(self, identifier, resolutions, candidates, information):
+    def get_preference(
+        self,
+        identifier,
+        resolutions,
+        candidates,
+        information,
+        backtrack_causes,
+    ):
         """Produce a sort key for given requirement based on preference.
 
         The preference is defined as "I think this requirement should be
@@ -17,23 +24,25 @@ class AbstractProvider(object):
         this group of arguments is.
 
         :param identifier: An identifier as returned by ``identify()``. This
-            identifies the dependency matches of which should be returned.
+            identifies the dependency matches which should be returned.
         :param resolutions: Mapping of candidates currently pinned by the
-            resolver. Each key is an identifier, and the value a candidate.
+            resolver. Each key is an identifier, and the value is a candidate.
             The candidate may conflict with requirements from ``information``.
         :param candidates: Mapping of each dependency's possible candidates.
             Each value is an iterator of candidates.
         :param information: Mapping of requirement information of each package.
             Each value is an iterator of *requirement information*.
+        :param backtrack_causes: Sequence of requirement information that were
+            the requirements that caused the resolver to most recently backtrack.
 
         A *requirement information* instance is a named tuple with two members:
 
         * ``requirement`` specifies a requirement contributing to the current
           list of candidates.
-        * ``parent`` specifies the candidate that provides (dependend on) the
+        * ``parent`` specifies the candidate that provides (depended on) the
           requirement, or ``None`` to indicate a root requirement.
 
-        The preference could depend on a various of issues, including (not
+        The preference could depend on various issues, including (not
         necessarily in this order):
 
         * Is this package pinned in the current resolution result?
@@ -52,7 +61,7 @@ class AbstractProvider(object):
         raise NotImplementedError
 
     def find_matches(self, identifier, requirements, incompatibilities):
-        """Find all possible candidates that satisfy given constraints.
+        """Find all possible candidates that satisfy the given constraints.
 
         :param identifier: An identifier as returned by ``identify()``. This
             identifies the dependency matches of which should be returned.
@@ -83,7 +92,7 @@ class AbstractProvider(object):
     def is_satisfied_by(self, requirement, candidate):
         """Whether the given requirement can be satisfied by a candidate.
 
-        The candidate is guarenteed to have been generated from the
+        The candidate is guaranteed to have been generated from the
         requirement.
 
         A boolean should be returned to indicate whether ``candidate`` is a
diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py b/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py
index 563489e1..688b5e10 100644
--- a/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py
+++ b/env/Lib/site-packages/pip/_vendor/resolvelib/reporters.py
@@ -30,7 +30,13 @@ class BaseReporter(object):
             requirements passed in from ``Resolver.resolve()``.
         """
 
-    def backtracking(self, candidate):
+    def resolving_conflicts(self, causes):
+        """Called when starting to attempt requirement conflict resolution.
+
+        :param causes: The information on the collision that caused the backtracking.
+        """
+
+    def rejecting_candidate(self, criterion, candidate):
         """Called when rejecting a candidate during backtracking."""
 
     def pinning(self, candidate):
diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py b/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py
index 99ee1051..2c3d0e30 100644
--- a/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py
+++ b/env/Lib/site-packages/pip/_vendor/resolvelib/resolvers.py
@@ -1,10 +1,10 @@
 import collections
+import itertools
 import operator
 
 from .providers import AbstractResolver
 from .structs import DirectedGraph, IteratorMapping, build_iter_view
 
-
 RequirementInformation = collections.namedtuple(
     "RequirementInformation", ["requirement", "parent"]
 )
@@ -99,7 +99,7 @@ class ResolutionTooDeep(ResolutionError):
 
 
 # Resolution state in a round.
-State = collections.namedtuple("State", "mapping criteria")
+State = collections.namedtuple("State", "mapping criteria backtrack_causes")
 
 
 class Resolution(object):
@@ -131,14 +131,15 @@ class Resolution(object):
         state = State(
             mapping=base.mapping.copy(),
             criteria=base.criteria.copy(),
+            backtrack_causes=base.backtrack_causes[:],
         )
         self._states.append(state)
 
-    def _merge_into_criterion(self, requirement, parent):
+    def _add_to_criteria(self, criteria, requirement, parent):
         self._r.adding_requirement(requirement=requirement, parent=parent)
 
         identifier = self._p.identify(requirement_or_candidate=requirement)
-        criterion = self.state.criteria.get(identifier)
+        criterion = criteria.get(identifier)
         if criterion:
             incompatibilities = list(criterion.incompatibilities)
         else:
@@ -147,12 +148,12 @@ class Resolution(object):
         matches = self._p.find_matches(
             identifier=identifier,
             requirements=IteratorMapping(
-                self.state.criteria,
+                criteria,
                 operator.methodcaller("iter_requirement"),
                 {identifier: [requirement]},
             ),
             incompatibilities=IteratorMapping(
-                self.state.criteria,
+                criteria,
                 operator.attrgetter("incompatibilities"),
                 {identifier: incompatibilities},
             ),
@@ -171,7 +172,32 @@ class Resolution(object):
         )
         if not criterion.candidates:
             raise RequirementsConflicted(criterion)
-        return identifier, criterion
+        criteria[identifier] = criterion
+
+    def _remove_information_from_criteria(self, criteria, parents):
+        """Remove information from parents of criteria.
+
+        Concretely, removes all values from each criterion's ``information``
+        field that have one of ``parents`` as provider of the requirement.
+
+        :param criteria: The criteria to update.
+        :param parents: Identifiers for which to remove information from all criteria.
+        """
+        if not parents:
+            return
+        for key, criterion in criteria.items():
+            criteria[key] = Criterion(
+                criterion.candidates,
+                [
+                    information
+                    for information in criterion.information
+                    if (
+                        information.parent is None
+                        or self._p.identify(information.parent) not in parents
+                    )
+                ],
+                criterion.incompatibilities,
+            )
 
     def _get_preference(self, name):
         return self._p.get_preference(
@@ -185,6 +211,7 @@ class Resolution(object):
                 self.state.criteria,
                 operator.attrgetter("information"),
             ),
+            backtrack_causes=self.state.backtrack_causes,
         )
 
     def _is_current_pin_satisfying(self, name, criterion):
@@ -197,11 +224,10 @@ class Resolution(object):
             for r in criterion.iter_requirement()
         )
 
-    def _get_criteria_to_update(self, candidate):
-        criteria = {}
-        for r in self._p.get_dependencies(candidate=candidate):
-            name, crit = self._merge_into_criterion(r, parent=candidate)
-            criteria[name] = crit
+    def _get_updated_criteria(self, candidate):
+        criteria = self.state.criteria.copy()
+        for requirement in self._p.get_dependencies(candidate=candidate):
+            self._add_to_criteria(criteria, requirement, parent=candidate)
         return criteria
 
     def _attempt_to_pin_criterion(self, name):
@@ -210,8 +236,9 @@ class Resolution(object):
         causes = []
         for candidate in criterion.candidates:
             try:
-                criteria = self._get_criteria_to_update(candidate)
+                criteria = self._get_updated_criteria(candidate)
             except RequirementsConflicted as e:
+                self._r.rejecting_candidate(e.criterion, candidate)
                 causes.append(e.criterion)
                 continue
 
@@ -226,12 +253,13 @@ class Resolution(object):
             if not satisfied:
                 raise InconsistentCandidate(candidate, criterion)
 
+            self._r.pinning(candidate=candidate)
+            self.state.criteria.update(criteria)
+
             # Put newly-pinned candidate at the end. This is essential because
             # backtracking looks at this mapping to get the last pin.
-            self._r.pinning(candidate=candidate)
             self.state.mapping.pop(name, None)
             self.state.mapping[name] = candidate
-            self.state.criteria.update(criteria)
 
             return []
 
@@ -239,8 +267,8 @@ class Resolution(object):
         # end, signal for backtracking.
         return causes
 
-    def _backtrack(self):
-        """Perform backtracking.
+    def _backjump(self, causes):
+        """Perform backjumping.
 
         When we enter here, the stack is like this::
 
@@ -256,22 +284,46 @@ class Resolution(object):
 
         Each iteration of the loop will:
 
-        1.  Discard Z.
-        2.  Discard Y but remember its incompatibility information gathered
+        1.  Identify Z. The incompatibility is not always caused by the latest
+            state. For example, given three requirements A, B and C, with
+            dependencies A1, B1 and C1, where A1 and B1 are incompatible: the
+            last state might be related to C, so we want to discard the
+            previous state.
+        2.  Discard Z.
+        3.  Discard Y but remember its incompatibility information gathered
             previously, and the failure we're dealing with right now.
-        3.  Push a new state Y' based on X, and apply the incompatibility
+        4.  Push a new state Y' based on X, and apply the incompatibility
             information from Y to Y'.
-        4a. If this causes Y' to conflict, we need to backtrack again. Make Y'
+        5a. If this causes Y' to conflict, we need to backtrack again. Make Y'
             the new Z and go back to step 2.
-        4b. If the incompatibilities apply cleanly, end backtracking.
+        5b. If the incompatibilities apply cleanly, end backtracking.
         """
+        incompatible_reqs = itertools.chain(
+            (c.parent for c in causes if c.parent is not None),
+            (c.requirement for c in causes),
+        )
+        incompatible_deps = {self._p.identify(r) for r in incompatible_reqs}
         while len(self._states) >= 3:
             # Remove the state that triggered backtracking.
             del self._states[-1]
 
-            # Retrieve the last candidate pin and known incompatibilities.
-            broken_state = self._states.pop()
-            name, candidate = broken_state.mapping.popitem()
+            # Ensure to backtrack to a state that caused the incompatibility
+            incompatible_state = False
+            while not incompatible_state:
+                # Retrieve the last candidate pin and known incompatibilities.
+                try:
+                    broken_state = self._states.pop()
+                    name, candidate = broken_state.mapping.popitem()
+                except (IndexError, KeyError):
+                    raise ResolutionImpossible(causes)
+                current_dependencies = {
+                    self._p.identify(d)
+                    for d in self._p.get_dependencies(candidate)
+                }
+                incompatible_state = not current_dependencies.isdisjoint(
+                    incompatible_deps
+                )
+
             incompatibilities_from_broken = [
                 (k, list(v.incompatibilities))
                 for k, v in broken_state.criteria.items()
@@ -280,8 +332,6 @@ class Resolution(object):
             # Also mark the newly known incompatibility.
             incompatibilities_from_broken.append((name, [candidate]))
 
-            self._r.backtracking(candidate=candidate)
-
             # Create a new state from the last known-to-work one, and apply
             # the previously gathered incompatibility information.
             def _patch_criteria():
@@ -335,13 +385,18 @@ class Resolution(object):
         self._r.starting()
 
         # Initialize the root state.
-        self._states = [State(mapping=collections.OrderedDict(), criteria={})]
+        self._states = [
+            State(
+                mapping=collections.OrderedDict(),
+                criteria={},
+                backtrack_causes=[],
+            )
+        ]
         for r in requirements:
             try:
-                name, crit = self._merge_into_criterion(r, parent=None)
+                self._add_to_criteria(self.state.criteria, r, parent=None)
             except RequirementsConflicted as e:
                 raise ResolutionImpossible(e.criterion.information)
-            self.state.criteria[name] = crit
 
         # The root state is saved as a sentinel so the first ever pin can have
         # something to backtrack to if it fails. The root state is basically
@@ -362,20 +417,38 @@ class Resolution(object):
                 self._r.ending(state=self.state)
                 return self.state
 
+            # keep track of satisfied names to calculate diff after pinning
+            satisfied_names = set(self.state.criteria.keys()) - set(
+                unsatisfied_names
+            )
+
             # Choose the most preferred unpinned criterion to try.
             name = min(unsatisfied_names, key=self._get_preference)
             failure_causes = self._attempt_to_pin_criterion(name)
 
             if failure_causes:
-                # Backtrack if pinning fails. The backtrack process puts us in
+                causes = [i for c in failure_causes for i in c.information]
+                # Backjump if pinning fails. The backjump process puts us in
                 # an unpinned state, so we can work on it in the next round.
-                success = self._backtrack()
+                self._r.resolving_conflicts(causes=causes)
+                success = self._backjump(causes)
+                self.state.backtrack_causes[:] = causes
 
                 # Dead ends everywhere. Give up.
                 if not success:
-                    causes = [i for c in failure_causes for i in c.information]
-                    raise ResolutionImpossible(causes)
+                    raise ResolutionImpossible(self.state.backtrack_causes)
             else:
+                # discard as information sources any invalidated names
+                # (unsatisfied names that were previously satisfied)
+                newly_unsatisfied_names = {
+                    key
+                    for key, criterion in self.state.criteria.items()
+                    if key in satisfied_names
+                    and not self._is_current_pin_satisfying(key, criterion)
+                }
+                self._remove_information_from_criteria(
+                    self.state.criteria, newly_unsatisfied_names
+                )
                 # Pinning was successful. Push a new state to do another pin.
                 self._push_new_state()
 
diff --git a/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py b/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py
index e1e7aa42..359a34f6 100644
--- a/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py
+++ b/env/Lib/site-packages/pip/_vendor/resolvelib/structs.py
@@ -75,6 +75,18 @@ class IteratorMapping(collections_abc.Mapping):
         self._accessor = accessor
         self._appends = appends or {}
 
+    def __repr__(self):
+        return "IteratorMapping({!r}, {!r}, {!r})".format(
+            self._mapping,
+            self._accessor,
+            self._appends,
+        )
+
+    def __bool__(self):
+        return bool(self._mapping or self._appends)
+
+    __nonzero__ = __bool__  # XXX: Python 2.
+
     def __contains__(self, key):
         return key in self._mapping or key in self._appends
 
@@ -90,7 +102,7 @@ class IteratorMapping(collections_abc.Mapping):
         return itertools.chain(self._mapping, more)
 
     def __len__(self):
-        more = len(k for k in self._appends if k not in self._mapping)
+        more = sum(1 for k in self._appends if k not in self._mapping)
         return len(self._mapping) + more
 
 
@@ -105,13 +117,14 @@ class _FactoryIterableView(object):
 
     def __init__(self, factory):
         self._factory = factory
+        self._iterable = None
 
     def __repr__(self):
-        return "{}({})".format(type(self).__name__, list(self._factory()))
+        return "{}({})".format(type(self).__name__, list(self))
 
     def __bool__(self):
         try:
-            next(self._factory())
+            next(iter(self))
         except StopIteration:
             return False
         return True
@@ -119,7 +132,11 @@ class _FactoryIterableView(object):
     __nonzero__ = __bool__  # XXX: Python 2.
 
     def __iter__(self):
-        return self._factory()
+        iterable = (
+            self._factory() if self._iterable is None else self._iterable
+        )
+        self._iterable, current = itertools.tee(iterable)
+        return current
 
 
 class _SequenceIterableView(object):
diff --git a/env/Lib/site-packages/pip/_vendor/six.py b/env/Lib/site-packages/pip/_vendor/six.py
index 83f69783..4e15675d 100644
--- a/env/Lib/site-packages/pip/_vendor/six.py
+++ b/env/Lib/site-packages/pip/_vendor/six.py
@@ -29,7 +29,7 @@ import sys
 import types
 
 __author__ = "Benjamin Peterson <benjamin@python.org>"
-__version__ = "1.15.0"
+__version__ = "1.16.0"
 
 
 # Useful for very coarse version differentiation.
@@ -71,6 +71,11 @@ else:
             MAXSIZE = int((1 << 63) - 1)
         del X
 
+if PY34:
+    from importlib.util import spec_from_loader
+else:
+    spec_from_loader = None
+
 
 def _add_doc(func, doc):
     """Add documentation to a function."""
@@ -186,6 +191,11 @@ class _SixMetaPathImporter(object):
             return self
         return None
 
+    def find_spec(self, fullname, path, target=None):
+        if fullname in self.known_modules:
+            return spec_from_loader(fullname, self)
+        return None
+
     def __get_module(self, fullname):
         try:
             return self.known_modules[fullname]
@@ -223,6 +233,12 @@ class _SixMetaPathImporter(object):
         return None
     get_source = get_code  # same as get_code
 
+    def create_module(self, spec):
+        return self.load_module(spec.name)
+
+    def exec_module(self, module):
+        pass
+
 _importer = _SixMetaPathImporter(__name__)
 
 
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py b/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py
index 42e9d894..4f1603ad 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/__init__.py
@@ -1,4 +1,3 @@
-# -*- coding: utf-8 -*-
 # Copyright 2016-2018 Julien Danjou
 # Copyright 2017 Elisey Zanko
 # Copyright 2016 Étienne Bersac
@@ -17,29 +16,16 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
-try:
-    from inspect import iscoroutinefunction
-except ImportError:
-    iscoroutinefunction = None
-
-# Replace a conditional import with a hard-coded None so that pip does
-# not attempt to use tornado even if it is present in the environment.
-# If tornado is non-None, tenacity will attempt to execute some code
-# that is sensitive to the version of tornado, which could break pip
-# if an old version is found.
-tornado = None
 
+import functools
 import sys
 import threading
+import time
 import typing as t
 import warnings
-from abc import ABCMeta, abstractmethod
+from abc import ABC, abstractmethod
 from concurrent import futures
-
-
-from pip._vendor import six
-
-from pip._vendor.tenacity import _utils
+from inspect import iscoroutinefunction
 
 # Import all built-in retry strategies for easier usage.
 from .retry import retry_base  # noqa
@@ -48,6 +34,8 @@ from .retry import retry_always  # noqa
 from .retry import retry_any  # noqa
 from .retry import retry_if_exception  # noqa
 from .retry import retry_if_exception_type  # noqa
+from .retry import retry_if_exception_cause_type  # noqa
+from .retry import retry_if_not_exception_type  # noqa
 from .retry import retry_if_not_result  # noqa
 from .retry import retry_if_result  # noqa
 from .retry import retry_never  # noqa
@@ -77,6 +65,7 @@ from .wait import wait_none  # noqa
 from .wait import wait_random  # noqa
 from .wait import wait_random_exponential  # noqa
 from .wait import wait_random_exponential as wait_full_jitter  # noqa
+from .wait import wait_exponential_jitter  # noqa
 
 # Import all built-in before strategies for easier usage.
 from .before import before_log  # noqa
@@ -90,58 +79,23 @@ from .after import after_nothing  # noqa
 from .before_sleep import before_sleep_log  # noqa
 from .before_sleep import before_sleep_nothing  # noqa
 
+# Replace a conditional import with a hard-coded None so that pip does
+# not attempt to use tornado even if it is present in the environment.
+# If tornado is non-None, tenacity will attempt to execute some code
+# that is sensitive to the version of tornado, which could break pip
+# if an old version is found.
+tornado = None  # type: ignore
 
-WrappedFn = t.TypeVar("WrappedFn", bound=t.Callable)
-
-
-@t.overload
-def retry(fn):
-    # type: (WrappedFn) -> WrappedFn
-    """Type signature for @retry as a raw decorator."""
-    pass
-
-
-@t.overload
-def retry(*dargs, **dkw):  # noqa
-    # type: (...) -> t.Callable[[WrappedFn], WrappedFn]
-    """Type signature for the @retry() decorator constructor."""
-    pass
-
-
-def retry(*dargs, **dkw):  # noqa
-    """Wrap a function with a new `Retrying` object.
-
-    :param dargs: positional arguments passed to Retrying object
-    :param dkw: keyword arguments passed to the Retrying object
-    """
-    # support both @retry and @retry() as valid syntax
-    if len(dargs) == 1 and callable(dargs[0]):
-        return retry()(dargs[0])
-    else:
+if t.TYPE_CHECKING:
+    import types
 
-        def wrap(f):
-            if isinstance(f, retry_base):
-                warnings.warn(
-                    (
-                        "Got retry_base instance ({cls}) as callable argument, "
-                        + "this will probably hang indefinitely (did you mean "
-                        + "retry={cls}(...)?)"
-                    ).format(cls=f.__class__.__name__)
-                )
-            if iscoroutinefunction is not None and iscoroutinefunction(f):
-                r = AsyncRetrying(*dargs, **dkw)
-            elif (
-                tornado
-                and hasattr(tornado.gen, "is_coroutine_function")
-                and tornado.gen.is_coroutine_function(f)
-            ):
-                r = TornadoRetrying(*dargs, **dkw)
-            else:
-                r = Retrying(*dargs, **dkw)
+    from .retry import RetryBaseT
+    from .stop import StopBaseT
+    from .wait import WaitBaseT
 
-            return r.wraps(f)
 
-        return wrap
+WrappedFnReturnT = t.TypeVar("WrappedFnReturnT")
+WrappedFn = t.TypeVar("WrappedFn", bound=t.Callable[..., t.Any])
 
 
 class TryAgain(Exception):
@@ -151,7 +105,7 @@ class TryAgain(Exception):
 NO_RESULT = object()
 
 
-class DoAttempt(object):
+class DoAttempt:
     pass
 
 
@@ -159,25 +113,23 @@ class DoSleep(float):
     pass
 
 
-class BaseAction(object):
+class BaseAction:
     """Base class for representing actions to take by retry object.
 
     Concrete implementations must define:
     - __init__: to initialize all necessary fields
-    - REPR_ATTRS: class variable specifying attributes to include in repr(self)
+    - REPR_FIELDS: class variable specifying attributes to include in repr(self)
     - NAME: for identification in retry object methods and callbacks
     """
 
-    REPR_FIELDS = ()
-    NAME = None
+    REPR_FIELDS: t.Sequence[str] = ()
+    NAME: t.Optional[str] = None
 
-    def __repr__(self):
-        state_str = ", ".join(
-            "%s=%r" % (field, getattr(self, field)) for field in self.REPR_FIELDS
-        )
-        return "%s(%s)" % (type(self).__name__, state_str)
+    def __repr__(self) -> str:
+        state_str = ", ".join(f"{field}={getattr(self, field)!r}" for field in self.REPR_FIELDS)
+        return f"{self.__class__.__name__}({state_str})"
 
-    def __str__(self):
+    def __str__(self) -> str:
         return repr(self)
 
 
@@ -185,66 +137,70 @@ class RetryAction(BaseAction):
     REPR_FIELDS = ("sleep",)
     NAME = "retry"
 
-    def __init__(self, sleep):
+    def __init__(self, sleep: t.SupportsFloat) -> None:
         self.sleep = float(sleep)
 
 
 _unset = object()
 
 
-def _first_set(first, second):
+def _first_set(first: t.Union[t.Any, object], second: t.Any) -> t.Any:
     return second if first is _unset else first
 
 
 class RetryError(Exception):
     """Encapsulates the last attempt instance right before giving up."""
 
-    def __init__(self, last_attempt):
+    def __init__(self, last_attempt: "Future") -> None:
         self.last_attempt = last_attempt
-        super(RetryError, self).__init__(last_attempt)
+        super().__init__(last_attempt)
 
-    def reraise(self):
+    def reraise(self) -> "t.NoReturn":
         if self.last_attempt.failed:
             raise self.last_attempt.result()
         raise self
 
-    def __str__(self):
-        return "{0}[{1}]".format(self.__class__.__name__, self.last_attempt)
+    def __str__(self) -> str:
+        return f"{self.__class__.__name__}[{self.last_attempt}]"
 
 
-class AttemptManager(object):
+class AttemptManager:
     """Manage attempt context."""
 
-    def __init__(self, retry_state):
+    def __init__(self, retry_state: "RetryCallState"):
         self.retry_state = retry_state
 
-    def __enter__(self):
+    def __enter__(self) -> None:
         pass
 
-    def __exit__(self, exc_type, exc_value, traceback):
-        if isinstance(exc_value, BaseException):
+    def __exit__(
+        self,
+        exc_type: t.Optional[t.Type[BaseException]],
+        exc_value: t.Optional[BaseException],
+        traceback: t.Optional["types.TracebackType"],
+    ) -> t.Optional[bool]:
+        if exc_type is not None and exc_value is not None:
             self.retry_state.set_exception((exc_type, exc_value, traceback))
             return True  # Swallow exception.
         else:
             # We don't have the result, actually.
             self.retry_state.set_result(None)
+            return None
 
 
-class BaseRetrying(object):
-    __metaclass__ = ABCMeta
-
+class BaseRetrying(ABC):
     def __init__(
         self,
-        sleep=sleep,
-        stop=stop_never,
-        wait=wait_none(),
-        retry=retry_if_exception_type(),
-        before=before_nothing,
-        after=after_nothing,
-        before_sleep=None,
-        reraise=False,
-        retry_error_cls=RetryError,
-        retry_error_callback=None,
+        sleep: t.Callable[[t.Union[int, float]], None] = sleep,
+        stop: "StopBaseT" = stop_never,
+        wait: "WaitBaseT" = wait_none(),
+        retry: "RetryBaseT" = retry_if_exception_type(),
+        before: t.Callable[["RetryCallState"], None] = before_nothing,
+        after: t.Callable[["RetryCallState"], None] = after_nothing,
+        before_sleep: t.Optional[t.Callable[["RetryCallState"], None]] = None,
+        reraise: bool = False,
+        retry_error_cls: t.Type[RetryError] = RetryError,
+        retry_error_callback: t.Optional[t.Callable[["RetryCallState"], t.Any]] = None,
     ):
         self.sleep = sleep
         self.stop = stop
@@ -258,23 +214,19 @@ class BaseRetrying(object):
         self.retry_error_cls = retry_error_cls
         self.retry_error_callback = retry_error_callback
 
-        # This attribute was moved to RetryCallState and is deprecated on
-        # Retrying objects but kept for backward compatibility.
-        self.fn = None
-
     def copy(
         self,
-        sleep=_unset,
-        stop=_unset,
-        wait=_unset,
-        retry=_unset,
-        before=_unset,
-        after=_unset,
-        before_sleep=_unset,
-        reraise=_unset,
-        retry_error_cls=_unset,
-        retry_error_callback=_unset,
-    ):
+        sleep: t.Union[t.Callable[[t.Union[int, float]], None], object] = _unset,
+        stop: t.Union["StopBaseT", object] = _unset,
+        wait: t.Union["WaitBaseT", object] = _unset,
+        retry: t.Union[retry_base, object] = _unset,
+        before: t.Union[t.Callable[["RetryCallState"], None], object] = _unset,
+        after: t.Union[t.Callable[["RetryCallState"], None], object] = _unset,
+        before_sleep: t.Union[t.Optional[t.Callable[["RetryCallState"], None]], object] = _unset,
+        reraise: t.Union[bool, object] = _unset,
+        retry_error_cls: t.Union[t.Type[RetryError], object] = _unset,
+        retry_error_callback: t.Union[t.Optional[t.Callable[["RetryCallState"], t.Any]], object] = _unset,
+    ) -> "BaseRetrying":
         """Copy this object with some parameters changed if needed."""
         return self.__class__(
             sleep=_first_set(sleep, self.sleep),
@@ -286,24 +238,22 @@ class BaseRetrying(object):
             before_sleep=_first_set(before_sleep, self.before_sleep),
             reraise=_first_set(reraise, self.reraise),
             retry_error_cls=_first_set(retry_error_cls, self.retry_error_cls),
-            retry_error_callback=_first_set(
-                retry_error_callback, self.retry_error_callback
-            ),
+            retry_error_callback=_first_set(retry_error_callback, self.retry_error_callback),
         )
 
-    def __repr__(self):
-        attrs = dict(
-            _utils.visible_attrs(self, attrs={"me": id(self)}),
-            __class__=self.__class__.__name__,
-        )
+    def __repr__(self) -> str:
         return (
-            "<%(__class__)s object at 0x%(me)x (stop=%(stop)s, "
-            "wait=%(wait)s, sleep=%(sleep)s, retry=%(retry)s, "
-            "before=%(before)s, after=%(after)s)>"
-        ) % (attrs)
+            f"<{self.__class__.__name__} object at 0x{id(self):x} ("
+            f"stop={self.stop}, "
+            f"wait={self.wait}, "
+            f"sleep={self.sleep}, "
+            f"retry={self.retry}, "
+            f"before={self.before}, "
+            f"after={self.after})>"
+        )
 
     @property
-    def statistics(self):
+    def statistics(self) -> t.Dict[str, t.Any]:
         """Return a dictionary of runtime statistics.
 
         This dictionary will be empty when the controller has never been
@@ -325,63 +275,60 @@ class BaseRetrying(object):
                   statistics from each thread).
         """
         try:
-            return self._local.statistics
+            return self._local.statistics  # type: ignore[no-any-return]
         except AttributeError:
-            self._local.statistics = {}
+            self._local.statistics = t.cast(t.Dict[str, t.Any], {})
             return self._local.statistics
 
-    def wraps(self, f):
+    def wraps(self, f: WrappedFn) -> WrappedFn:
         """Wrap a function for retrying.
 
         :param f: A function to wraps for retrying.
         """
 
-        @_utils.wraps(f)
-        def wrapped_f(*args, **kw):
+        @functools.wraps(f)
+        def wrapped_f(*args: t.Any, **kw: t.Any) -> t.Any:
             return self(f, *args, **kw)
 
-        def retry_with(*args, **kwargs):
+        def retry_with(*args: t.Any, **kwargs: t.Any) -> WrappedFn:
             return self.copy(*args, **kwargs).wraps(f)
 
-        wrapped_f.retry = self
-        wrapped_f.retry_with = retry_with
+        wrapped_f.retry = self  # type: ignore[attr-defined]
+        wrapped_f.retry_with = retry_with  # type: ignore[attr-defined]
 
-        return wrapped_f
+        return wrapped_f  # type: ignore[return-value]
 
-    def begin(self, fn):
+    def begin(self) -> None:
         self.statistics.clear()
-        self.statistics["start_time"] = _utils.now()
+        self.statistics["start_time"] = time.monotonic()
         self.statistics["attempt_number"] = 1
         self.statistics["idle_for"] = 0
-        self.fn = fn
 
-    def iter(self, retry_state):  # noqa
+    def iter(self, retry_state: "RetryCallState") -> t.Union[DoAttempt, DoSleep, t.Any]:  # noqa
         fut = retry_state.outcome
         if fut is None:
             if self.before is not None:
                 self.before(retry_state)
             return DoAttempt()
 
-        is_explicit_retry = retry_state.outcome.failed and isinstance(
-            retry_state.outcome.exception(), TryAgain
-        )
-        if not (is_explicit_retry or self.retry(retry_state=retry_state)):
+        is_explicit_retry = fut.failed and isinstance(fut.exception(), TryAgain)
+        if not (is_explicit_retry or self.retry(retry_state)):
             return fut.result()
 
         if self.after is not None:
-            self.after(retry_state=retry_state)
+            self.after(retry_state)
 
         self.statistics["delay_since_first_attempt"] = retry_state.seconds_since_start
-        if self.stop(retry_state=retry_state):
+        if self.stop(retry_state):
             if self.retry_error_callback:
-                return self.retry_error_callback(retry_state=retry_state)
+                return self.retry_error_callback(retry_state)
             retry_exc = self.retry_error_cls(fut)
             if self.reraise:
                 raise retry_exc.reraise()
-            six.raise_from(retry_exc, fut.exception())
+            raise retry_exc from fut.exception()
 
         if self.wait:
-            sleep = self.wait(retry_state=retry_state)
+            sleep = self.wait(retry_state)
         else:
             sleep = 0.0
         retry_state.next_action = RetryAction(sleep)
@@ -390,12 +337,12 @@ class BaseRetrying(object):
         self.statistics["attempt_number"] += 1
 
         if self.before_sleep is not None:
-            self.before_sleep(retry_state=retry_state)
+            self.before_sleep(retry_state)
 
         return DoSleep(sleep)
 
-    def __iter__(self):
-        self.begin(None)
+    def __iter__(self) -> t.Generator[AttemptManager, None, None]:
+        self.begin()
 
         retry_state = RetryCallState(self, fn=None, args=(), kwargs={})
         while True:
@@ -409,23 +356,25 @@ class BaseRetrying(object):
                 break
 
     @abstractmethod
-    def __call__(self, *args, **kwargs):
+    def __call__(
+        self,
+        fn: t.Callable[..., WrappedFnReturnT],
+        *args: t.Any,
+        **kwargs: t.Any,
+    ) -> WrappedFnReturnT:
         pass
 
-    def call(self, *args, **kwargs):
-        """Use ``__call__`` instead because this method is deprecated."""
-        warnings.warn(
-            "'call()' method is deprecated. " + "Use '__call__()' instead",
-            DeprecationWarning,
-        )
-        return self.__call__(*args, **kwargs)
-
 
 class Retrying(BaseRetrying):
     """Retrying controller."""
 
-    def __call__(self, fn, *args, **kwargs):
-        self.begin(fn)
+    def __call__(
+        self,
+        fn: t.Callable[..., WrappedFnReturnT],
+        *args: t.Any,
+        **kwargs: t.Any,
+    ) -> WrappedFnReturnT:
+        self.begin()
 
         retry_state = RetryCallState(retry_object=self, fn=fn, args=args, kwargs=kwargs)
         while True:
@@ -434,30 +383,36 @@ class Retrying(BaseRetrying):
                 try:
                     result = fn(*args, **kwargs)
                 except BaseException:  # noqa: B902
-                    retry_state.set_exception(sys.exc_info())
+                    retry_state.set_exception(sys.exc_info())  # type: ignore[arg-type]
                 else:
                     retry_state.set_result(result)
             elif isinstance(do, DoSleep):
                 retry_state.prepare_for_next_attempt()
                 self.sleep(do)
             else:
-                return do
+                return do  # type: ignore[no-any-return]
 
 
-class Future(futures.Future):
+if sys.version_info[1] >= 9:
+    FutureGenericT = futures.Future[t.Any]
+else:
+    FutureGenericT = futures.Future
+
+
+class Future(FutureGenericT):
     """Encapsulates a (future or past) attempted call to a target function."""
 
-    def __init__(self, attempt_number):
-        super(Future, self).__init__()
+    def __init__(self, attempt_number: int) -> None:
+        super().__init__()
         self.attempt_number = attempt_number
 
     @property
-    def failed(self):
+    def failed(self) -> bool:
         """Return whether a exception is being held in this future."""
         return self.exception() is not None
 
     @classmethod
-    def construct(cls, attempt_number, value, has_exception):
+    def construct(cls, attempt_number: int, value: t.Any, has_exception: bool) -> "Future":
         """Construct a new Future object."""
         fut = cls(attempt_number)
         if has_exception:
@@ -467,12 +422,18 @@ class Future(futures.Future):
         return fut
 
 
-class RetryCallState(object):
+class RetryCallState:
     """State related to a single call wrapped with Retrying."""
 
-    def __init__(self, retry_object, fn, args, kwargs):
+    def __init__(
+        self,
+        retry_object: BaseRetrying,
+        fn: t.Optional[WrappedFn],
+        args: t.Any,
+        kwargs: t.Any,
+    ) -> None:
         #: Retry call start timestamp
-        self.start_time = _utils.now()
+        self.start_time = time.monotonic()
         #: Retry manager object
         self.retry_object = retry_object
         #: Function wrapped by this retry call
@@ -483,43 +444,165 @@ class RetryCallState(object):
         self.kwargs = kwargs
 
         #: The number of the current attempt
-        self.attempt_number = 1
+        self.attempt_number: int = 1
         #: Last outcome (result or exception) produced by the function
-        self.outcome = None
+        self.outcome: t.Optional[Future] = None
         #: Timestamp of the last outcome
-        self.outcome_timestamp = None
+        self.outcome_timestamp: t.Optional[float] = None
         #: Time spent sleeping in retries
-        self.idle_for = 0
+        self.idle_for: float = 0.0
         #: Next action as decided by the retry manager
-        self.next_action = None
+        self.next_action: t.Optional[RetryAction] = None
 
     @property
-    def seconds_since_start(self):
+    def seconds_since_start(self) -> t.Optional[float]:
         if self.outcome_timestamp is None:
             return None
         return self.outcome_timestamp - self.start_time
 
-    def prepare_for_next_attempt(self):
+    def prepare_for_next_attempt(self) -> None:
         self.outcome = None
         self.outcome_timestamp = None
         self.attempt_number += 1
         self.next_action = None
 
-    def set_result(self, val):
-        ts = _utils.now()
+    def set_result(self, val: t.Any) -> None:
+        ts = time.monotonic()
         fut = Future(self.attempt_number)
         fut.set_result(val)
         self.outcome, self.outcome_timestamp = fut, ts
 
-    def set_exception(self, exc_info):
-        ts = _utils.now()
+    def set_exception(
+        self, exc_info: t.Tuple[t.Type[BaseException], BaseException, "types.TracebackType| None"]
+    ) -> None:
+        ts = time.monotonic()
         fut = Future(self.attempt_number)
-        _utils.capture(fut, exc_info)
+        fut.set_exception(exc_info[1])
         self.outcome, self.outcome_timestamp = fut, ts
 
+    def __repr__(self) -> str:
+        if self.outcome is None:
+            result = "none yet"
+        elif self.outcome.failed:
+            exception = self.outcome.exception()
+            result = f"failed ({exception.__class__.__name__} {exception})"
+        else:
+            result = f"returned {self.outcome.result()}"
+
+        slept = float(round(self.idle_for, 2))
+        clsname = self.__class__.__name__
+        return f"<{clsname} {id(self)}: attempt #{self.attempt_number}; slept for {slept}; last result: {result}>"
+
+
+@t.overload
+def retry(func: WrappedFn) -> WrappedFn:
+    ...
+
+
+@t.overload
+def retry(
+    sleep: t.Callable[[t.Union[int, float]], None] = sleep,
+    stop: "StopBaseT" = stop_never,
+    wait: "WaitBaseT" = wait_none(),
+    retry: "RetryBaseT" = retry_if_exception_type(),
+    before: t.Callable[["RetryCallState"], None] = before_nothing,
+    after: t.Callable[["RetryCallState"], None] = after_nothing,
+    before_sleep: t.Optional[t.Callable[["RetryCallState"], None]] = None,
+    reraise: bool = False,
+    retry_error_cls: t.Type["RetryError"] = RetryError,
+    retry_error_callback: t.Optional[t.Callable[["RetryCallState"], t.Any]] = None,
+) -> t.Callable[[WrappedFn], WrappedFn]:
+    ...
+
+
+def retry(*dargs: t.Any, **dkw: t.Any) -> t.Any:
+    """Wrap a function with a new `Retrying` object.
+
+    :param dargs: positional arguments passed to Retrying object
+    :param dkw: keyword arguments passed to the Retrying object
+    """
+    # support both @retry and @retry() as valid syntax
+    if len(dargs) == 1 and callable(dargs[0]):
+        return retry()(dargs[0])
+    else:
+
+        def wrap(f: WrappedFn) -> WrappedFn:
+            if isinstance(f, retry_base):
+                warnings.warn(
+                    f"Got retry_base instance ({f.__class__.__name__}) as callable argument, "
+                    f"this will probably hang indefinitely (did you mean retry={f.__class__.__name__}(...)?)"
+                )
+            r: "BaseRetrying"
+            if iscoroutinefunction(f):
+                r = AsyncRetrying(*dargs, **dkw)
+            elif tornado and hasattr(tornado.gen, "is_coroutine_function") and tornado.gen.is_coroutine_function(f):
+                r = TornadoRetrying(*dargs, **dkw)
+            else:
+                r = Retrying(*dargs, **dkw)
+
+            return r.wraps(f)
+
+        return wrap
 
-if iscoroutinefunction:
-    from pip._vendor.tenacity._asyncio import AsyncRetrying
+
+from pip._vendor.tenacity._asyncio import AsyncRetrying  # noqa:E402,I100
 
 if tornado:
     from pip._vendor.tenacity.tornadoweb import TornadoRetrying
+
+
+__all__ = [
+    "retry_base",
+    "retry_all",
+    "retry_always",
+    "retry_any",
+    "retry_if_exception",
+    "retry_if_exception_type",
+    "retry_if_exception_cause_type",
+    "retry_if_not_exception_type",
+    "retry_if_not_result",
+    "retry_if_result",
+    "retry_never",
+    "retry_unless_exception_type",
+    "retry_if_exception_message",
+    "retry_if_not_exception_message",
+    "sleep",
+    "sleep_using_event",
+    "stop_after_attempt",
+    "stop_after_delay",
+    "stop_all",
+    "stop_any",
+    "stop_never",
+    "stop_when_event_set",
+    "wait_chain",
+    "wait_combine",
+    "wait_exponential",
+    "wait_fixed",
+    "wait_incrementing",
+    "wait_none",
+    "wait_random",
+    "wait_random_exponential",
+    "wait_full_jitter",
+    "wait_exponential_jitter",
+    "before_log",
+    "before_nothing",
+    "after_log",
+    "after_nothing",
+    "before_sleep_log",
+    "before_sleep_nothing",
+    "retry",
+    "WrappedFn",
+    "TryAgain",
+    "NO_RESULT",
+    "DoAttempt",
+    "DoSleep",
+    "BaseAction",
+    "RetryAction",
+    "RetryError",
+    "AttemptManager",
+    "BaseRetrying",
+    "Retrying",
+    "Future",
+    "RetryCallState",
+    "AsyncRetrying",
+]
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 001b1a7fa9d35d4dfdb92f3bff67d39437251949..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 14706
zcmYe~<>g{vU|^UdaWHk7BLl-@5C<7^FfcGUFfcF_yD>8`R0*Uoq%h_%<T6GvGBSiS
z<cYB`q%u{iF*1N)3R4tgBtssP0YeH?6mtqg3R4bC6bqPUjba7UY*FlBnj?xMg&~DG
zhclNeiYu2pikp!kg&~C{hbNaeiWkgg&Ed=CkKzZj*>VJO1)~HR8B*9&IC6w?g`<SQ
zY|b2^T#+adFq<n!C|5K}6wKz%5y};d5(Be&a)fflqr|~%-W;J^i6{v$n=eNwS29Wx
z%;wJ#%9V<e0<#5jgmR^$q`_>#9HCs9C>bzYC`Tw)HcA%E7S0jMm5Y)Cvqf^`a}}Z#
zz--YR`CP>)MKD_|M=4i1N*T-+&r!-%iBbWxC32K<RijkFY{?v@T(u}QFk31|DOWv8
z9n6-_QOebb(g3q%ax`<bqO`zl*&NMW?I>+9TP{a4S0_pb%$Cp5%+-z31+x`$G;{T$
z^uTPz9L-$)D19(nDMvHcAj$yDR?gAPHH<PuVjF?kDmlivCQ&9}wrY-Xu4$Ahn5~v$
zmTMkm4rZ(8nB`hTS%BFZIhMIrQC48KW{zd9b(A$DLn?cgO^Q}3dzNjAb}v(uT`GH)
zeTq(sZVN**W0Vk>rw8Mu=z~~MLhcMH1}TOu3@L`G4$aI_j;T(~3{lSR3@Jt_#w`pf
z#;H!t%uz1x3@IilrY#I9rm3#Y%u#Oc3@K(Q<}C~<=3seucZL*;6w4Nd6w6fiX67gl
zuqmD?Rw>pk3{hV03@J7#wk-@PwqQHF-5FBsQtVq8QtZLHecTyR98w%x7*asCGe`Nl
zGo(1BIJYpQIH&qHGe`NkGo-krxVA8)xTf-E`8P91`MWcuxTUzaFr>JHO$bP3oWNXU
zkiwASkrS936cxnCkjgxPxyUJnA;mK%I5#9JgpnbIDVRai>m?|MX)@jt&MZ#OFUl`1
z$;?YlE6qzT$;{95(`35E?&##~n_7~1i!U*$xTGjCxg<BWBqKjXlkpaNT4_mXQEIU!
z<1Oam%nD7$TWs;AC7C(JFBusa7&IAgaTTSO6jjD2B^IY@GT!2Z@Dg)!G#PL4z&PcJ
zl^_FPl6jSyjJJd!l9_4osTIko1t6zrGTsu$6pb&bEC3lT442BwFNrToEiTO|(PX^E
z4;O|DaYKaiQp-|{G#PJ6L%5}RIjP0P2-{%hN<pNN9TK0LT3no%4zg7aE(@|1?o^nH
zm5jGoi*r&_3p5#T34$5%rNx<f>G7#$sd*sh2^E**7sMx~m82HMCzh0?<`#fN1&~Bj
zQgaeP0m1<h1BV=x4Gt(SusF;!!eCx`Mrt0!iumGGkbzv~iJ2ww$r*{6d7yxY@bYt$
zGV?&55CHR2D+==SQu9hO6G4#!(UF!}kqU}tL9mL<yyT+PT#%BybWmi11@rR3W^jW!
zMTvPS`MIEoLgL1wnVgiGmS2<_pOX(Vgb&Kg%P+~ugcu764Tv-^goBV3fU1WCCPa}4
ziWpSwEza<w#Dap<6gQBUS(EZh^HP#Qi4v69K^VjaVP{Zv!otA7kir<upvhFF8&X-2
zs!*Jno|gzp+6rm;MG6k!XjVupR!CGRN-S4MNlnf#N-W7Q((_vhO65#xc}02*3=Cl6
zSEI94OlWaxQE^OaPD*A`jDKFLOHpQ7s)DXUsGnz;Yf!Lfh-0vVr=N?zpKGwEV@$BC
zuWN9KYmkCjOhAB7OrnWyPJVi3aY<%&Oln?Pj8A4#OmSvOs%}AIa&}^RYH>_KW`TZu
zS!!NNevy7jYF=V;W=W-fe0*kJW=VX!UP0w8R<MH;L0)45d6uQfkb!|A8N`HPkT}Ty
z{vbt2{x`$o|B{SUXc%Z{B0R5<oS#=*QdF7@4hXQ{S2EpVO-U?DFTTZ`l3flKf)ECv
z&;hw217sb@ZUz<<=P)xcFn};WNZy8lfuV$<gQ1x*g)y6{NUemigCT`UlA)QgNUema
znE}QNW@u+<XG~*CVNPLb;izS*VG3qQVGU-`WUJZ&ihhMe1z16*P@Y+mp^&JMms+ln
z5CkfeGV{_C6!Md@Qj<&cxVRJ)6cnrq5{nXZ6~G>_QYgqT&IFY^i8%_1Md_uWgkP*s
zkXT%tnxasWuK+UxY6OY_+2vLW*{PM~`9&#M^@73^oBkqD`=$sKD=0}76kMzf3=G1c
zuxSB@O$|c{V>45cLJ89X<`l*(mKugE)-1LZre4N{jEoE=>?sVTj71J5>@}b;b132H
zV8~?XU|ho3$5_jlXH~*klvBc0!kNXL!raVMlmlWd;HhC)$XJw9!i%DouY?boU&FY7
zAEYjrL6gO=s@grjL;;-Cz$LswW?pegVqS8pf<|?6PI0X!D90ox=Hw(M<)p#`LPwz_
zBePhcJToUpp`a)~DKROhQXwNTFI^!sFC{e%l!#MvDit(RGE)>P^Gg+SQxo$bme_(#
z)zH(^)3nzFRXNEy#kWK=i{s(dRy-`aH3e>QWfsHSQ^d)@z;KJBJh3P*GcUdP77K`V
zi!Cj`C^xa>7H52Xa!z7#aeVwOj`;Yz#N5>Q_##l4-{N&FuFOk@#ndhKlKi5)#FYG7
z>=}v0i6tdPx0usY^NP$shVzF&<lu@q;4IeiqQrt?O{QCnX}1`Qii|*60bE*uGQ}+x
zkZctwW>r90laY&&g^B4u6ARlPmj5j50*nG69uwC;CT6a`OsoP-d`wl4x=zm~CqFqc
zr`S#pWP+b2^DX9_)Vy09umA^Vc}?abV~~9&Ai@nqfNci50c1T`Q9j6aP|{;ymtf>$
z<`YB7nP6AJ+T8*S3=F9ZQH&`JQA{a}QOw{L1oJJ9kfKV*^u)}(Dt*TsP<;-GFa=OT
zPpwEzE-gt-LCT65sd)-TiJ8TzDSCdIEJdK~ev2zUJ~uz5G$%Da{uWPsd|_!~4kRjW
zvB$@!<R{0+LrM~``@sa*{hkaA43k0b2SpeMV-bjt+xa{w&IgtEw>Vw$9U(QZ-%4h%
zQ;NJm;p7b>!1f>ru#LV93=Ff7Yy|O1vXR{-KN!>~@GJ7eWe2EGo`+-yh>u|h$j9K$
zkOqpcK#>x~lENItn!=L8+QJaUmco|8-og;Yp28f=pviHI%PFxq)e+phOEh6*U;uFy
zz&QY1*%hT06r~nJs(FP(u(D!Mfmf24ovM&j360r&<bu;VAJjA`Nma<qEyw{k5fVWq
zXR$(VX>o}HI8&!uflEkT1z0s@1u_$q*)tP!GOJP*5_57C@=}vQO{=0xg|y7noRngy
zmLS)Fpm@iSkf2~Is5{FNi!#B5N^wDIa%Ng(W?s4iC_`o@m6oJ}U7MMgoKu>Ts*njP
zI|_<4ic@paG@<7CIr_R<f&H490`g~CW-{2l5XB`$mC!O>0n*MbR!GcCQ2=GDq{QTG
zh@-%1(GP1W4XVY8b-)dZ1q|&BX^bgMDa<V#9Sm8FE)30#3mIz}Q&>uvK($*Ia}8q}
zlNduVgC?tA6_btvhJkDh3=E(QT&%#rz)-^wD^bgs!cfBqsvK(=o0&kG!x$JD3Ynm-
z7gp6`Th$^zP}4j;wFDF-noPHt^bBsXf<tsA<1H3YNPwMR1WL}gIBn8X^HM7citN_I
z5*!O-l^Q5fK+=d_d^{*g#K$8F9JrP$Hq~Mc)nZLemRl@Y`I&jQxWRGd=IQF=5`2pV
z)HVlaDNUxLP*5q!SzMA>k{VxJQUq~92q*)9oxuUKWgW;B;KGQJkCEj+2XmD$7Pp`T
z6sW=kWd?9l4y3h&0aWh=Gpu9;g#-)8`9)x>P_r_qWGOBwijUs{vJ+$i17npCifv$N
zO%AXpkje!gkh>#5K4JkSrlM#NKMq77Yyh)Bek%%KU|?7TvH~=?!NJJF!NSPG#K8s@
z$DONXu;%I%mKKI6R!Ae~7B{$#fkac0D9CzH6Dt|)6Hu|uz`y`vgD^O3_#kZu#%9JE
zhIqylhG2%G7*Icr=@x5RPJUuZkr<c<jw>)55=(HOfa*t3mW_|!1M&{YTn5G}5hPdW
z!LqlXCL4O7fx@dO9^}d-5CJw7L4ZRlfq{Wx2gqnpy60d7g;Nno47Zm+6;cgD2}3DE
z5l;<cFhdR8Q{cX69;gEZ@?K_9amg*V;?(5)ycBd_amA;Bq(Pmf!ywBc{whjCZ!&{|
z6qLI`bTP=i$TcA%r$@0s3tm=e!OPapz`_v44k>)Wf#q6MlwVY3=bD$CSWsM=lL#)f
zGEx<C5{pYf1sSL#h-gg}Wu|A8C_s8S3h9|;pwh0iKo28OKyCx!VkuBz0g7XW62=my
z8ir=31<W<zmLVd}S#I%wY=d<>Z?P7a7NiyxrGugd6hF``TLfybuVgH;28n}X3*_-4
zkcv~FumbfQ7#P_YtAr6AgC_#qxfJX|hAf6G#v-8_hAf5!ObZ#B7;6}skWwWx*zQ|w
zX^ELRsVTSEAU$~O8M!DG+@3fGauO)*Ffej3axqp3Avp@F1j9`rAAoa*5VXv$VaQ_4
zVya=tVqORuA7S#V;;1&LjjlGVjn!l+vH}GJI5a@b7O)esIjIO#8e9fB2a=jloDvTz
z0psIwlq;aHEy@L112W?lFSL1@oSKt^(g?}|DFMd@DAJCD>;e^j9E>bXJS-fn;Hbo1
zykIsOQkYv9Fw<@dM=*mX=Pf>HBgr>0FEKr}s7f5dfG5`E{JfIXiW1C33GzNTctM3<
z4LDK46X8n6ThP%MaJ>Laa)ls|fzuk80DBP>D7Qdf1ewRcSS60?9^6R|R5^g{2gNho
zW=Ii$txn*Kk5A15jmN~_MY2u;!#b#<WRS6-0s(|UY*0rHY#+$kB@8u8CE$))4MP?<
z6V@=*FsCttI%%L98!XC_!T{!jngL9HA)2g3=AfE|7gQ0s!bZP}K!I|Lw>Y%~F-CQZ
z3&e$F3r!YqseOwhwIUfjc6Eyr#41b7DNVh_2^zIa1+`uv{)PuDs6bDx0F4?v0C^Ua
zd>9zH7=;*Fn6ZQ~M5Ui5J9^0ut`0#lR8$0tx=IiMwgW+cLZb-O(YOw?2$W7am^qli
zq8RBElv==z+ZjmJU@CJIODbzBTPk}qLn=ozLn>z~R|;baQz~}~V;UED6o4^`CzTfy
zrg5dPrm(dzM)840?OPb4_)`T^I8(U5<G_L`+$lUQ3{gTUyeWJw3{k=<{3!x03{fH}
zf+<2R3{j$~VkyEYB4D-RDWWN2Eeuf-py<;Szr_QJC2%Q|nV0V8mdp)G2T%-RgOV#a
zIe;1gkmO&(1gd>&m}?l~nQB;S7~+|0SZf&KS!&p77~)xL*lQT#*=jgy7~<JWI2Ld&
zWT;_?=c?hXVTk9h;i_SX=ScyH@WPX_CLg$}zQqC>`vY}tGfTj|x?60J8sio#co6Lt
z4}=?E4C;G;%a>c6B^gDji7A<R>9<(Hoyl8l@emq1Zkh_Jr{a@yif@TPy7^Fn#GD*(
zYSL$5U|7iwPI+KQ6jg(wz6L~qS|UZYAXXiSs0R_?LaiCZ0*zvzrA2U^@&=STBtYTE
z%f^Tbxj=lDDpBMBM`U|YSc9~IFo?~|z`y_w_dHNt$dJWQ!UzieET(3r5=KxAWHEzT
z%ry*IEMOLR3<b<$tzpPw1GCs_7_!*GEcP0PEDkV>qlO`i6U^eQVaVbFv$$#)vbdX>
zQW$%=K%L4e3+McTO2{||q@x5Gek#t-O;rF7GNqQJ78NTbgN8j)Qxr1O6!KD2Q&Lm(
zG`UC*M@=3`?F?$KkgmI^6%-$+8TA%Ra(+Q2CnEzxF{l;Fz{kSKg#nou+5R(qs}e+s
z50E~T8WxoPK@~DMF0{by&k}I$n!;GZ3~HrkGNv%~f@)iqEY=j}UM5iQsD=^RC%VOy
z3mTzj1$AVKi$E1#RlAL<2DC<ukJl`Qb=49}6bvd<HF8rmD-<+9Il)#HOlcPDD1Zi|
zZB;cu6o?DX03c~lMgR$bleVp@2ABp3Kyr$$ss@As5(4KTTU8A(ty!#Tr^$AUB_%Vt
zq=+3{SeIoMXC~#Of|^rB#kZI;Qy_5yY9qj^wGPaH26r6PK;aB(nlmsmF^Vv<{bOTg
zVrKe-k<vlknD}^<&;?a)ph6oQx}ZUwDo{#f$YKm<2xeemC}FD90nLRnGGsD<T3PXo
zATo=QjUkdDn85%#<eeDI!oU!eT2fk+r;w-s@>6DhULvR$oTgAznpcvUo2me+pFtzi
z$;HsIQqXv52xuG+Nj-Q-FDX?4)OxK{0L?;x2Y^6LgQEPLoYW$PjKpFE@LYvLQfg`*
zxH}Fqs3<W{PazyMDwJ8GkXa0}6*N$%kPp#Ol$fVbP?TDhnO|C*Q>l<yqEMWXUz(Gm
zkdauHs-TfnS^_sIH?dM7FTX?+B2`+PnpT<v>b~pe7b#@sK?eLlzRLlP&q6x(;3~2h
z>|D4pMWuOQ2V@p2l;)+R7L_Mf!c0ld2aR!*q^2MRgr1%PXhbnHFWt&YAtWOeVt8gA
zqy#_;AuTP4%eAx=l2R4G#X)&SBEtEgz<}f867Ud*MqYjiq@(~%kmx8Rm6m{lwJ22~
zwIZ{)Bo#E?s-=~iSgEB2cR$<=5Cc-mC?utpl&7ZVDdZ+*<rgUwrRJn27N-`2hG;=!
z;)n=VNGwXlZcut+Nk(c>Y6>V`ic)j)%TiMmit}L|lf-1u;0>s6lAT&vtdN>lTw0W>
zP=eEYB^jxepz)>B#GIT;h+jZq3>pef$w>vr2gsk53Mu)ZC`AqKy!?_>Xjntz4@+n#
z7NshHt25A06KE(BQr%(k94x*;gFFfv#rdETIkz;YB(op~<ONVAS*%c;0WuI|PH|#x
zDr6iiGcO&BanLefS0ObM6k-Y~nMJ9|B{`L#fXmE-@iZac1LvC5#N-Tcn#E!o$cR*h
z{PH}7vdq+Sh5R(6+z2rOoDY&gSu7be(5e9r3v7`HnXXkRPgMYAl!BuCvdolJg+v8V
z`Yy>=NK8*JN=;8J0r@#q0W`>#UkVxT0;MAaMoKJcMftf3VAn$eS5pt}13yjXq9#z`
z$c0c3?ne}Xhv~q5V60uI9tH*mLr|dzY6LQfF)?y6@-T8RR*9ojH3&mdI>MkfI0%C~
z!l0q~5{3ng9SjQ@+aXg$j44bl9L<ciOi(^#>WI06v4$z0sfM|RDV`ZLjikw16^%ZH
z1eyv2*Aba{=}5^DI&G9@rQnDd<1Wcp01e9*gNGRrnqXmw(%uEtksv3_gBm}eA(#%v
z4u*8b8iqxTL7<WwJZ}RXs{uEfG?{L(fM?m5vddR86}f;a7SQ+_SQ0v{2eQ2&H6=bR
z7!;BqD;SunR8c|@q@)-zst4kNbr5n~7DEl(S&*=WI!=?Rs14*6P<5oqRMZEGe75Xz
zkW-5$fF!`p3{Y19wlDxRD;ExTAavXj)|>`UY#=!h9E|ZGEt)LgYPSev5xB8i1eybY
z_JJVbF%e`RNE8w%VCz9PgZ21=tOQL4FtBkj3NZ6AvoW$UL5BWNEk{XOpg;sAE0C?l
zpri$=O&2gOWME_f&BK9O>RAjaj5Z7@p!N(y3bPGE3aC}dkiu%i0BU{4vw&Ldnrwcz
zKv|-wBpy_^f+ziM@j<8m<MT>$lTwSolYqB4GE;I=<J0nsG+B#4nc@~}a!zVu5!mmy
znDg?>i$D!<So;FRhIkec%&bYN>6v-)An$@R6C)QRAGjrl=2@^Z6wiVhZScM<Xqupg
zF^d5-#hL;dYtsM?l7J@}m1-CkFhT~GKvT293?Ow`%=vaDEFjhb)`biuY|Tuy%r(r#
z5uoOD4Py#pFJo~;4buXSg$$q(yDUzyNqL}#HAI#XWD2M$!=1up18TbPK*Wm<)G%c6
z7R>;W5D}361$;G33mI!cLCs&Zp@wAvKWH$iL|}nn4NDCZ$OQ|T7(u286<w)e$P$9+
ztYyt(Nnx&KEfKC^ZDy=tj2Ee4WMRk>tzk81U}A_D1vTkYSXdb(89*Y;3}AO~r?7%V
zQrOHHpdw-*w@+X!(y3v{5`&n`$WS5<GBcP#lijbV0F(<P!Rt8Ui!<|*Q=y}c&<F>O
z-GDkR3`NsGDRwG|05$0}C2q0jmzE^w=cYosQJ{IIqHK^fcz6KRy@xD}0nd3sazPGA
z8r0vqB@7wrEQVTHT#{H+0!~AaE?NsnA-E?7?vsHc`xX~?2rV8|q8EX?aG;UbTiki6
z6(#YIc_4@r!Cg7fjFcuDq~})%@*#6tX~`|YOwbaVf}G6cOwb~nlA=o3nxE8)WJuox
zoHoG(C^z0>$t+1NN&}@&P*WK+k_Z~O<6>lE;$r0b&%!Lg$ic+L$iu|L$iv9S$ioQg
z1#&P7FtIW6F@bs|e2hYjLLgZtw4MmaT$HvlDCdIw2`b%+Q^38#1q_g(mlDPr(276C
zOokMuUY1%=E19W=F@?F8v6iWXxrV8PrJ1S7u7njL2A*({0*kXXGZiJ&FfL#Rl>s#j
z3phXtk&&TLsxYBY3Y^zj{J>dKlNp><!9`-xBv9akl7%K`(M(X-@qr5+=fs?xV9@+X
z(PEGSP%IaLBONqsQUnU{TM`9DsRfBe;4&c|5;2guOK{j~G9$$YQ%XMAW(WZeYmWGM
zP^iSm_kzM3G~CI+$i*bU1PWD9sldU=!-Uc6fat&oNl?!N<fLLy#Rc*ycqRdC*-EH0
zK*c}Aui)qg6EJsx8d~x3vqA0vm8uMw_Ci!(*bA}_Y%i!|3aZ*u7)zL-*_*kBF_WQ&
z3AD-q+zYo3ElyQPNQjSzn3a$K9#T(DOi@TmO-?K=1~qdsi=nf8pngXRXzDXL5!AS^
zGFJ!b($G}LF0TMGTODRJNEv9cL26=(CQFe8DEcfx5i8^ZH8C?kFC4P^plBsXb_Iw4
zhX|Me2MY_x!ug;e0T<OwER0NyO#fI|&=NLCm8K;65F99VgNBN8Q%e%TbGh;H;51PL
z3a27vkaeIgW|2CGr3oTH1rK=4r3jQGAQg8s$k7}HMfnA(MJ1Jx@&Z)bfs-jDSuO|Z
z1;qlyBdbANupbZv$TvlxB@Hh@4H_o~1_lmB78WK(CeVZq$Wt)<l}jEZiiW>($#QTr
zF>*<B2yw7;sB`c!F>*13%>y|UTvoyeP}%{H5`u<|kY{7SbFSdgY|z|l5y%bDc`8r`
z1<@nbL#gvXU3pO13r=95fyWw#1q{%-jj;w)g)`MKr!e-ifa@Bj8Wzxkn_AWq<{DOT
z5m8VjRKr-ql*v%T3`&HxY~c)f3M>pItd&WSZg>sL0=5!%P`w8l@r`6CoMgaI!?J+0
zh7H6o1QjZ*C0xx+MSV3a3%H?$3Qr9yM7D-Cm;qX>F#Bn;z*bN~dK*~F7hXujEdfOm
zTA@-55-S14H*;}iF=X5r+(Rw}Nq|D2Xeo#VYL9BNLkbpf3j>j@LFInYGLRy0y@Qqj
zK<RunC^duTdJqK-6Qd9#52FaU&;b`Xg5bgr)TD;xCO=J9^yCd5VFsB9E@6-ea9RUJ
z?+TDrpmYfuR|ZEoMrr}&5m3r024zs>)Pg*BmkM1r(aaddmdXy9!E0uW;sDR#af0XY
z*xbOYUaMSC=I;^}G@#w9{36ggu@X(#<VY%H^#G_Bny65cSd^Yx0`DlGCO}Yn2DuW1
zi$Q6+1T=05n!jTLCkD{;2{XL3)nqBk1cm-a5CI;32elqx%|Q?wJY)t5EpR}A6di&E
z6ayn4V--KdFNlFuP{9rgBoGF%K~4e{0mY!^GAKVRWJqBwg{+mdfQ}lKXQYBUsS1e-
z@FlRI;xs80l-V*;b5cMnE5NJ1AR(mZr^#3}2jprjGce#b&M}Z9K~^&`SMfrf2$=^&
znQ#F$P(fh@cAy%#POo8X1~mnlizI4T7BE2S<2<e!mIaIub`47~gC=8@oHK0kB6Lw8
z#1iOmqMjyG5h!mIfii<8Ymq6)t)KwC#aafQQQ^%<1hsUaOOuNhfaFor|1D1V^2pO5
z&w$HxX3(5A4-*$-l>o#(J-8xGF05%D6k|neLB@lcez&;6WjkbDN)c$;LJ??u8xq4{
z`$1!*;2vNRC{^qS*$j#}P^REvVPfQBVPXW!V9gxhq7>8)L(Uwqq7*q}K(a*?dkRMi
zXA46VM+#R8cMC%lX9`a+gC=hgsJy8%1-E5D15Ka`6_WTti=T5+!E0&2-Q$AP6v)Up
zybMSNMJXulfiQ>-N(A8Obpa0^gSuPbi4$;E01f2Fvw){kSiw^%Y$+gd_7u<*2?v<u
zOaV=|aDmy}psb_G><8|0fxB3mJmAh$5vZ^)ngR-D(E1bfvJ@2aMYBO=r69CP4(_=X
zmn7yEK-$FfK?^5XA*CcX6Too;CgAz-CMa%1K;C5HVq$|pW+=^6B@PY|c$1Kb{0S;%
zK^;<X|BMghQxFf-Pm_SJiC`+)2J$1=qu8?ETm}Y)4<L7e8p;ezT#PJ?RZ3_s!P2on
zX{CV*4S1det!V@YJp-6ztYKhb$YM%i1b4BRz+&L?Op^%`DVi+caE3S&9PFTw#X3p^
zs-3=p+zP6(K^+G+P<f_~=2~10W|Vp#RBgbW42mUC!*U@*EfZ+*L>6;1BdGVffTae!
zgaR~1!~{xTph-J6P&k8|zMAYvDG8MKionhX6(9&NK}RTVF_$Ig++r#z##V5E%bY(5
zk3srFRg!2PLrnc*cm?DgaFzk3HB7IRFf0IN8AfocnYo6EXwTeYPfjcVEsDqRP|*fZ
zvI4E#!RjMWQOd-`z)%c{Dv*zO7^`Hk_y}Hq_z^4*L1`7zL;;5}$PT1(5EP4$au8G)
zT>}LtsQn8n2RX!<7`a$E*f`k01(haaku50qG8Q?4sL)&NnR%dPg(XFxqURR3XKq1$
zQ3+(U(hlTJ&^o!I22g3hR#I62nmlDJ0k`>YF()P^7l9H|5hx07aV6*HC6^WzrRJ3s
zfr_$Q+y$8hdeDXYMW8HpO9V+o54Myal90d?sGJ}Rxj+PHQnLtDlox@fHj6->DFQ8)
zF9NNADiQ=K0rlvLgh4D&v2u$!FR`Eq)O;%v2Z@2FW<hO=B1sSzR9qBEgIM4mf-Hyy
z?)A%oSfHWEBG8({B1I5a2}FQ95uglRqzdvpWZOtuX--ajR%S^_Y7u0Z0#pk_dKsW`
zh$7H3lOk|`13YX1ngJ}*25Dyp?K22VEV{)3D&#;j9Yvr;leakX%TkMS@)J{TaUvE!
zc!G4WK^nTZIQ{(NgIt3{eL^7JW6(ASaQ7IzpborV4AP|mPl$rMIp7{Ns7C^B7=kN6
zaNOUL#TNd0@rj^y-<kQ~gb^i=RSk44czJ3PINe}Ndbc=ia=}ZQ?LhHS3>t!DViW)k
zVz9F?aWF!l03#1G4-*eFXn+F?28n|(BUBEV4G{y0z_9=`3nLdB2y>_iu&^-;un4dS
ghzW48F>|m82nYxX)H65;hzp4e7_%|*FtITL0Dj`1-2eap

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_asyncio.cpython-39.pyc
deleted file mode 100644
index 3b91e36b9860330261afab3457cf18cdc2344855..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2231
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
B`%C};

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/_utils.cpython-39.pyc
deleted file mode 100644
index acda5734ea771b4394eab166b0e3ac803689901c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3979
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
FW&l;UkoW)q

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/after.cpython-39.pyc
deleted file mode 100644
index fd5a3325512a761d42ef133ff5c6b4eff191f6ab..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1006
zcmYe~<>g{vU|^UdaWGYym4V?gh=Yuo85kHG7#J9el^7TpQW#Pga~N_NqZk<(QkYVh
zTNt94QaDmrQ`lM<qnK0JgBdhAUxIXNGTvf~FD=Q;DNbet@u3*R24QEAfh-^c8G{)#
znX1$r(@Ii{6p|BjaukY7iV{mw(<>E9G7?J^Qu0%a74q^+GBWeh_54;ctYo~!U6fi<
zR2g4fl30>j1acmj_*Lg@6%$&VT2vg9nv;@Q6yu+l>Qa<hma3qu5bEa{<{A|28R8hM
z;OXb$@8=rq=@=92>gyUD;u@r2784NQ6O(A7o0FfOSzMBt9g~_@7UPqd6jPj8lB!#f
zn4F!Mo?0AJkXfJ~UzVDel3%1>lA4#8oLN$-p9pffUP0w8UN9>j>Q)hu51ByTW-MZ7
zU|{&gs%oHToR$o7FGv)GK>+~bgK)75I5bKaYM7cC#TinV#2Gpn+Zoy!+nLgsQ<zg&
zS~zN%YnX!>G+C>haE4Y+etNM&NxnjHer~ElPJViNYLP-oMyf(uW?p7-Mrw*eVo6DA
zZb6A&m5duq2ps4o`3mZ)#p()RKPXhGY7}egD3oMm7Auq|7K4pYEmkPW%uNNyQD$Dc
zLS~5`M$~dLFfa&%Jg&jOz|g_8fT4q-gRz8h0aFb_7V|>J8ip*E62=9rH4Is73mF%(
zGBTtv1T$zd`f0M?V$R7=F9L<vEy48El6a7#k`j}%<MR@8Q*SY)<=ql4PEF3wODT>o
z&df_r1;u_*$t|vu{P_H$l+3)uoLhWQzs2X3<|d^U6@fx`CG#!Loc#3ooYb<^oLlT5
zW=TQLEjCEdfYVJ88v_FaSR_8PL>}aLK2Y2+vM@3+GBI*7vM_S}u95_YOMFg#x}Hr=
zesW??v7H{su*?!o##_wAB}JMnMM4Y=3`GJU!?=o5ljGC!i*gf7ia@~uv4<Zd54MaG
zZkhzhJ`Rw5%zXcuSOqwX#26SD{4^PhK!Tbqw?qmu3-q9AP7jvmz~KZ=Rbb^1<3WiC
a!UEgDVUwGmQks)$CkV0v6c#+p94r9M-UTZF

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before.cpython-39.pyc
deleted file mode 100644
index 352c12dc204df5f3c7ee733d55beec0dd720ed4c..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 902
zcmYe~<>g{vU|^UdaWJ)sg@NHQh=Yuo7#J8F7#J9e6&M&8QW#Pga~N_NqZk<(QkYVh
zTNt94Qdm-0TNt94Q`mwTG}&K*^lCERVv8>=$;>HEW(4t}7{mr)XOM9$AmbQ=88n%y
z)SXh(@{3Xxk`r@s6pBlV5=&CkD-}vI5=#_P@>7cy^72bEGV{{){8looWW2>)lv+|$
z8DCtISdv=A%)r0^CVtgBTg8MHrxq2*q~@e#7RC7IrMeVlmZd7_DunuZhPeg>dxkg$
zD|q_3`1`pAdpgDhyZX8YhqwkQn8gGH_{1cd=;q|7XBL-aX2+!FmBsjECdCwImZa(y
zBqnDkrl%Ii6l50Y$Cst%rQ{dsm!#$;CTEsZ>L-Dnu2)cbix0w#hq_h-<VjHAF)$Xf
zGcYhDgW1rK0680mi-i~%7}^=y8Pk|j7*m*9IBJ<{n1UHJnX9aDhf7X=da*)DzCv++
zZmL2~etLRpkwQsEszPE(NosCEi5^C{b1*P42!ouY!oa}L!MK2-gCT{ngmD2=4MP_5
zLJ*6kh9Qe}A>%?8MurpyP`vn6nFW_57L{b?r9+~oBws;YwOCz8p(G=-SRu0*Y@=$i
zLP=&WB=SHiGfVU|*={lC<fj*be0)nVJ+&kr6thW*$=UIFiMgq_n9}lYah2r9=NF}9
z<|XFb;)A+6KCd)4DYd8wlr&Z{-Qvv2Pmj+@ElbV0#Rl;rIHrr(7#JA9BJr6e(jYJK
zfI^j#g^`JoiIIzu>ra&wG%9lP)Aej}@{<#DitY43re&6ZjnHH+;s+%hJ`f=QB0!N*
z#0z49P3J-wAOW%g<RS)UK8_+m1_lN{O_p0C1(^kU(8QnzOAKHSgCiTP4r~<?0XCV#
VCO1E&G$+*#WKuE6Tpnf)762LD<FEh#

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/before_sleep.cpython-39.pyc
deleted file mode 100644
index 19336c81dafca811eed88bb1a85887e1c153b53e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1250
zcmYe~<>g{vU|^UdaWM4<8w0~*5C<7EGcYhXFfcF_>oG7eq%fo~<}l<kMlmvi*i1Q0
zxy(__j0`EvDJ(4vQ7kE(DQqe1EsRmDDICEJnp`hICTTL>Vv8>=$;>I%WV|Jjo>~&0
zT9F)|nU|IypH`Hg8=qEMQd*Rn%m`8o#UM5aJA*7{0a?r#%%I6srS6oPmS2>rkery4
zqflH@lvt9QUa3%$kyxUTlAl_vke6SQk(rmS=eLqUlkpaJQEEw1Wqff-Vo7Qd$P_T~
ztJT>mCbT%Us5mAyCnd8e#y>CBr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6
z*EKlAHAulMCLq8kCecJUCqF&2xFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_$-
zEHy7Bzev9%H7_wav!qf#3GDRv;+)jf0=<IDTO!B;@lcnGf;`Lw3I)a@b_NCpw`5TG
zgZLl}@&kwu!o?yC3=HiI?TqbAY0N2%DNHRKwahil!3>(rRaUrzDJMU@SfM0ep*TM`
zRUs!oJw3HZp(G<!A+e++HMgKd4<#B{85kHi85kIZL9S|GU|^_W$YRK1EOG$R3z!x%
z)G~r>E@7@=Y-Y@2sbNfG5@TRusAZ~U?qDdgDq#hwYi6uvDGW(ru4Ty+NnrtrEMQv*
zRRt35V9H|eU`$~x;aI>~!;r<bkg<fjh9Qe5g{_&XhN*_Rh9!l)mmQSef*CY9{BE%o
zC1w_<rc|-17F#K(7Q5ZzC`v6UEy_zxsZt99MR;ajx`Jx4LS`O_EKW_%&r2y*NGw*!
zECC6q7VF(&1xJD=<1G$YO4Q`N#hzbUlANELdW$VBF*7GM<rZgZMRICENoIcDEtZnX
zg4A0a@$q?yxvBB-MW6_{#a5JBT$)pIi#aDhy$BR%w**0n8<aMa5|gvRYHu;6<=tXW
zPc2C-DJi<eotIis5}%k1GE<Ya2o$`xm{Kclv6Q72CEa2zOUx-vy~UT4pPZNj&m$|D
zi?|sW7;bUq<fq5yq?V=T++u^o8#px=v4JE(BJr6eGN5=;0;Lp24n{6U2__as9ws&>
z0Y(-k7DgsUCPpqsE-=mXvq}La`Q_xN>)C)UF1FJH*_2rVHeQpZNS1+tp$KF$*d0Z3
zATB5&7D<CxVCx0Y&5{H;1f+<8SwOr<o`HeEPm|G2lkJvBL1uv-G;8R=vIZpZq_Iiq
sCFkcBB$j{!9GoG*hJl@iM1UQ^VUwGmQks)$CkV0}B*eqW!_2_~02t^^iU0rr

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/compat.cpython-39.pyc
deleted file mode 100644
index 5dcd8e471a97ace9c209bbe19553aae881787f13..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 986
zcmYe~<>g{vU|^UdaWM5U69dCz5C<7EF)%PVFfcF_%P=r7q%cG=q%fv1<uK+lMKLil
zq%fzjv@k?5r?3VyXtGu5hn8gKWR_&67AvIX7bz4J<(FlqWagzSBqb(imnRmbC?x0S
z79^HrCV`Yy>b(S6q{(=Txj3^TnGwW+VrB*g1`u`zS!}_;z)-@F#aP5w!?1v9Aww`j
z4Z{NFg$yxFwT!h)HH;~Yr3^)CDU87kB`h_J&5SjSHB4#D!3-b~O{T<Ej0_B13JMAe
z?x`gTiFpdC70L0Ld1?6yWr;bZsS0UD`MC;-3T~w(rA4WFTo9F+WvO`ziEv?s%)H`~
z#JuEG9fhLQlA_GivQ#W46_;j~BqrsgLj0asT%4Jg4mK_`Pa&~bp(G;}VRu1dQDSat
zNotWoNxni(etLRlUb>!7etLRpkzP)Ix`w7gVqS_uQEE<NNotBhZfZ$Jeo8Uab^dt@
z0hJ{g`FRRPItnEjnZ*j_nK?NMNvR5n3K}Jq1*tj^ujwe16eT97g2G-?p`<9YASYE1
z>>h*x#^?rsgD171Br`t`?r8;$^30M9h1A@n)RdIe6eLrj4)RO`d9El`p**ozAuk`~
zONbFV3V!){sS26JpkOO4%1cdA$j?(q$}h=KC`&CW&dkp%R>)6-`Uc`QKTXymP?EdF
z91v-Ii!-$%8Di8eJ~$H`d$(9XKGkHt#g+z+xm!%B6}Om5l2$SlfztD@dS|Pc(Bjmh
z;+WK&l+2<S|GZR}qRg^X1zm+uKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9S
zfB>JEL=)Yd{PfJ?lFaOw)V#77pUk9~;>?m%-GapA?8Nlc;+TTW0{!^1)V!4ZBK?xo
zyu{?pl1hC@`qnF`yd{yIS`rUSYw@5|77uYLD=1C#fD$?n8zTo34<iR73u6&Tz)zFq
z7JGbrN`7*D{4MT+%mO{A`QQ)%D*<~BiQr~nV7SF$lbfGXnv-e=%0k5~3=9k`j6BQ$
DSZE^=

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/nap.cpython-39.pyc
deleted file mode 100644
index ada140b69cc271300fd45807a99f8bcaf2574f68..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1055
zcmYe~<>g{vU|^UdaWIvEm4V?gh=Yt-7#J8F7#J9eRTvl;QW#Pga~Pr+QkYVhTNt7k
z-5F9?QdnCUQdm=&nwg`RQy7C8G}&H)^!p_<f+#2kv6&ed7@R>S@i8zklrSt{tYKKl
z$jAWJ!&EhcOF=<FAvh;BwLqb`q$sf@HN8@yBqOmzAtf~@v9eepwIVgSv?Mb>Pa!S8
zNFh-nJ+mw|Pa&@~Hz~D9AwNx_I5jyxFQr(I3v5tGMrN@>X0bv^Myf(eYFc7xP6^yt
z9fica6ouTxN`<6Uh1~q)?9>#6{L&JzxutoTB?={}#U+_}>3U$3{4|+vv6N)yrru&L
z2Dwg?@fJJOu9XZ$tPBhcziOPVVnT~ki;81Xb5b&kV*K+`U5YZxQWbO+Lj63$T!Vr=
zLmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-IV^Z_VVtg`_Vu~|M
zQgsUwld}`kQ;TB?G7I$M%Tn`F@{9CKQu7j%GfOJ<^AZd63Mz|0;VK3SS0+$kvw``^
zASN;f$$_I$fq{V`l_82Tg&~S5g)xd58kH=Nh>T)QVGCx^WWOZ{_G^4;ab{k6d}>*0
zUP+Y!w#X?@%q%HZ$j?(q%u@g>Qz*#?1#59?iC!|uQkWw^Y!C*g08o;vVXR?@XGmcP
zX3%8x(`3BG3f2w^?Bdj%v?2}$21w|FgSd!|fq~%`M|^x{US>&ryb|2Ij8#$?F4co6
z!*Bp7sK5>oVqjpXVaQ_0Vyt0IVeADZLy$w5Kn`ICMRtB^i6#@+5w}=Ce$-?t;sm*f
z8$^I29o1RMi8(p(@v3lVF=KZYM46u^8^|kpiMgrq@wd3*<8$*<N^?MLp7{8}(!?C7
z410WhN`7*Dd=V(Pig;0N2D<?iDn;xJ3=Hxhn?XDdMiwRxX0VthOA#o*!Rg@^TYgej
hYH|r!0^)SA0bl~8?-qv*#1(eJAfrIJo`ac#69A#P{Zjw{

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/retry.cpython-39.pyc
deleted file mode 100644
index 65a3393e79869d742a0b48b593a396668bf2ca64..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7440
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
XY|LQHE5IcnAiyiYE1)dEFTe!=XEh}e

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/stop.cpython-39.pyc
deleted file mode 100644
index 2db4c1e1427b4a1058f95b522991b81cbb12178a..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/tornadoweb.cpython-39.pyc
deleted file mode 100644
index 69b973f11458b55b226a947be93ecf31d66d6a93..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1370
zcmYe~<>g{vU|^UdaWM5D8w0~*5C<8vFfcGUFfcF_M=&rjq%fo~<}gHoXr>&-T&5@{
zMi84hhcTBqiW$si$zjZ8iDCh>S#ub3S)*9NY_=S>T=pn-Mh16=6!sL37KRj#RHkO;
zD2^1yU<OUjmmoX+G#PL4I3*UR2Bnr1Rc7X;Yck&Abjf!tDM`&ODA8oR#qN?HoRgYb
zpvicP53I&HF()UuB(Wq_lkpaFdTL%W$QWb{az2P(Y{0<4kjfCnn8Fanl**jNlE&E1
zkj9w8n8MV;8O55)oW+*HoWjz=(99Uc-p;_n5XBM9pviiRKP0~>FEJ$_Y+GhtdNLEp
zG$>|fU|;}Qzzqr?1qKF&5{44S8ir=3ET%MuOoke!C5(NHj0`o5H4O30DGb33nv8y$
zEVo#TOAAtqir5(#7;bUI$7kkcmc+;3Vl4*yjQJKzacWLl5hzw}v1OMh7Nr-jWW2>0
zAD^6)SX>+*zmnlsv$Iu9XmM&$aZGAXN@h`ve_pCfQD#}Hg04cSpJ$kBP_So+W3Ym!
zpNqerYp|zdOt7o3YjB8bkb+rEK!8t7qKR%!etKqcNoICTYF=54Pi9g~ab`)XZb4#l
zc4B&JaZEvGfqr~hYF<iyk$y>PUSe`)Nu_=XBq+*Llk^HIi#Qn=7^FcS2ZaCwqZnhA
z1X@_>!Tg32XdrKMFfcIWgY+(9U|^_WSin%jxR8+%9C$U1HB2?kDU7`=wJbFZSxhx7
zDNMbLwX7w~HLN8p%}hl_RU#lYnG7||px_N-sAUUh$WvfpC}FKkVPpWo8kPlYCF~10
z7BYZLjbtdCW57_uvVgOO4a6^$0-MFv%v3a~hGhZwLIy^V8+dA17cz!1FftTMmGCa$
z1M!*|3#Gu(#te!!o+41HjL%QXN=+`g#gvwJiv<)pMLY})44RC$xFOQT;MB-}i!~`V
zJu|O}6%@%VnI)-3x41HkGxLf|67!N%i$E#o7B48NyH+Hp7L;V>=iTBhPA!Q~g>#vU
zD~oS&q*f%yXXd5l-{Jzv7Nr)K=9CnHLj0CQK~ZW!Vo_>*T7FS{UTQ^2d?F;DfRj!U
z8^~g|pwyDmqC8FZB2W@75@KLrC=vz{AU79@fRr$$<lkb0n#&K80uurtDUSH~<iwnu
z_;`6xR7rsnJrfs`022=*7b6p+2qO=p2$;>m$j5{&@*$cvIYEg$FEKYYKK>S0e0*+x
zN@)&=%@ZGASelpvkpa6G;&M)q-JHq!Mfs&AnR%&2iXc8OH2o*1f*e!?b|jeK1-TjI
zTyTB@IkFh!bq+=$78XXZm?mctNcfgWL1uv-G*Rop5_J(MKZBzK9IBA`Vuz-5h@(IW
f7Rf@etso0;ao9loVh7?CgMyTUiH8vknRu81V)j<4

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/tenacity/__pycache__/wait.cpython-39.pyc
deleted file mode 100644
index 2beda98fff5b3a24f2af5567aed1c555d1a9d452..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7373
zcmYe~<>g{vU|^UdaWJ(}oPpsnh=Yt-85kHG7#J9ePcSerq%fo~<}gG-XvQeU6owS0
z9Hw06C}u{G7;_FwE^8DkBSR|l0=86!EcS(r?hGj`DXc9FDXgg+&CJb=QJn4!DQqe1
zEet8_shrKsQC#i}DI6)BEet7~sa(y>QQYnfDO@SsEet8#V0j*Qh7_I@-WG-wUNE26
zogsxUg};R%g&)l4b7x2qND*vdND&0{`P~^(gi?fC7*d46d;xcc6p<9s7KRkjRDovZ
zD8UrQU<OUGmmoj-X)@koF3zmbWW2=|Us{rxQ=AMEM#juA@9QxzFr+eoyd1@p!WhMz
z%96#J!j!_?!qChZ#Rl<Y6g$LgQ5-28!3>(5w>ZlaGfU!=5{px-G#rzPONtVcOB6s{
zh2)&X;$nrg{2~RA5(SV{Nosm#YO!826O#QPHX{QAgEJ@wSimt5%&?NtZzaP@rduq<
zsX1x4xQkLtiYnuaOA<>`i`W<#7{J7@T4$@6(Bjmh;+WK&l+2<S|GZR}qRg^X1zm+u
zKhH4NpkU7s$6y6dKNo*L*I-Y_m|$05*WeJ>AO*9SfB>JEL=)Yd{PfJ?lFaOw)V#77
zpUk9~;>?m%-GapA?8Nlc;+TTW0{!^1)V!4ZBK?xoyu{?pl1hD$Z}bW(Z*j!OCnx6Q
z#K+5nTn_RE15=d{NERF%dN64W-+}@h>|0Q>EMcf&s9|ho3T7w*r9(}|TRdPRlJj$u
zGV@YbG8J(!FfiO=%`eGFEdu)+LV)z%VvmncOi784SBATQu}ToE9TWq4P+8m#5My9q
zs9{WD%w{U$sbL6as9{*ZP{X*8F_>W`lV1@iRx}xl_(1{A3nJh_Uj(+DBR;+eY`q%D
zdXOXo69*#;BWfT(l=x|Kf&wfrF*h|n{uWn!d~SY9X%2|Z6CYn#nwSHXVULeb$xn`t
zzr~!GlzfXX5t^cMQ%f@PQ;N7jt^m775X1sm2?-4_3*@LGPzsU;xd+7KU}9lnVdP@w
zU<Qk0Bz;h%fpfkBTGEFk`zRJ@qGwHE3ue${zr_U(+qBGz)RZdc@Wjj#SgNj6D9K1H
z0Vnigg+v9g3Wdbn{L;J<h5R&ylFZyxg{0Jy^3>Ekh1A643<YqC#>@yH2f>p@4Py;M
zJVOctG-<44ERtYgV9<o72o{iA(0mUH;>^6vlK6N7P!NDjV_>Wj2C0k(yGbuT9wLvC
zCP0x5wiy(ZH4IrWTZ<$?A<YgVKr#>uL17Dy3}c+uK(dD4O12^)kX~UBAp#;qK?Ep<
zzy?6fLo*rVO<j=5AaM>x7A6j6u-7r-50sNYMM*Jw{IxTrF@oceBZ{S+frTN8HJCw@
z1zK3;<>#eVnPZ8*l>F4<JatGkDkPRDB<AEOB&DY17o|etD>E-$FBue2AUi=A#0I$m
zgo{DGD`6;MtYK(oTELXTxR4Q4V+1o434mga`4($&X+dgHku1#rnvCGAy^`@3XM8-k
zu#As~1P3^HK|y2%3Iu2@LP{2p+u@O@i92v_@j}f^P6ZWF5OYDnSp+Jr!1)*K5_6CZ
zpgaQ#X0Qm>Kn7<LCG<?f3C<pjQ7q6pffZaQaNXhtC%B@-yp;UhDn~2<4Uz}t6NnOA
z86`I}Pd_)YLJwRJy#$4IGAN)y0T03;HYjYssTLH*ko;1^RKpO@2+uW|Ot<(!*2P2Y
ziqFl=Lla1>&}0V3#4To!By(<J1yXRq<H8XZQVfi2j8!5?X2RnGBU6C_7VJDJP(jO(
z#ZbbyfN>#14MP?aD2qujh%ku5GMXlHkqW4!XM;GjNEMV$aOFE!kYhm6$-v0MDD)rQ
zInd0f$pj9%B2e{EBm*)Jqy^n`plG#&nFmS+Tr5Q(F^q%&3T$vfK+kR9oW_7&S{Csz
zFfddpJ3}fmh2qq*)S|>3a2c7ImkujA!R-N1+=8MMgh94|usg^}pwNdzD<VP}Va0H1
zUUD(4e&j+lFVOu5%1C}7!$77oFjk3zqYhfX;*UE}5-SFkMkNg35`{5^sfDA4A&b$4
zp_#E6)XHM^Ln#nIR)8WMTrPq%)-c2h)H2pEb}*zc^fHDqFftS}ftzPcD;bM885kJ+
zz|PfVy2YetaEq~`NCzHGAiv+@v`J6RORXp<vI}BhVE7CQpehYC4?tpD&n727IWec$
zP7kg{lj#<7acORmCdf=gQUY56G96q32jU4Dh{=Aq(+((#y+H<m5*8@!a4>_Tozk=e
zjpF2t#LT?JyNnDB&LEaTNqN3Pevv{hs6++@0$Mua;!;phQ1DCx7u<*hp^#XVs*qZd
zkyu(>lA5BUP?C|VP?lO$sgRRcj8ubX7Auq%r>20-05!H!6Vpmki}WCdy5$!sq*f&6
z7UZN_SwVzAb~%9Sad3p#f*ceNcCm(5G?)Xfay1M!!HwWdh0HvKqQt!PR1IUzSOsmc
zJs>l1U}PhVAVy>%j4&nD2vdj=*$5*{G&MEhjz~#O1LsVL2U1fsG_BxrAO{u{W#*M=
zD1pmzLrAOMSRt{bBsI67q*zD62qI((7g9*fOHnW_Mll0qj)DRx_=})ns|0ZXMiv5P
zBi#AFNE?)%wLk<Y*?}_<q(%c}^;A%D1Q`Ht`GDgDdqxN4RS*Uj(gq9+4B!f!F^egM
zv6-oaxrQN&rJ1prsTNdRv(zx9FiJ2;GSo8HFxN1qF!e$T07&r)%2b-HMWCi|kvgax
z=Yxh$d|qj8QfkpH=A6_#u*)@Bz_krH_d^@|X{C9|@p<{s_6djw@f6s5@SK_f@)<~o
zfl-2y57w@O`Ho;-HDX|32!$EJ!N|hT!CV9q!^o?kQV(3tgMt{jLkKG8L7l=hW@yFF
z2Cewn!4*H}ElA%ZGcUO)H8(Y{Br`9)>Nq&bB<3l=MH6$-D|~Q9gS3mGfd<WW!6k`B
zAXC7NF@<6nuPiaAG!>k};D&-qf}~1?L<NW(sMiT@XG6^cr$Y@;nk-5!E-A`P2Ac{h
z2uceIQi~LFGIKLa6iV_Hit}?*6><|RGIL9FA!cdnfi;6`(w8X=3=GMj1OqCFK^Vja
zB{pyZf^?@qjdn;Qq=vbMA)X0QbAj4`AV1vVgu5G@R$wW@5|pGtZ9cFldJ+I7?owF%
zff^xfj8#(Lat3Z1sDX;Lg%65SQ1=q-Obuvb1XPjLfYUmpAyUg!!kofX!UA%97IQNb
zs8hO<*$<MwK~=OSYZ1bUpehdHPEeYMHlZMinyo0cxHP8(-2<TBTNTIypg?0_6vN?s
zXhL4efwkuV^2sd@U&n~}a7WLOB2b`!t1%?YKv@J*9)Mc6c_14>LL7`NY(lI>ATf+2
z4{{MW$%C>nYLW*f_!Q<8mNb?W))clD&`1b-3P%e=6nhG1FoP!7Edg*Gq*fH<=Yi6E
zVosts69WS{*+c6fXzwtwpdcqRwO9d3sX|g>a&~@N8Z^Cog8Ll#<&e@eQ6agsxFkO}
zvnn-3A-6QABom~+2%PW}^Ar-3GIKIZDnY3hmZ(8xD>$`6QZ*>O=j4~e(swaPDM|td
zDag&tLnL;nJ3=y26*BWmQj5wGbBe*$C%7t8(8$zF)dN{ll&X+ftdN(lkd;|dl3Jvx
zqfnf$P?C{Z3~Sa^Dr7<m|KifjlEkE(RB#=bl$ev4mki3Qpn4M&7K!PJnR&$}3OR`-
zsd>qj3gsE8c?yXNMX80QnMJ873Pq{K`K3k4AnPC=%S$Xv%*=tCn3$(fnwOoIU!JFs
zQd*Q)l9`{UqmWcuqM((RU!tXeVmrvJoU+Wkbg)Uu`FSOv_{z_N_spSToT^Yzl%Jeh
zT$~DvhvJMxWXI?!gchfQ4FN|zq`@AK9Ic@82UNP`fXbgDh2+HIRA?~*YKy-Fl^Eax
zB^i_{LFEVtgV-P$a3%#c*C8$68WvE829zn|nZP9qGonOcxy1!_bY^N1Qsu*uT2TNV
zh0<h&R5qaA3naHXfeIN=mPN`j;3@``m3ly#1vKCUDPPzat0ci*MDiQ%iWH;|>~>I7
zwMq`u!>M7+Vgyy1!VKUll&OYEgrSx>oFPwwg`tGG(u|P-1VPm-8$%>RFoOX@2}=n}
z3aGkeZDuNA1^G9N1yU3hS%dn~Y(-!XfJ+~cr*853m!%e^<>Z&U78T_eLHr2v9;{FW
zHL`CpgPPDbAfJOu0*KGSo(7dklR%yZwPYC>nHU8a`51W^d9ZsNS~L~eqM8IY6KtG4
z0|P@n$T*M?2O|rQ2wM?I45PpS6=R?{CwAmQ92^apDJ@Zkg@GXm+|vfP-xSI-OEQp4
zn4C(5^30UfJW!@9&&*57FNfxF$2??Zu!0DYe?e_wP=S$~nv$7VlB$3wzkstsX<l-E
zeo;zhUSdgV3ZWbXYK5j`f@<QVQjqfE%HopL++sb2kPK+Kky#8XXB3K4^NK-bkwSS!
zW^#st5>i5hIavu*6y>HS=9Pd<P1Q@+Q*Z^f-}6#Szz)kxEh*10%FfJ7*8vxu$@xV^
zsl^5Pc`4um5tL1p+)8tD6uiJ?nUX?cPI`V(W=Te_LP~0Ja#3bdYKlT;9@s2!5to#c
zpRQ1lUt9w12xOF$6ck(O>nD~M>m}wUR^{jECFkergOnBPCl)1VWR|2Rmy{Nz>La;c
z7h3Y`Cg!E+LP}A6NWa1rK0c_BpPXD;R19hTK;j-Ul$Z%BBhyp!b5lWWnZ%r&N>E%T
z=B0pQ8CGyZ3LNZJ3h~v60=OyxdmhqA0u5(oq=I@fDfzkZS^|_(P^y+PP#X=J)Lbz;
zPB@aY2BI{xHPAEFQBY7;01a4Xf(8!2saL^34|}%)+Pi>Ixrr6FW(JxN4v16+HR=@1
z42r=4m|t1~3F~lBbpvt>DBwVaHn=`PR573`16=)-<SQhlCW9J>2uX0=rK6Atsp#?x
z3i69nQ$PVxQd9{tuOuH_edUy)WFD|B3TQP7xKj!aWRPP}suFk`LIaWoN<q~UY={{a
z*P05siIoaTpqeW+Ewu<#Jwn4CWlRcG>VTR$Ai7u%*4<%fX3Am$O#}2Yf|`H}K;<vf
zLZ)B_O=dsHcm%ZZ2hvdl8hV1XxIpd5TkNHInQ8e&xhM@lmW<5w49G|$s33$i#y~~w
zR#4dpasdOQ5Mvd%#DWdXA>|GD)CrCOPLN4Oil}8UVptR8z}YZ+I2c(Z!A{l`Dgrgn
zi@=WNF32p<gHG%efvVhFB1j^7u&JIRP&nP<1<i5frj{gv$7pY{J32Z0rj{h$V#`m;
zN=+^S&n$q4r@_Og;Gr|{7zns?1#WJFs{pVoAT<v-Ouz)F(zwN81DOo50}YZFgN6z@
d7&(}Dn0T1E7=;7{xCGb*cm=owBn1QoWB}*B(|!N|

diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py b/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py
index d9a2d463..2e50cd7b 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/_asyncio.py
@@ -1,4 +1,3 @@
-# -*- coding: utf-8 -*-
 # Copyright 2016 Étienne Bersac
 # Copyright 2016 Julien Danjou
 # Copyright 2016 Joshua Harlow
@@ -15,7 +14,10 @@
 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 # See the License for the specific language governing permissions and
 # limitations under the License.
+
+import functools
 import sys
+import typing as t
 from asyncio import sleep
 
 from pip._vendor.tenacity import AttemptManager
@@ -24,14 +26,21 @@ from pip._vendor.tenacity import DoAttempt
 from pip._vendor.tenacity import DoSleep
 from pip._vendor.tenacity import RetryCallState
 
+WrappedFnReturnT = t.TypeVar("WrappedFnReturnT")
+WrappedFn = t.TypeVar("WrappedFn", bound=t.Callable[..., t.Awaitable[t.Any]])
+
 
 class AsyncRetrying(BaseRetrying):
-    def __init__(self, sleep=sleep, **kwargs):
-        super(AsyncRetrying, self).__init__(**kwargs)
+    sleep: t.Callable[[float], t.Awaitable[t.Any]]
+
+    def __init__(self, sleep: t.Callable[[float], t.Awaitable[t.Any]] = sleep, **kwargs: t.Any) -> None:
+        super().__init__(**kwargs)
         self.sleep = sleep
 
-    async def __call__(self, fn, *args, **kwargs):
-        self.begin(fn)
+    async def __call__(  # type: ignore[override]
+        self, fn: WrappedFn, *args: t.Any, **kwargs: t.Any
+    ) -> WrappedFnReturnT:
+        self.begin()
 
         retry_state = RetryCallState(retry_object=self, fn=fn, args=args, kwargs=kwargs)
         while True:
@@ -40,21 +49,24 @@ class AsyncRetrying(BaseRetrying):
                 try:
                     result = await fn(*args, **kwargs)
                 except BaseException:  # noqa: B902
-                    retry_state.set_exception(sys.exc_info())
+                    retry_state.set_exception(sys.exc_info())  # type: ignore[arg-type]
                 else:
                     retry_state.set_result(result)
             elif isinstance(do, DoSleep):
                 retry_state.prepare_for_next_attempt()
                 await self.sleep(do)
             else:
-                return do
+                return do  # type: ignore[no-any-return]
 
-    def __aiter__(self):
-        self.begin(None)
+    def __iter__(self) -> t.Generator[AttemptManager, None, None]:
+        raise TypeError("AsyncRetrying object is not iterable")
+
+    def __aiter__(self) -> "AsyncRetrying":
+        self.begin()
         self._retry_state = RetryCallState(self, fn=None, args=(), kwargs={})
         return self
 
-    async def __anext__(self):
+    async def __anext__(self) -> AttemptManager:
         while True:
             do = self.iter(retry_state=self._retry_state)
             if do is None:
@@ -65,17 +77,18 @@ class AsyncRetrying(BaseRetrying):
                 self._retry_state.prepare_for_next_attempt()
                 await self.sleep(do)
             else:
-                return do
+                raise StopAsyncIteration
 
-    def wraps(self, fn):
+    def wraps(self, fn: WrappedFn) -> WrappedFn:
         fn = super().wraps(fn)
         # Ensure wrapper is recognized as a coroutine function.
 
-        async def async_wrapped(*args, **kwargs):
+        @functools.wraps(fn)
+        async def async_wrapped(*args: t.Any, **kwargs: t.Any) -> t.Any:
             return await fn(*args, **kwargs)
 
         # Preserve attributes
-        async_wrapped.retry = fn.retry
-        async_wrapped.retry_with = fn.retry_with
+        async_wrapped.retry = fn.retry  # type: ignore[attr-defined]
+        async_wrapped.retry_with = fn.retry_with  # type: ignore[attr-defined]
 
-        return async_wrapped
+        return async_wrapped  # type: ignore[return-value]
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py b/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py
index 8c0ca788..f14ff320 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/_utils.py
@@ -14,73 +14,17 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
-import inspect
 import sys
-import time
-from functools import update_wrapper
+import typing
+from datetime import timedelta
 
-from pip._vendor import six
 
-# sys.maxint / 2, since Python 3.2 doesn't have a sys.maxint...
-try:
-    MAX_WAIT = sys.maxint / 2
-except AttributeError:
-    MAX_WAIT = 1073741823
+# sys.maxsize:
+# An integer giving the maximum value a variable of type Py_ssize_t can take.
+MAX_WAIT = sys.maxsize / 2
 
 
-if six.PY2:
-    from functools import WRAPPER_ASSIGNMENTS, WRAPPER_UPDATES
-
-    def wraps(fn):
-        """Do the same as six.wraps but only copy attributes that exist.
-
-        For example, object instances don't have __name__ attribute, so
-        six.wraps fails. This is fixed in Python 3
-        (https://bugs.python.org/issue3445), but didn't get backported to six.
-
-        Also, see https://github.com/benjaminp/six/issues/250.
-        """
-
-        def filter_hasattr(obj, attrs):
-            return tuple(a for a in attrs if hasattr(obj, a))
-
-        return six.wraps(
-            fn,
-            assigned=filter_hasattr(fn, WRAPPER_ASSIGNMENTS),
-            updated=filter_hasattr(fn, WRAPPER_UPDATES),
-        )
-
-    def capture(fut, tb):
-        # TODO(harlowja): delete this in future, since its
-        # has to repeatedly calculate this crap.
-        fut.set_exception_info(tb[1], tb[2])
-
-    def getargspec(func):
-        # This was deprecated in Python 3.
-        return inspect.getargspec(func)
-
-
-else:
-    from functools import wraps  # noqa
-
-    def capture(fut, tb):
-        fut.set_exception(tb[1])
-
-    def getargspec(func):
-        return inspect.getfullargspec(func)
-
-
-def visible_attrs(obj, attrs=None):
-    if attrs is None:
-        attrs = {}
-    for attr_name, attr in inspect.getmembers(obj):
-        if attr_name.startswith("_"):
-            continue
-        attrs[attr_name] = attr
-    return attrs
-
-
-def find_ordinal(pos_num):
+def find_ordinal(pos_num: int) -> str:
     # See: https://en.wikipedia.org/wiki/English_numerals#Ordinal_numbers
     if pos_num == 0:
         return "th"
@@ -90,17 +34,17 @@ def find_ordinal(pos_num):
         return "nd"
     elif pos_num == 3:
         return "rd"
-    elif pos_num >= 4 and pos_num <= 20:
+    elif 4 <= pos_num <= 20:
         return "th"
     else:
         return find_ordinal(pos_num % 10)
 
 
-def to_ordinal(pos_num):
-    return "%i%s" % (pos_num, find_ordinal(pos_num))
+def to_ordinal(pos_num: int) -> str:
+    return f"{pos_num}{find_ordinal(pos_num)}"
 
 
-def get_callback_name(cb):
+def get_callback_name(cb: typing.Callable[..., typing.Any]) -> str:
     """Get a callback fully-qualified name.
 
     If no name can be produced ``repr(cb)`` is called and returned.
@@ -111,14 +55,6 @@ def get_callback_name(cb):
     except AttributeError:
         try:
             segments.append(cb.__name__)
-            if inspect.ismethod(cb):
-                try:
-                    # This attribute doesn't exist on py3.x or newer, so
-                    # we optionally ignore it... (on those versions of
-                    # python `__qualname__` should have been found anyway).
-                    segments.insert(0, cb.im_class.__name__)
-                except AttributeError:
-                    pass
         except AttributeError:
             pass
     if not segments:
@@ -133,27 +69,8 @@ def get_callback_name(cb):
         return ".".join(segments)
 
 
-try:
-    now = time.monotonic  # noqa
-except AttributeError:
-    from monotonic import monotonic as now  # noqa
-
-
-class cached_property(object):
-    """A property that is computed once per instance.
-
-    Upon being computed it replaces itself with an ordinary attribute. Deleting
-    the attribute resets the property.
-
-    Source: https://github.com/bottlepy/bottle/blob/1de24157e74a6971d136550afe1b63eec5b0df2b/bottle.py#L234-L246
-    """  # noqa: E501
+time_unit_type = typing.Union[int, float, timedelta]
 
-    def __init__(self, func):
-        update_wrapper(self, func)
-        self.func = func
 
-    def __get__(self, obj, cls):
-        if obj is None:
-            return self
-        value = obj.__dict__[self.func.__name__] = self.func(obj)
-        return value
+def to_seconds(time_unit: time_unit_type) -> float:
+    return float(time_unit.total_seconds() if isinstance(time_unit, timedelta) else time_unit)
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/after.py b/env/Lib/site-packages/pip/_vendor/tenacity/after.py
index c04e7c18..574c9bce 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/after.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/after.py
@@ -14,27 +14,38 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
+import typing
+
 from pip._vendor.tenacity import _utils
 
+if typing.TYPE_CHECKING:
+    import logging
+
+    from pip._vendor.tenacity import RetryCallState
+
 
-def after_nothing(retry_state):
+def after_nothing(retry_state: "RetryCallState") -> None:
     """After call strategy that does nothing."""
 
 
-def after_log(logger, log_level, sec_format="%0.3f"):
+def after_log(
+    logger: "logging.Logger",
+    log_level: int,
+    sec_format: str = "%0.3f",
+) -> typing.Callable[["RetryCallState"], None]:
     """After call strategy that logs to some logger the finished attempt."""
-    log_tpl = (
-        "Finished call to '%s' after " + str(sec_format) + "(s), "
-        "this was the %s time calling it."
-    )
 
-    def log_it(retry_state):
+    def log_it(retry_state: "RetryCallState") -> None:
+        if retry_state.fn is None:
+            # NOTE(sileht): can't really happen, but we must please mypy
+            fn_name = "<unknown>"
+        else:
+            fn_name = _utils.get_callback_name(retry_state.fn)
         logger.log(
             log_level,
-            log_tpl,
-            _utils.get_callback_name(retry_state.fn),
-            retry_state.seconds_since_start,
-            _utils.to_ordinal(retry_state.attempt_number),
+            f"Finished call to '{fn_name}' "
+            f"after {sec_format % retry_state.seconds_since_start}(s), "
+            f"this was the {_utils.to_ordinal(retry_state.attempt_number)} time calling it.",
         )
 
     return log_it
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/before.py b/env/Lib/site-packages/pip/_vendor/tenacity/before.py
index 3229517d..cfd7dc72 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/before.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/before.py
@@ -14,22 +14,33 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
+import typing
+
 from pip._vendor.tenacity import _utils
 
+if typing.TYPE_CHECKING:
+    import logging
+
+    from pip._vendor.tenacity import RetryCallState
+
 
-def before_nothing(retry_state):
+def before_nothing(retry_state: "RetryCallState") -> None:
     """Before call strategy that does nothing."""
 
 
-def before_log(logger, log_level):
+def before_log(logger: "logging.Logger", log_level: int) -> typing.Callable[["RetryCallState"], None]:
     """Before call strategy that logs to some logger the attempt."""
 
-    def log_it(retry_state):
+    def log_it(retry_state: "RetryCallState") -> None:
+        if retry_state.fn is None:
+            # NOTE(sileht): can't really happen, but we must please mypy
+            fn_name = "<unknown>"
+        else:
+            fn_name = _utils.get_callback_name(retry_state.fn)
         logger.log(
             log_level,
-            "Starting call to '%s', this is the %s time calling it.",
-            _utils.get_callback_name(retry_state.fn),
-            _utils.to_ordinal(retry_state.attempt_number),
+            f"Starting call to '{fn_name}', "
+            f"this is the {_utils.to_ordinal(retry_state.attempt_number)} time calling it.",
         )
 
     return log_it
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py b/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py
index a051acac..8c6167fb 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/before_sleep.py
@@ -14,37 +14,57 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 
+import typing
+
 from pip._vendor.tenacity import _utils
-from pip._vendor.tenacity.compat import get_exc_info_from_future
 
+if typing.TYPE_CHECKING:
+    import logging
+
+    from pip._vendor.tenacity import RetryCallState
 
-def before_sleep_nothing(retry_state):
+
+def before_sleep_nothing(retry_state: "RetryCallState") -> None:
     """Before call strategy that does nothing."""
 
 
-def before_sleep_log(logger, log_level, exc_info=False):
+def before_sleep_log(
+    logger: "logging.Logger",
+    log_level: int,
+    exc_info: bool = False,
+) -> typing.Callable[["RetryCallState"], None]:
     """Before call strategy that logs to some logger the attempt."""
 
-    def log_it(retry_state):
+    def log_it(retry_state: "RetryCallState") -> None:
+        local_exc_info: BaseException | bool | None
+
+        if retry_state.outcome is None:
+            raise RuntimeError("log_it() called before outcome was set")
+
+        if retry_state.next_action is None:
+            raise RuntimeError("log_it() called before next_action was set")
+
         if retry_state.outcome.failed:
             ex = retry_state.outcome.exception()
-            verb, value = "raised", "%s: %s" % (type(ex).__name__, ex)
+            verb, value = "raised", f"{ex.__class__.__name__}: {ex}"
 
             if exc_info:
-                local_exc_info = get_exc_info_from_future(retry_state.outcome)
+                local_exc_info = retry_state.outcome.exception()
             else:
                 local_exc_info = False
         else:
             verb, value = "returned", retry_state.outcome.result()
             local_exc_info = False  # exc_info does not apply when no exception
 
+        if retry_state.fn is None:
+            # NOTE(sileht): can't really happen, but we must please mypy
+            fn_name = "<unknown>"
+        else:
+            fn_name = _utils.get_callback_name(retry_state.fn)
+
         logger.log(
             log_level,
-            "Retrying %s in %s seconds as it %s %s.",
-            _utils.get_callback_name(retry_state.fn),
-            getattr(retry_state.next_action, "sleep"),
-            verb,
-            value,
+            f"Retrying {fn_name} " f"in {retry_state.next_action.sleep} seconds as it {verb} {value}.",
             exc_info=local_exc_info,
         )
 
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/compat.py b/env/Lib/site-packages/pip/_vendor/tenacity/compat.py
deleted file mode 100644
index ce4796b1..00000000
--- a/env/Lib/site-packages/pip/_vendor/tenacity/compat.py
+++ /dev/null
@@ -1,23 +0,0 @@
-"""Utilities for providing backward compatibility."""
-from pip._vendor import six
-
-
-def get_exc_info_from_future(future):
-    """
-    Get an exc_info value from a Future.
-
-    Given a a Future instance, retrieve an exc_info value suitable for passing
-    in as the exc_info parameter to logging.Logger.log() and related methods.
-
-    On Python 2, this will be a (type, value, traceback) triple.
-    On Python 3, this will be an exception instance (with embedded traceback).
-
-    If there was no exception, None is returned on both versions of Python.
-    """
-    if six.PY3:
-        return future.exception()
-    else:
-        ex, tb = future.exception_info()
-        if ex is None:
-            return None
-        return type(ex), ex, tb
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/nap.py b/env/Lib/site-packages/pip/_vendor/tenacity/nap.py
index 83ff839c..72aa5bfd 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/nap.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/nap.py
@@ -1,4 +1,3 @@
-# -*- coding: utf-8 -*-
 # Copyright 2016 Étienne Bersac
 # Copyright 2016 Julien Danjou
 # Copyright 2016 Joshua Harlow
@@ -17,9 +16,13 @@
 # limitations under the License.
 
 import time
+import typing
 
+if typing.TYPE_CHECKING:
+    import threading
 
-def sleep(seconds):
+
+def sleep(seconds: float) -> None:
     """
     Sleep strategy that delays execution for a given number of seconds.
 
@@ -28,13 +31,13 @@ def sleep(seconds):
     time.sleep(seconds)
 
 
-class sleep_using_event(object):
+class sleep_using_event:
     """Sleep strategy that waits on an event to be set."""
 
-    def __init__(self, event):
+    def __init__(self, event: "threading.Event") -> None:
         self.event = event
 
-    def __call__(self, timeout):
+    def __call__(self, timeout: typing.Optional[float]) -> None:
         # NOTE(harlowja): this may *not* actually wait for timeout
         # seconds if the event is set (ie this may eject out early).
         self.event.wait(timeout=timeout)
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/retry.py b/env/Lib/site-packages/pip/_vendor/tenacity/retry.py
index ddaf8e7f..38988739 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/retry.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/retry.py
@@ -1,5 +1,3 @@
-# -*- encoding: utf-8 -*-
-#
 # Copyright 2016–2021 Julien Danjou
 # Copyright 2016 Joshua Harlow
 # Copyright 2013-2014 Ray Holder
@@ -18,29 +16,33 @@
 
 import abc
 import re
+import typing
 
-from pip._vendor import six
+if typing.TYPE_CHECKING:
+    from pip._vendor.tenacity import RetryCallState
 
 
-@six.add_metaclass(abc.ABCMeta)
-class retry_base(object):
+class retry_base(abc.ABC):
     """Abstract base class for retry strategies."""
 
     @abc.abstractmethod
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         pass
 
-    def __and__(self, other):
+    def __and__(self, other: "retry_base") -> "retry_all":
         return retry_all(self, other)
 
-    def __or__(self, other):
+    def __or__(self, other: "retry_base") -> "retry_any":
         return retry_any(self, other)
 
 
+RetryBaseT = typing.Union[retry_base, typing.Callable[["RetryCallState"], bool]]
+
+
 class _retry_never(retry_base):
     """Retry strategy that never rejects any result."""
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return False
 
 
@@ -50,7 +52,7 @@ retry_never = _retry_never()
 class _retry_always(retry_base):
     """Retry strategy that always rejects any result."""
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return True
 
 
@@ -60,12 +62,18 @@ retry_always = _retry_always()
 class retry_if_exception(retry_base):
     """Retry strategy that retries if an exception verifies a predicate."""
 
-    def __init__(self, predicate):
+    def __init__(self, predicate: typing.Callable[[BaseException], bool]) -> None:
         self.predicate = predicate
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.outcome is None:
+            raise RuntimeError("__call__() called before outcome was set")
+
         if retry_state.outcome.failed:
-            return self.predicate(retry_state.outcome.exception())
+            exception = retry_state.outcome.exception()
+            if exception is None:
+                raise RuntimeError("outcome failed but the exception is None")
+            return self.predicate(exception)
         else:
             return False
 
@@ -73,36 +81,98 @@ class retry_if_exception(retry_base):
 class retry_if_exception_type(retry_if_exception):
     """Retries if an exception has been raised of one or more types."""
 
-    def __init__(self, exception_types=Exception):
+    def __init__(
+        self,
+        exception_types: typing.Union[
+            typing.Type[BaseException],
+            typing.Tuple[typing.Type[BaseException], ...],
+        ] = Exception,
+    ) -> None:
+        self.exception_types = exception_types
+        super().__init__(lambda e: isinstance(e, exception_types))
+
+
+class retry_if_not_exception_type(retry_if_exception):
+    """Retries except an exception has been raised of one or more types."""
+
+    def __init__(
+        self,
+        exception_types: typing.Union[
+            typing.Type[BaseException],
+            typing.Tuple[typing.Type[BaseException], ...],
+        ] = Exception,
+    ) -> None:
         self.exception_types = exception_types
-        super(retry_if_exception_type, self).__init__(
-            lambda e: isinstance(e, exception_types)
-        )
+        super().__init__(lambda e: not isinstance(e, exception_types))
 
 
 class retry_unless_exception_type(retry_if_exception):
     """Retries until an exception is raised of one or more types."""
 
-    def __init__(self, exception_types=Exception):
+    def __init__(
+        self,
+        exception_types: typing.Union[
+            typing.Type[BaseException],
+            typing.Tuple[typing.Type[BaseException], ...],
+        ] = Exception,
+    ) -> None:
         self.exception_types = exception_types
-        super(retry_unless_exception_type, self).__init__(
-            lambda e: not isinstance(e, exception_types)
-        )
+        super().__init__(lambda e: not isinstance(e, exception_types))
+
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.outcome is None:
+            raise RuntimeError("__call__() called before outcome was set")
 
-    def __call__(self, retry_state):
         # always retry if no exception was raised
         if not retry_state.outcome.failed:
             return True
-        return self.predicate(retry_state.outcome.exception())
+
+        exception = retry_state.outcome.exception()
+        if exception is None:
+            raise RuntimeError("outcome failed but the exception is None")
+        return self.predicate(exception)
+
+
+class retry_if_exception_cause_type(retry_base):
+    """Retries if any of the causes of the raised exception is of one or more types.
+
+    The check on the type of the cause of the exception is done recursively (until finding
+    an exception in the chain that has no `__cause__`)
+    """
+
+    def __init__(
+        self,
+        exception_types: typing.Union[
+            typing.Type[BaseException],
+            typing.Tuple[typing.Type[BaseException], ...],
+        ] = Exception,
+    ) -> None:
+        self.exception_cause_types = exception_types
+
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.outcome is None:
+            raise RuntimeError("__call__ called before outcome was set")
+
+        if retry_state.outcome.failed:
+            exc = retry_state.outcome.exception()
+            while exc is not None:
+                if isinstance(exc.__cause__, self.exception_cause_types):
+                    return True
+                exc = exc.__cause__
+
+        return False
 
 
 class retry_if_result(retry_base):
     """Retries if the result verifies a predicate."""
 
-    def __init__(self, predicate):
+    def __init__(self, predicate: typing.Callable[[typing.Any], bool]) -> None:
         self.predicate = predicate
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.outcome is None:
+            raise RuntimeError("__call__() called before outcome was set")
+
         if not retry_state.outcome.failed:
             return self.predicate(retry_state.outcome.result())
         else:
@@ -112,10 +182,13 @@ class retry_if_result(retry_base):
 class retry_if_not_result(retry_base):
     """Retries if the result refutes a predicate."""
 
-    def __init__(self, predicate):
+    def __init__(self, predicate: typing.Callable[[typing.Any], bool]) -> None:
         self.predicate = predicate
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.outcome is None:
+            raise RuntimeError("__call__() called before outcome was set")
+
         if not retry_state.outcome.failed:
             return not self.predicate(retry_state.outcome.result())
         else:
@@ -125,68 +198,75 @@ class retry_if_not_result(retry_base):
 class retry_if_exception_message(retry_if_exception):
     """Retries if an exception message equals or matches."""
 
-    def __init__(self, message=None, match=None):
+    def __init__(
+        self,
+        message: typing.Optional[str] = None,
+        match: typing.Optional[str] = None,
+    ) -> None:
         if message and match:
-            raise TypeError(
-                "{}() takes either 'message' or 'match', not both".format(
-                    self.__class__.__name__
-                )
-            )
+            raise TypeError(f"{self.__class__.__name__}() takes either 'message' or 'match', not both")
 
         # set predicate
         if message:
 
-            def message_fnc(exception):
+            def message_fnc(exception: BaseException) -> bool:
                 return message == str(exception)
 
             predicate = message_fnc
         elif match:
             prog = re.compile(match)
 
-            def match_fnc(exception):
-                return prog.match(str(exception))
+            def match_fnc(exception: BaseException) -> bool:
+                return bool(prog.match(str(exception)))
 
             predicate = match_fnc
         else:
-            raise TypeError(
-                "{}() missing 1 required argument 'message' or 'match'".format(
-                    self.__class__.__name__
-                )
-            )
+            raise TypeError(f"{self.__class__.__name__}() missing 1 required argument 'message' or 'match'")
 
-        super(retry_if_exception_message, self).__init__(predicate)
+        super().__init__(predicate)
 
 
 class retry_if_not_exception_message(retry_if_exception_message):
     """Retries until an exception message equals or matches."""
 
-    def __init__(self, *args, **kwargs):
-        super(retry_if_not_exception_message, self).__init__(*args, **kwargs)
+    def __init__(
+        self,
+        message: typing.Optional[str] = None,
+        match: typing.Optional[str] = None,
+    ) -> None:
+        super().__init__(message, match)
         # invert predicate
         if_predicate = self.predicate
         self.predicate = lambda *args_, **kwargs_: not if_predicate(*args_, **kwargs_)
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.outcome is None:
+            raise RuntimeError("__call__() called before outcome was set")
+
         if not retry_state.outcome.failed:
             return True
-        return self.predicate(retry_state.outcome.exception())
+
+        exception = retry_state.outcome.exception()
+        if exception is None:
+            raise RuntimeError("outcome failed but the exception is None")
+        return self.predicate(exception)
 
 
 class retry_any(retry_base):
     """Retries if any of the retries condition is valid."""
 
-    def __init__(self, *retries):
+    def __init__(self, *retries: retry_base) -> None:
         self.retries = retries
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return any(r(retry_state) for r in self.retries)
 
 
 class retry_all(retry_base):
     """Retries if all the retries condition are valid."""
 
-    def __init__(self, *retries):
+    def __init__(self, *retries: retry_base) -> None:
         self.retries = retries
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return all(r(retry_state) for r in self.retries)
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/stop.py b/env/Lib/site-packages/pip/_vendor/tenacity/stop.py
index 4db27f14..bb23effd 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/stop.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/stop.py
@@ -1,5 +1,3 @@
-# -*- encoding: utf-8 -*-
-#
 # Copyright 2016–2021 Julien Danjou
 # Copyright 2016 Joshua Harlow
 # Copyright 2013-2014 Ray Holder
@@ -16,49 +14,57 @@
 # See the License for the specific language governing permissions and
 # limitations under the License.
 import abc
+import typing
+
+from pip._vendor.tenacity import _utils
+
+if typing.TYPE_CHECKING:
+    import threading
 
-from pip._vendor import six
+    from pip._vendor.tenacity import RetryCallState
 
 
-@six.add_metaclass(abc.ABCMeta)
-class stop_base(object):
+class stop_base(abc.ABC):
     """Abstract base class for stop strategies."""
 
     @abc.abstractmethod
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         pass
 
-    def __and__(self, other):
+    def __and__(self, other: "stop_base") -> "stop_all":
         return stop_all(self, other)
 
-    def __or__(self, other):
+    def __or__(self, other: "stop_base") -> "stop_any":
         return stop_any(self, other)
 
 
+StopBaseT = typing.Union[stop_base, typing.Callable[["RetryCallState"], bool]]
+
+
 class stop_any(stop_base):
     """Stop if any of the stop condition is valid."""
 
-    def __init__(self, *stops):
+    def __init__(self, *stops: stop_base) -> None:
         self.stops = stops
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return any(x(retry_state) for x in self.stops)
 
 
 class stop_all(stop_base):
     """Stop if all the stop conditions are valid."""
 
-    def __init__(self, *stops):
+    def __init__(self, *stops: stop_base) -> None:
         self.stops = stops
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return all(x(retry_state) for x in self.stops)
 
 
 class _stop_never(stop_base):
     """Never stop."""
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return False
 
 
@@ -68,28 +74,30 @@ stop_never = _stop_never()
 class stop_when_event_set(stop_base):
     """Stop when the given event is set."""
 
-    def __init__(self, event):
+    def __init__(self, event: "threading.Event") -> None:
         self.event = event
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return self.event.is_set()
 
 
 class stop_after_attempt(stop_base):
     """Stop when the previous attempt >= max_attempt."""
 
-    def __init__(self, max_attempt_number):
+    def __init__(self, max_attempt_number: int) -> None:
         self.max_attempt_number = max_attempt_number
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
         return retry_state.attempt_number >= self.max_attempt_number
 
 
 class stop_after_delay(stop_base):
     """Stop when the time from the first attempt >= limit."""
 
-    def __init__(self, max_delay):
-        self.max_delay = max_delay
+    def __init__(self, max_delay: _utils.time_unit_type) -> None:
+        self.max_delay = _utils.to_seconds(max_delay)
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> bool:
+        if retry_state.seconds_since_start is None:
+            raise RuntimeError("__call__() called but seconds_since_start is not set")
         return retry_state.seconds_since_start >= self.max_delay
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py b/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py
index dbf9f762..e19c30b1 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/tornadoweb.py
@@ -1,4 +1,3 @@
-# -*- coding: utf-8 -*-
 # Copyright 2017 Elisey Zanko
 #
 # Licensed under the Apache License, Version 2.0 (the "License");
@@ -14,6 +13,7 @@
 # limitations under the License.
 
 import sys
+import typing
 
 from pip._vendor.tenacity import BaseRetrying
 from pip._vendor.tenacity import DoAttempt
@@ -22,15 +22,25 @@ from pip._vendor.tenacity import RetryCallState
 
 from tornado import gen
 
+if typing.TYPE_CHECKING:
+    from tornado.concurrent import Future
+
+_RetValT = typing.TypeVar("_RetValT")
+
 
 class TornadoRetrying(BaseRetrying):
-    def __init__(self, sleep=gen.sleep, **kwargs):
-        super(TornadoRetrying, self).__init__(**kwargs)
+    def __init__(self, sleep: "typing.Callable[[float], Future[None]]" = gen.sleep, **kwargs: typing.Any) -> None:
+        super().__init__(**kwargs)
         self.sleep = sleep
 
-    @gen.coroutine
-    def __call__(self, fn, *args, **kwargs):
-        self.begin(fn)
+    @gen.coroutine  # type: ignore[misc]
+    def __call__(
+        self,
+        fn: "typing.Callable[..., typing.Union[typing.Generator[typing.Any, typing.Any, _RetValT], Future[_RetValT]]]",
+        *args: typing.Any,
+        **kwargs: typing.Any,
+    ) -> "typing.Generator[typing.Any, typing.Any, _RetValT]":
+        self.begin()
 
         retry_state = RetryCallState(retry_object=self, fn=fn, args=args, kwargs=kwargs)
         while True:
@@ -39,7 +49,7 @@ class TornadoRetrying(BaseRetrying):
                 try:
                     result = yield fn(*args, **kwargs)
                 except BaseException:  # noqa: B902
-                    retry_state.set_exception(sys.exc_info())
+                    retry_state.set_exception(sys.exc_info())  # type: ignore[arg-type]
                 else:
                     retry_state.set_result(result)
             elif isinstance(do, DoSleep):
diff --git a/env/Lib/site-packages/pip/_vendor/tenacity/wait.py b/env/Lib/site-packages/pip/_vendor/tenacity/wait.py
index 625b0e36..f9349c02 100644
--- a/env/Lib/site-packages/pip/_vendor/tenacity/wait.py
+++ b/env/Lib/site-packages/pip/_vendor/tenacity/wait.py
@@ -1,5 +1,3 @@
-# -*- encoding: utf-8 -*-
-#
 # Copyright 2016–2021 Julien Danjou
 # Copyright 2016 Joshua Harlow
 # Copyright 2013-2014 Ray Holder
@@ -18,67 +16,69 @@
 
 import abc
 import random
-
-from pip._vendor import six
+import typing
 
 from pip._vendor.tenacity import _utils
 
+if typing.TYPE_CHECKING:
+    from pip._vendor.tenacity import RetryCallState
+
 
-@six.add_metaclass(abc.ABCMeta)
-class wait_base(object):
+class wait_base(abc.ABC):
     """Abstract base class for wait strategies."""
 
     @abc.abstractmethod
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> float:
         pass
 
-    def __add__(self, other):
+    def __add__(self, other: "wait_base") -> "wait_combine":
         return wait_combine(self, other)
 
-    def __radd__(self, other):
+    def __radd__(self, other: "wait_base") -> typing.Union["wait_combine", "wait_base"]:
         # make it possible to use multiple waits with the built-in sum function
-        if other == 0:
+        if other == 0:  # type: ignore[comparison-overlap]
             return self
         return self.__add__(other)
 
 
+WaitBaseT = typing.Union[wait_base, typing.Callable[["RetryCallState"], typing.Union[float, int]]]
+
+
 class wait_fixed(wait_base):
     """Wait strategy that waits a fixed amount of time between each retry."""
 
-    def __init__(self, wait):
-        self.wait_fixed = wait
+    def __init__(self, wait: _utils.time_unit_type) -> None:
+        self.wait_fixed = _utils.to_seconds(wait)
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> float:
         return self.wait_fixed
 
 
 class wait_none(wait_fixed):
     """Wait strategy that doesn't wait at all before retrying."""
 
-    def __init__(self):
-        super(wait_none, self).__init__(0)
+    def __init__(self) -> None:
+        super().__init__(0)
 
 
 class wait_random(wait_base):
     """Wait strategy that waits a random amount of time between min/max."""
 
-    def __init__(self, min=0, max=1):  # noqa
-        self.wait_random_min = min
-        self.wait_random_max = max
+    def __init__(self, min: _utils.time_unit_type = 0, max: _utils.time_unit_type = 1) -> None:  # noqa
+        self.wait_random_min = _utils.to_seconds(min)
+        self.wait_random_max = _utils.to_seconds(max)
 
-    def __call__(self, retry_state):
-        return self.wait_random_min + (
-            random.random() * (self.wait_random_max - self.wait_random_min)
-        )
+    def __call__(self, retry_state: "RetryCallState") -> float:
+        return self.wait_random_min + (random.random() * (self.wait_random_max - self.wait_random_min))
 
 
 class wait_combine(wait_base):
     """Combine several waiting strategies."""
 
-    def __init__(self, *strategies):
+    def __init__(self, *strategies: wait_base) -> None:
         self.wait_funcs = strategies
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> float:
         return sum(x(retry_state=retry_state) for x in self.wait_funcs)
 
 
@@ -98,10 +98,10 @@ class wait_chain(wait_base):
                    thereafter.")
     """
 
-    def __init__(self, *strategies):
+    def __init__(self, *strategies: wait_base) -> None:
         self.strategies = strategies
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> float:
         wait_func_no = min(max(retry_state.attempt_number, 1), len(self.strategies))
         wait_func = self.strategies[wait_func_no - 1]
         return wait_func(retry_state=retry_state)
@@ -114,12 +114,17 @@ class wait_incrementing(wait_base):
     (and restricting the upper limit to some maximum value).
     """
 
-    def __init__(self, start=0, increment=100, max=_utils.MAX_WAIT):  # noqa
-        self.start = start
-        self.increment = increment
-        self.max = max
-
-    def __call__(self, retry_state):
+    def __init__(
+        self,
+        start: _utils.time_unit_type = 0,
+        increment: _utils.time_unit_type = 100,
+        max: _utils.time_unit_type = _utils.MAX_WAIT,  # noqa
+    ) -> None:
+        self.start = _utils.to_seconds(start)
+        self.increment = _utils.to_seconds(increment)
+        self.max = _utils.to_seconds(max)
+
+    def __call__(self, retry_state: "RetryCallState") -> float:
         result = self.start + (self.increment * (retry_state.attempt_number - 1))
         return max(0, min(result, self.max))
 
@@ -137,13 +142,19 @@ class wait_exponential(wait_base):
     wait_random_exponential for the latter case.
     """
 
-    def __init__(self, multiplier=1, max=_utils.MAX_WAIT, exp_base=2, min=0):  # noqa
+    def __init__(
+        self,
+        multiplier: typing.Union[int, float] = 1,
+        max: _utils.time_unit_type = _utils.MAX_WAIT,  # noqa
+        exp_base: typing.Union[int, float] = 2,
+        min: _utils.time_unit_type = 0,  # noqa
+    ) -> None:
         self.multiplier = multiplier
-        self.min = min
-        self.max = max
+        self.min = _utils.to_seconds(min)
+        self.max = _utils.to_seconds(max)
         self.exp_base = exp_base
 
-    def __call__(self, retry_state):
+    def __call__(self, retry_state: "RetryCallState") -> float:
         try:
             exp = self.exp_base ** (retry_state.attempt_number - 1)
             result = self.multiplier * exp
@@ -178,6 +189,40 @@ class wait_random_exponential(wait_exponential):
 
     """
 
-    def __call__(self, retry_state):
-        high = super(wait_random_exponential, self).__call__(retry_state=retry_state)
+    def __call__(self, retry_state: "RetryCallState") -> float:
+        high = super().__call__(retry_state=retry_state)
         return random.uniform(0, high)
+
+
+class wait_exponential_jitter(wait_base):
+    """Wait strategy that applies exponential backoff and jitter.
+
+    It allows for a customized initial wait, maximum wait and jitter.
+
+    This implements the strategy described here:
+    https://cloud.google.com/storage/docs/retry-strategy
+
+    The wait time is min(initial * 2**n + random.uniform(0, jitter), maximum)
+    where n is the retry count.
+    """
+
+    def __init__(
+        self,
+        initial: float = 1,
+        max: float = _utils.MAX_WAIT,  # noqa
+        exp_base: float = 2,
+        jitter: float = 1,
+    ) -> None:
+        self.initial = initial
+        self.max = max
+        self.exp_base = exp_base
+        self.jitter = jitter
+
+    def __call__(self, retry_state: "RetryCallState") -> float:
+        jitter = random.uniform(0, self.jitter)
+        try:
+            exp = self.exp_base ** (retry_state.attempt_number - 1)
+            result = self.initial * exp + jitter
+        except OverflowError:
+            result = self.max
+        return max(0, min(result, self.max))
diff --git a/env/Lib/site-packages/pip/_vendor/toml/__init__.py b/env/Lib/site-packages/pip/_vendor/toml/__init__.py
deleted file mode 100644
index 34a5eabb..00000000
--- a/env/Lib/site-packages/pip/_vendor/toml/__init__.py
+++ /dev/null
@@ -1,25 +0,0 @@
-"""Python module which parses and emits TOML.
-
-Released under the MIT license.
-"""
-
-from pip._vendor.toml import encoder
-from pip._vendor.toml import decoder
-
-__version__ = "0.10.2"
-_spec_ = "0.5.0"
-
-load = decoder.load
-loads = decoder.loads
-TomlDecoder = decoder.TomlDecoder
-TomlDecodeError = decoder.TomlDecodeError
-TomlPreserveCommentDecoder = decoder.TomlPreserveCommentDecoder
-
-dump = encoder.dump
-dumps = encoder.dumps
-TomlEncoder = encoder.TomlEncoder
-TomlArraySeparatorEncoder = encoder.TomlArraySeparatorEncoder
-TomlPreserveInlineDictEncoder = encoder.TomlPreserveInlineDictEncoder
-TomlNumpyEncoder = encoder.TomlNumpyEncoder
-TomlPreserveCommentEncoder = encoder.TomlPreserveCommentEncoder
-TomlPathlibEncoder = encoder.TomlPathlibEncoder
diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index ca82ded3eb81ec38fe627461a835663545c2b4bd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 760
zcmYe~<>g{vU|^UdaWM5Y69dCz5C<7EF)%PVFfcF_moYFfq%cG=q%fv1<uK+lMKLjg
z*vvVMxy(__j0`C(Q7kE}QLL%VS!_{ksmxjIQS7PASsYOusmxiNQJksFSzJ+EsZ3ei
zQQWCaSv*lZsZ3eCQM{>4S$t7^sZ3e?QT(Y)Sprc4sZ3ddQG%&VSwc}lDQv+En(S3R
z0hJ{g`FRSt`6;D2sS4#8naLRn1&Kw)sl^J3c_|91xtS%!3L*Z!K6+eSL8&>ZiN&cY
z3Z;1|sYMDU8L0}so*@c3naQbn#i@E+FG2p(WW2?mnwOlPl3D~}rlf+IRcr=&h6Z{@
zRjdYjrg{c`n!>l(<Kt8EljGx~1PU?>^y14>^HTDQ^h)w`bBaJ=Q^d@`z;KH@KE5oq
zs5mn}FFyVjTYParYI6K7mYn>=lv}JIviKHvNPcdP3&fUN{0NR~QBi);Eh&&dKv8OO
zYEfCLbAE1aYF-IUF-uBmZow^95D7KL72@t&k|14<MMa5~!Knp_MTsT(MKCE@kQB^7
z&%B(>yi}LW<Pw;)07%-eG`FA<CW6fcFgYQR>VU+OjGW9QsMtz|A`u1#2=S}d*(xTq
zIJKxaCN(D|vna+tFV&?evn*9XS0U8TGt4z8*fYd2Si#fJ#oy00*wZm4*wxoHIK(wb
z!7L^qz$YfrL^mftJ+rtZGdm_VuPnwVGbyGxvm{lwATc>RF+H_7rXaIG9~$)fprF@}
vkI&4@EQycTE2zB1VUr6^7IuuFbgIO_z`(-F!^p$L!pOqJ#t4N77FYxTi}U7p

diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/decoder.cpython-39.pyc
deleted file mode 100644
index ee3886f5664d4469ce2cb19412609f523febcade..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 23252
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%0AtE6#vDkb`+*z<ius}#1_p*gP#vQO
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
M0xSX`v3dq603W2I&;S4c

diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/encoder.cpython-39.pyc
deleted file mode 100644
index 8b97b1bb72931a01834061a9be164ebc033076c5..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9435
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
BQ5FCI

diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/ordered.cpython-39.pyc
deleted file mode 100644
index 90cfae58691e54ede44f5243c98e1955324a18e1..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 999
zcmYe~<>g{vU|^UdaWJ)tk%8ech=Yt-7#J8F7#J9eJs21mQW#Pga~N_NqZk=MY^EHh
zT;?cdFq=7tDVHURg^|IXA%!J{wS^&tHI=2AIf~VtA%!i4y@er#J(ancIf^ZXBbY&x
z^Cid*O~zZ?{zWONMX4z+naL#}Zb*J^j%!|WeoAT)jO&sL<|c!5AY*1Ir&xx8fgzP4
ziZO*Dim9C;jWLBWg{g%jin*PEg&~S1m_d{ImJrBXm{m~o7@_(>6o?Hn4}^;)7#J8z
z7-|@@7;6}snX;Hlm{S;g!9EUVSjpt4$#{!3J|#1`WF^Zj*5cBF)S_FQ@$tzyiN(e7
z@wYhQ<1_OzOXA~;m>3usRx;jVDNfBvTgg}i3g(pzziOPVVnT~ki;81Xb5b&kV*K+`
zU5YZxQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(O
zi%T-IV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9CK@^f?a^C3a3S5R5R
z&A`CG0g6qK;}{sLq%p%q59WcDtRT<iCFZ8a$KT?LkI&6dDa`?~dE(;>OA~V-GGHTb
z@j?S2IW;FIKE8;bfq?-+@PSwYAcB>Ffq@NXH3w4>h)=aRg(jI~P&|U-6NEu*P<(<g
z-Z(7+Ijaa1EJZvZmxA34_5#@9pfCdo6=MlAsJ-woD-r}50M-j8K>CWnrid{xFn~-4
zo5I0V1mgQ?vftuP&d<q7O)kmI&npHenJ9sR%mO`V1nPkzun6RXB2Y#I2O3x_By_=c
cfC-Qtw>WGdabySbdNIgDJd8YyJj?=Y09~`)SpWb4

diff --git a/env/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/toml/__pycache__/tz.cpython-39.pyc
deleted file mode 100644
index 648184f27d9f9fa32c959539c8b12e66a5449dba..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1301
zcmYe~<>g{vU|^UdaWHi+69dCz5C<8vFfcGUFfcF_t1vJyq%fo~<}l<kMlt3xMKLil
zxHF_Mr7*WJq%fy4HZw;tr?3PwXtKTp>DOes#a2?4nU|J-i?bv%H#H?Srz9~MB!i5Z
zV5XZeFfgPtL@}l?L@}i>rZBZIL@}o@r?9jzM6sl>rm(dzM6sr@r*O0|M6soCrf{_|
zM6suE2Qz5$++qvK&&>&`N(Pw)GaJMPx!f7#@+bxdh8o5c#%!h{ffS}1hIocNwi-qd
zUBi&Ykism<kiwG9RHTu@n#YvFR>Kg_Si%IBVM}3eWs+oQ2B~F+igBcH!o^rp7=jrz
zx%_T1MpdzC8yHv_7!)xwFfjaL)P4E?|Ns9lL7bP&3=9k}L5_LJ#=yX!$$E=Bz9_Lg
zK0ht3IJM*!YkYBLdfqMO%)F9YZ1EZSrA5WJIO20N^GZuni#3^Uu@tA~q}}2!$<NJ!
zYFWupBn+~o+}SE7v^ce>I3_hGC9^2TKQGm#D6=e8L02Kv&oj(5DA+T^F<8OV&&A)*
zHQ3WJCfL>2H8{jINWm;7AiyUk(L^^VKRvU!Br`iEHLonjCo?IgII|>Gw;(Y&J25@A
zIHn-8KtH}LH7_N<NFU??{gNuZg34PQ@$s2?nI-Y@tf0{40fjju2O|d)8>0lH2xApL
zBtG<DsxTr36d>S;0covaSin%jkj1!=F_=M<(NB}<7H52Xa!z7#aeRCcNP#9(kst#D
z!!4HF)ZBcq&mn{eNRTH!J|#7^AUVIFGCrOU<Q!1UGcZ;O!ySQ;$8ZQpE!ZKTERezo
zigR&Lj57J%Vh#;))?@@bU?tQ6OerN0n?a#p1h$^7q$)2lHx=Z*Vvu1Bj8(i)iy<-?
zR)T^IY^4||Q8HvPlz^-SB{$|2#$F~7i1nIGw^$)bfgP3-Sc-TV7#NB`VOPWtVhMl<
zDG&j6510TuinFvN8Irg_T$sBApzeZ8VmJ-t0kG3J7#J8z7*ZIUK~ciw2TszOj1a4_
zS;(AHTq2GX_FPb_Qi@CbG&w-Y1r$i}@wd3*<8$*<N^?@<<8SfA#}}3+=0IeML_z+L
z01+}ELLNjYfC#X+5Cq6aMWDO{!o{Fy<6z|A<X{Ftu(+Ql%Po$S#FA7{nNtMv62#pg
Z^+>S?HW6glEe;!qlk7lw6&zRs%m6T<7V`iA

diff --git a/env/Lib/site-packages/pip/_vendor/toml/decoder.py b/env/Lib/site-packages/pip/_vendor/toml/decoder.py
deleted file mode 100644
index e071100d..00000000
--- a/env/Lib/site-packages/pip/_vendor/toml/decoder.py
+++ /dev/null
@@ -1,1057 +0,0 @@
-import datetime
-import io
-from os import linesep
-import re
-import sys
-
-from pip._vendor.toml.tz import TomlTz
-
-if sys.version_info < (3,):
-    _range = xrange  # noqa: F821
-else:
-    unicode = str
-    _range = range
-    basestring = str
-    unichr = chr
-
-
-def _detect_pathlib_path(p):
-    if (3, 4) <= sys.version_info:
-        import pathlib
-        if isinstance(p, pathlib.PurePath):
-            return True
-    return False
-
-
-def _ispath(p):
-    if isinstance(p, (bytes, basestring)):
-        return True
-    return _detect_pathlib_path(p)
-
-
-def _getpath(p):
-    if (3, 6) <= sys.version_info:
-        import os
-        return os.fspath(p)
-    if _detect_pathlib_path(p):
-        return str(p)
-    return p
-
-
-try:
-    FNFError = FileNotFoundError
-except NameError:
-    FNFError = IOError
-
-
-TIME_RE = re.compile(r"([0-9]{2}):([0-9]{2}):([0-9]{2})(\.([0-9]{3,6}))?")
-
-
-class TomlDecodeError(ValueError):
-    """Base toml Exception / Error."""
-
-    def __init__(self, msg, doc, pos):
-        lineno = doc.count('\n', 0, pos) + 1
-        colno = pos - doc.rfind('\n', 0, pos)
-        emsg = '{} (line {} column {} char {})'.format(msg, lineno, colno, pos)
-        ValueError.__init__(self, emsg)
-        self.msg = msg
-        self.doc = doc
-        self.pos = pos
-        self.lineno = lineno
-        self.colno = colno
-
-
-# Matches a TOML number, which allows underscores for readability
-_number_with_underscores = re.compile('([0-9])(_([0-9]))*')
-
-
-class CommentValue(object):
-    def __init__(self, val, comment, beginline, _dict):
-        self.val = val
-        separator = "\n" if beginline else " "
-        self.comment = separator + comment
-        self._dict = _dict
-
-    def __getitem__(self, key):
-        return self.val[key]
-
-    def __setitem__(self, key, value):
-        self.val[key] = value
-
-    def dump(self, dump_value_func):
-        retstr = dump_value_func(self.val)
-        if isinstance(self.val, self._dict):
-            return self.comment + "\n" + unicode(retstr)
-        else:
-            return unicode(retstr) + self.comment
-
-
-def _strictly_valid_num(n):
-    n = n.strip()
-    if not n:
-        return False
-    if n[0] == '_':
-        return False
-    if n[-1] == '_':
-        return False
-    if "_." in n or "._" in n:
-        return False
-    if len(n) == 1:
-        return True
-    if n[0] == '0' and n[1] not in ['.', 'o', 'b', 'x']:
-        return False
-    if n[0] == '+' or n[0] == '-':
-        n = n[1:]
-        if len(n) > 1 and n[0] == '0' and n[1] != '.':
-            return False
-    if '__' in n:
-        return False
-    return True
-
-
-def load(f, _dict=dict, decoder=None):
-    """Parses named file or files as toml and returns a dictionary
-
-    Args:
-        f: Path to the file to open, array of files to read into single dict
-           or a file descriptor
-        _dict: (optional) Specifies the class of the returned toml dictionary
-        decoder: The decoder to use
-
-    Returns:
-        Parsed toml file represented as a dictionary
-
-    Raises:
-        TypeError -- When f is invalid type
-        TomlDecodeError: Error while decoding toml
-        IOError / FileNotFoundError -- When an array with no valid (existing)
-        (Python 2 / Python 3)          file paths is passed
-    """
-
-    if _ispath(f):
-        with io.open(_getpath(f), encoding='utf-8') as ffile:
-            return loads(ffile.read(), _dict, decoder)
-    elif isinstance(f, list):
-        from os import path as op
-        from warnings import warn
-        if not [path for path in f if op.exists(path)]:
-            error_msg = "Load expects a list to contain filenames only."
-            error_msg += linesep
-            error_msg += ("The list needs to contain the path of at least one "
-                          "existing file.")
-            raise FNFError(error_msg)
-        if decoder is None:
-            decoder = TomlDecoder(_dict)
-        d = decoder.get_empty_table()
-        for l in f:  # noqa: E741
-            if op.exists(l):
-                d.update(load(l, _dict, decoder))
-            else:
-                warn("Non-existent filename in list with at least one valid "
-                     "filename")
-        return d
-    else:
-        try:
-            return loads(f.read(), _dict, decoder)
-        except AttributeError:
-            raise TypeError("You can only load a file descriptor, filename or "
-                            "list")
-
-
-_groupname_re = re.compile(r'^[A-Za-z0-9_-]+$')
-
-
-def loads(s, _dict=dict, decoder=None):
-    """Parses string as toml
-
-    Args:
-        s: String to be parsed
-        _dict: (optional) Specifies the class of the returned toml dictionary
-
-    Returns:
-        Parsed toml file represented as a dictionary
-
-    Raises:
-        TypeError: When a non-string is passed
-        TomlDecodeError: Error while decoding toml
-    """
-
-    implicitgroups = []
-    if decoder is None:
-        decoder = TomlDecoder(_dict)
-    retval = decoder.get_empty_table()
-    currentlevel = retval
-    if not isinstance(s, basestring):
-        raise TypeError("Expecting something like a string")
-
-    if not isinstance(s, unicode):
-        s = s.decode('utf8')
-
-    original = s
-    sl = list(s)
-    openarr = 0
-    openstring = False
-    openstrchar = ""
-    multilinestr = False
-    arrayoftables = False
-    beginline = True
-    keygroup = False
-    dottedkey = False
-    keyname = 0
-    key = ''
-    prev_key = ''
-    line_no = 1
-
-    for i, item in enumerate(sl):
-        if item == '\r' and sl[i + 1] == '\n':
-            sl[i] = ' '
-            continue
-        if keyname:
-            key += item
-            if item == '\n':
-                raise TomlDecodeError("Key name found without value."
-                                      " Reached end of line.", original, i)
-            if openstring:
-                if item == openstrchar:
-                    oddbackslash = False
-                    k = 1
-                    while i >= k and sl[i - k] == '\\':
-                        oddbackslash = not oddbackslash
-                        k += 1
-                    if not oddbackslash:
-                        keyname = 2
-                        openstring = False
-                        openstrchar = ""
-                continue
-            elif keyname == 1:
-                if item.isspace():
-                    keyname = 2
-                    continue
-                elif item == '.':
-                    dottedkey = True
-                    continue
-                elif item.isalnum() or item == '_' or item == '-':
-                    continue
-                elif (dottedkey and sl[i - 1] == '.' and
-                      (item == '"' or item == "'")):
-                    openstring = True
-                    openstrchar = item
-                    continue
-            elif keyname == 2:
-                if item.isspace():
-                    if dottedkey:
-                        nextitem = sl[i + 1]
-                        if not nextitem.isspace() and nextitem != '.':
-                            keyname = 1
-                    continue
-                if item == '.':
-                    dottedkey = True
-                    nextitem = sl[i + 1]
-                    if not nextitem.isspace() and nextitem != '.':
-                        keyname = 1
-                    continue
-            if item == '=':
-                keyname = 0
-                prev_key = key[:-1].rstrip()
-                key = ''
-                dottedkey = False
-            else:
-                raise TomlDecodeError("Found invalid character in key name: '" +
-                                      item + "'. Try quoting the key name.",
-                                      original, i)
-        if item == "'" and openstrchar != '"':
-            k = 1
-            try:
-                while sl[i - k] == "'":
-                    k += 1
-                    if k == 3:
-                        break
-            except IndexError:
-                pass
-            if k == 3:
-                multilinestr = not multilinestr
-                openstring = multilinestr
-            else:
-                openstring = not openstring
-            if openstring:
-                openstrchar = "'"
-            else:
-                openstrchar = ""
-        if item == '"' and openstrchar != "'":
-            oddbackslash = False
-            k = 1
-            tripquote = False
-            try:
-                while sl[i - k] == '"':
-                    k += 1
-                    if k == 3:
-                        tripquote = True
-                        break
-                if k == 1 or (k == 3 and tripquote):
-                    while sl[i - k] == '\\':
-                        oddbackslash = not oddbackslash
-                        k += 1
-            except IndexError:
-                pass
-            if not oddbackslash:
-                if tripquote:
-                    multilinestr = not multilinestr
-                    openstring = multilinestr
-                else:
-                    openstring = not openstring
-            if openstring:
-                openstrchar = '"'
-            else:
-                openstrchar = ""
-        if item == '#' and (not openstring and not keygroup and
-                            not arrayoftables):
-            j = i
-            comment = ""
-            try:
-                while sl[j] != '\n':
-                    comment += s[j]
-                    sl[j] = ' '
-                    j += 1
-            except IndexError:
-                break
-            if not openarr:
-                decoder.preserve_comment(line_no, prev_key, comment, beginline)
-        if item == '[' and (not openstring and not keygroup and
-                            not arrayoftables):
-            if beginline:
-                if len(sl) > i + 1 and sl[i + 1] == '[':
-                    arrayoftables = True
-                else:
-                    keygroup = True
-            else:
-                openarr += 1
-        if item == ']' and not openstring:
-            if keygroup:
-                keygroup = False
-            elif arrayoftables:
-                if sl[i - 1] == ']':
-                    arrayoftables = False
-            else:
-                openarr -= 1
-        if item == '\n':
-            if openstring or multilinestr:
-                if not multilinestr:
-                    raise TomlDecodeError("Unbalanced quotes", original, i)
-                if ((sl[i - 1] == "'" or sl[i - 1] == '"') and (
-                        sl[i - 2] == sl[i - 1])):
-                    sl[i] = sl[i - 1]
-                    if sl[i - 3] == sl[i - 1]:
-                        sl[i - 3] = ' '
-            elif openarr:
-                sl[i] = ' '
-            else:
-                beginline = True
-            line_no += 1
-        elif beginline and sl[i] != ' ' and sl[i] != '\t':
-            beginline = False
-            if not keygroup and not arrayoftables:
-                if sl[i] == '=':
-                    raise TomlDecodeError("Found empty keyname. ", original, i)
-                keyname = 1
-                key += item
-    if keyname:
-        raise TomlDecodeError("Key name found without value."
-                              " Reached end of file.", original, len(s))
-    if openstring:  # reached EOF and have an unterminated string
-        raise TomlDecodeError("Unterminated string found."
-                              " Reached end of file.", original, len(s))
-    s = ''.join(sl)
-    s = s.split('\n')
-    multikey = None
-    multilinestr = ""
-    multibackslash = False
-    pos = 0
-    for idx, line in enumerate(s):
-        if idx > 0:
-            pos += len(s[idx - 1]) + 1
-
-        decoder.embed_comments(idx, currentlevel)
-
-        if not multilinestr or multibackslash or '\n' not in multilinestr:
-            line = line.strip()
-        if line == "" and (not multikey or multibackslash):
-            continue
-        if multikey:
-            if multibackslash:
-                multilinestr += line
-            else:
-                multilinestr += line
-            multibackslash = False
-            closed = False
-            if multilinestr[0] == '[':
-                closed = line[-1] == ']'
-            elif len(line) > 2:
-                closed = (line[-1] == multilinestr[0] and
-                          line[-2] == multilinestr[0] and
-                          line[-3] == multilinestr[0])
-            if closed:
-                try:
-                    value, vtype = decoder.load_value(multilinestr)
-                except ValueError as err:
-                    raise TomlDecodeError(str(err), original, pos)
-                currentlevel[multikey] = value
-                multikey = None
-                multilinestr = ""
-            else:
-                k = len(multilinestr) - 1
-                while k > -1 and multilinestr[k] == '\\':
-                    multibackslash = not multibackslash
-                    k -= 1
-                if multibackslash:
-                    multilinestr = multilinestr[:-1]
-                else:
-                    multilinestr += "\n"
-            continue
-        if line[0] == '[':
-            arrayoftables = False
-            if len(line) == 1:
-                raise TomlDecodeError("Opening key group bracket on line by "
-                                      "itself.", original, pos)
-            if line[1] == '[':
-                arrayoftables = True
-                line = line[2:]
-                splitstr = ']]'
-            else:
-                line = line[1:]
-                splitstr = ']'
-            i = 1
-            quotesplits = decoder._get_split_on_quotes(line)
-            quoted = False
-            for quotesplit in quotesplits:
-                if not quoted and splitstr in quotesplit:
-                    break
-                i += quotesplit.count(splitstr)
-                quoted = not quoted
-            line = line.split(splitstr, i)
-            if len(line) < i + 1 or line[-1].strip() != "":
-                raise TomlDecodeError("Key group not on a line by itself.",
-                                      original, pos)
-            groups = splitstr.join(line[:-1]).split('.')
-            i = 0
-            while i < len(groups):
-                groups[i] = groups[i].strip()
-                if len(groups[i]) > 0 and (groups[i][0] == '"' or
-                                           groups[i][0] == "'"):
-                    groupstr = groups[i]
-                    j = i + 1
-                    while ((not groupstr[0] == groupstr[-1]) or
-                           len(groupstr) == 1):
-                        j += 1
-                        if j > len(groups) + 2:
-                            raise TomlDecodeError("Invalid group name '" +
-                                                  groupstr + "' Something " +
-                                                  "went wrong.", original, pos)
-                        groupstr = '.'.join(groups[i:j]).strip()
-                    groups[i] = groupstr[1:-1]
-                    groups[i + 1:j] = []
-                else:
-                    if not _groupname_re.match(groups[i]):
-                        raise TomlDecodeError("Invalid group name '" +
-                                              groups[i] + "'. Try quoting it.",
-                                              original, pos)
-                i += 1
-            currentlevel = retval
-            for i in _range(len(groups)):
-                group = groups[i]
-                if group == "":
-                    raise TomlDecodeError("Can't have a keygroup with an empty "
-                                          "name", original, pos)
-                try:
-                    currentlevel[group]
-                    if i == len(groups) - 1:
-                        if group in implicitgroups:
-                            implicitgroups.remove(group)
-                            if arrayoftables:
-                                raise TomlDecodeError("An implicitly defined "
-                                                      "table can't be an array",
-                                                      original, pos)
-                        elif arrayoftables:
-                            currentlevel[group].append(decoder.get_empty_table()
-                                                       )
-                        else:
-                            raise TomlDecodeError("What? " + group +
-                                                  " already exists?" +
-                                                  str(currentlevel),
-                                                  original, pos)
-                except TypeError:
-                    currentlevel = currentlevel[-1]
-                    if group not in currentlevel:
-                        currentlevel[group] = decoder.get_empty_table()
-                        if i == len(groups) - 1 and arrayoftables:
-                            currentlevel[group] = [decoder.get_empty_table()]
-                except KeyError:
-                    if i != len(groups) - 1:
-                        implicitgroups.append(group)
-                    currentlevel[group] = decoder.get_empty_table()
-                    if i == len(groups) - 1 and arrayoftables:
-                        currentlevel[group] = [decoder.get_empty_table()]
-                currentlevel = currentlevel[group]
-                if arrayoftables:
-                    try:
-                        currentlevel = currentlevel[-1]
-                    except KeyError:
-                        pass
-        elif line[0] == "{":
-            if line[-1] != "}":
-                raise TomlDecodeError("Line breaks are not allowed in inline"
-                                      "objects", original, pos)
-            try:
-                decoder.load_inline_object(line, currentlevel, multikey,
-                                           multibackslash)
-            except ValueError as err:
-                raise TomlDecodeError(str(err), original, pos)
-        elif "=" in line:
-            try:
-                ret = decoder.load_line(line, currentlevel, multikey,
-                                        multibackslash)
-            except ValueError as err:
-                raise TomlDecodeError(str(err), original, pos)
-            if ret is not None:
-                multikey, multilinestr, multibackslash = ret
-    return retval
-
-
-def _load_date(val):
-    microsecond = 0
-    tz = None
-    try:
-        if len(val) > 19:
-            if val[19] == '.':
-                if val[-1].upper() == 'Z':
-                    subsecondval = val[20:-1]
-                    tzval = "Z"
-                else:
-                    subsecondvalandtz = val[20:]
-                    if '+' in subsecondvalandtz:
-                        splitpoint = subsecondvalandtz.index('+')
-                        subsecondval = subsecondvalandtz[:splitpoint]
-                        tzval = subsecondvalandtz[splitpoint:]
-                    elif '-' in subsecondvalandtz:
-                        splitpoint = subsecondvalandtz.index('-')
-                        subsecondval = subsecondvalandtz[:splitpoint]
-                        tzval = subsecondvalandtz[splitpoint:]
-                    else:
-                        tzval = None
-                        subsecondval = subsecondvalandtz
-                if tzval is not None:
-                    tz = TomlTz(tzval)
-                microsecond = int(int(subsecondval) *
-                                  (10 ** (6 - len(subsecondval))))
-            else:
-                tz = TomlTz(val[19:])
-    except ValueError:
-        tz = None
-    if "-" not in val[1:]:
-        return None
-    try:
-        if len(val) == 10:
-            d = datetime.date(
-                int(val[:4]), int(val[5:7]),
-                int(val[8:10]))
-        else:
-            d = datetime.datetime(
-                int(val[:4]), int(val[5:7]),
-                int(val[8:10]), int(val[11:13]),
-                int(val[14:16]), int(val[17:19]), microsecond, tz)
-    except ValueError:
-        return None
-    return d
-
-
-def _load_unicode_escapes(v, hexbytes, prefix):
-    skip = False
-    i = len(v) - 1
-    while i > -1 and v[i] == '\\':
-        skip = not skip
-        i -= 1
-    for hx in hexbytes:
-        if skip:
-            skip = False
-            i = len(hx) - 1
-            while i > -1 and hx[i] == '\\':
-                skip = not skip
-                i -= 1
-            v += prefix
-            v += hx
-            continue
-        hxb = ""
-        i = 0
-        hxblen = 4
-        if prefix == "\\U":
-            hxblen = 8
-        hxb = ''.join(hx[i:i + hxblen]).lower()
-        if hxb.strip('0123456789abcdef'):
-            raise ValueError("Invalid escape sequence: " + hxb)
-        if hxb[0] == "d" and hxb[1].strip('01234567'):
-            raise ValueError("Invalid escape sequence: " + hxb +
-                             ". Only scalar unicode points are allowed.")
-        v += unichr(int(hxb, 16))
-        v += unicode(hx[len(hxb):])
-    return v
-
-
-# Unescape TOML string values.
-
-# content after the \
-_escapes = ['0', 'b', 'f', 'n', 'r', 't', '"']
-# What it should be replaced by
-_escapedchars = ['\0', '\b', '\f', '\n', '\r', '\t', '\"']
-# Used for substitution
-_escape_to_escapedchars = dict(zip(_escapes, _escapedchars))
-
-
-def _unescape(v):
-    """Unescape characters in a TOML string."""
-    i = 0
-    backslash = False
-    while i < len(v):
-        if backslash:
-            backslash = False
-            if v[i] in _escapes:
-                v = v[:i - 1] + _escape_to_escapedchars[v[i]] + v[i + 1:]
-            elif v[i] == '\\':
-                v = v[:i - 1] + v[i:]
-            elif v[i] == 'u' or v[i] == 'U':
-                i += 1
-            else:
-                raise ValueError("Reserved escape sequence used")
-            continue
-        elif v[i] == '\\':
-            backslash = True
-        i += 1
-    return v
-
-
-class InlineTableDict(object):
-    """Sentinel subclass of dict for inline tables."""
-
-
-class TomlDecoder(object):
-
-    def __init__(self, _dict=dict):
-        self._dict = _dict
-
-    def get_empty_table(self):
-        return self._dict()
-
-    def get_empty_inline_table(self):
-        class DynamicInlineTableDict(self._dict, InlineTableDict):
-            """Concrete sentinel subclass for inline tables.
-            It is a subclass of _dict which is passed in dynamically at load
-            time
-
-            It is also a subclass of InlineTableDict
-            """
-
-        return DynamicInlineTableDict()
-
-    def load_inline_object(self, line, currentlevel, multikey=False,
-                           multibackslash=False):
-        candidate_groups = line[1:-1].split(",")
-        groups = []
-        if len(candidate_groups) == 1 and not candidate_groups[0].strip():
-            candidate_groups.pop()
-        while len(candidate_groups) > 0:
-            candidate_group = candidate_groups.pop(0)
-            try:
-                _, value = candidate_group.split('=', 1)
-            except ValueError:
-                raise ValueError("Invalid inline table encountered")
-            value = value.strip()
-            if ((value[0] == value[-1] and value[0] in ('"', "'")) or (
-                    value[0] in '-0123456789' or
-                    value in ('true', 'false') or
-                    (value[0] == "[" and value[-1] == "]") or
-                    (value[0] == '{' and value[-1] == '}'))):
-                groups.append(candidate_group)
-            elif len(candidate_groups) > 0:
-                candidate_groups[0] = (candidate_group + "," +
-                                       candidate_groups[0])
-            else:
-                raise ValueError("Invalid inline table value encountered")
-        for group in groups:
-            status = self.load_line(group, currentlevel, multikey,
-                                    multibackslash)
-            if status is not None:
-                break
-
-    def _get_split_on_quotes(self, line):
-        doublequotesplits = line.split('"')
-        quoted = False
-        quotesplits = []
-        if len(doublequotesplits) > 1 and "'" in doublequotesplits[0]:
-            singlequotesplits = doublequotesplits[0].split("'")
-            doublequotesplits = doublequotesplits[1:]
-            while len(singlequotesplits) % 2 == 0 and len(doublequotesplits):
-                singlequotesplits[-1] += '"' + doublequotesplits[0]
-                doublequotesplits = doublequotesplits[1:]
-                if "'" in singlequotesplits[-1]:
-                    singlequotesplits = (singlequotesplits[:-1] +
-                                         singlequotesplits[-1].split("'"))
-            quotesplits += singlequotesplits
-        for doublequotesplit in doublequotesplits:
-            if quoted:
-                quotesplits.append(doublequotesplit)
-            else:
-                quotesplits += doublequotesplit.split("'")
-                quoted = not quoted
-        return quotesplits
-
-    def load_line(self, line, currentlevel, multikey, multibackslash):
-        i = 1
-        quotesplits = self._get_split_on_quotes(line)
-        quoted = False
-        for quotesplit in quotesplits:
-            if not quoted and '=' in quotesplit:
-                break
-            i += quotesplit.count('=')
-            quoted = not quoted
-        pair = line.split('=', i)
-        strictly_valid = _strictly_valid_num(pair[-1])
-        if _number_with_underscores.match(pair[-1]):
-            pair[-1] = pair[-1].replace('_', '')
-        while len(pair[-1]) and (pair[-1][0] != ' ' and pair[-1][0] != '\t' and
-                                 pair[-1][0] != "'" and pair[-1][0] != '"' and
-                                 pair[-1][0] != '[' and pair[-1][0] != '{' and
-                                 pair[-1].strip() != 'true' and
-                                 pair[-1].strip() != 'false'):
-            try:
-                float(pair[-1])
-                break
-            except ValueError:
-                pass
-            if _load_date(pair[-1]) is not None:
-                break
-            if TIME_RE.match(pair[-1]):
-                break
-            i += 1
-            prev_val = pair[-1]
-            pair = line.split('=', i)
-            if prev_val == pair[-1]:
-                raise ValueError("Invalid date or number")
-            if strictly_valid:
-                strictly_valid = _strictly_valid_num(pair[-1])
-        pair = ['='.join(pair[:-1]).strip(), pair[-1].strip()]
-        if '.' in pair[0]:
-            if '"' in pair[0] or "'" in pair[0]:
-                quotesplits = self._get_split_on_quotes(pair[0])
-                quoted = False
-                levels = []
-                for quotesplit in quotesplits:
-                    if quoted:
-                        levels.append(quotesplit)
-                    else:
-                        levels += [level.strip() for level in
-                                   quotesplit.split('.')]
-                    quoted = not quoted
-            else:
-                levels = pair[0].split('.')
-            while levels[-1] == "":
-                levels = levels[:-1]
-            for level in levels[:-1]:
-                if level == "":
-                    continue
-                if level not in currentlevel:
-                    currentlevel[level] = self.get_empty_table()
-                currentlevel = currentlevel[level]
-            pair[0] = levels[-1].strip()
-        elif (pair[0][0] == '"' or pair[0][0] == "'") and \
-                (pair[0][-1] == pair[0][0]):
-            pair[0] = _unescape(pair[0][1:-1])
-        k, koffset = self._load_line_multiline_str(pair[1])
-        if k > -1:
-            while k > -1 and pair[1][k + koffset] == '\\':
-                multibackslash = not multibackslash
-                k -= 1
-            if multibackslash:
-                multilinestr = pair[1][:-1]
-            else:
-                multilinestr = pair[1] + "\n"
-            multikey = pair[0]
-        else:
-            value, vtype = self.load_value(pair[1], strictly_valid)
-        try:
-            currentlevel[pair[0]]
-            raise ValueError("Duplicate keys!")
-        except TypeError:
-            raise ValueError("Duplicate keys!")
-        except KeyError:
-            if multikey:
-                return multikey, multilinestr, multibackslash
-            else:
-                currentlevel[pair[0]] = value
-
-    def _load_line_multiline_str(self, p):
-        poffset = 0
-        if len(p) < 3:
-            return -1, poffset
-        if p[0] == '[' and (p.strip()[-1] != ']' and
-                            self._load_array_isstrarray(p)):
-            newp = p[1:].strip().split(',')
-            while len(newp) > 1 and newp[-1][0] != '"' and newp[-1][0] != "'":
-                newp = newp[:-2] + [newp[-2] + ',' + newp[-1]]
-            newp = newp[-1]
-            poffset = len(p) - len(newp)
-            p = newp
-        if p[0] != '"' and p[0] != "'":
-            return -1, poffset
-        if p[1] != p[0] or p[2] != p[0]:
-            return -1, poffset
-        if len(p) > 5 and p[-1] == p[0] and p[-2] == p[0] and p[-3] == p[0]:
-            return -1, poffset
-        return len(p) - 1, poffset
-
-    def load_value(self, v, strictly_valid=True):
-        if not v:
-            raise ValueError("Empty value is invalid")
-        if v == 'true':
-            return (True, "bool")
-        elif v.lower() == 'true':
-            raise ValueError("Only all lowercase booleans allowed")
-        elif v == 'false':
-            return (False, "bool")
-        elif v.lower() == 'false':
-            raise ValueError("Only all lowercase booleans allowed")
-        elif v[0] == '"' or v[0] == "'":
-            quotechar = v[0]
-            testv = v[1:].split(quotechar)
-            triplequote = False
-            triplequotecount = 0
-            if len(testv) > 1 and testv[0] == '' and testv[1] == '':
-                testv = testv[2:]
-                triplequote = True
-            closed = False
-            for tv in testv:
-                if tv == '':
-                    if triplequote:
-                        triplequotecount += 1
-                    else:
-                        closed = True
-                else:
-                    oddbackslash = False
-                    try:
-                        i = -1
-                        j = tv[i]
-                        while j == '\\':
-                            oddbackslash = not oddbackslash
-                            i -= 1
-                            j = tv[i]
-                    except IndexError:
-                        pass
-                    if not oddbackslash:
-                        if closed:
-                            raise ValueError("Found tokens after a closed " +
-                                             "string. Invalid TOML.")
-                        else:
-                            if not triplequote or triplequotecount > 1:
-                                closed = True
-                            else:
-                                triplequotecount = 0
-            if quotechar == '"':
-                escapeseqs = v.split('\\')[1:]
-                backslash = False
-                for i in escapeseqs:
-                    if i == '':
-                        backslash = not backslash
-                    else:
-                        if i[0] not in _escapes and (i[0] != 'u' and
-                                                     i[0] != 'U' and
-                                                     not backslash):
-                            raise ValueError("Reserved escape sequence used")
-                        if backslash:
-                            backslash = False
-                for prefix in ["\\u", "\\U"]:
-                    if prefix in v:
-                        hexbytes = v.split(prefix)
-                        v = _load_unicode_escapes(hexbytes[0], hexbytes[1:],
-                                                  prefix)
-                v = _unescape(v)
-            if len(v) > 1 and v[1] == quotechar and (len(v) < 3 or
-                                                     v[1] == v[2]):
-                v = v[2:-2]
-            return (v[1:-1], "str")
-        elif v[0] == '[':
-            return (self.load_array(v), "array")
-        elif v[0] == '{':
-            inline_object = self.get_empty_inline_table()
-            self.load_inline_object(v, inline_object)
-            return (inline_object, "inline_object")
-        elif TIME_RE.match(v):
-            h, m, s, _, ms = TIME_RE.match(v).groups()
-            time = datetime.time(int(h), int(m), int(s), int(ms) if ms else 0)
-            return (time, "time")
-        else:
-            parsed_date = _load_date(v)
-            if parsed_date is not None:
-                return (parsed_date, "date")
-            if not strictly_valid:
-                raise ValueError("Weirdness with leading zeroes or "
-                                 "underscores in your number.")
-            itype = "int"
-            neg = False
-            if v[0] == '-':
-                neg = True
-                v = v[1:]
-            elif v[0] == '+':
-                v = v[1:]
-            v = v.replace('_', '')
-            lowerv = v.lower()
-            if '.' in v or ('x' not in v and ('e' in v or 'E' in v)):
-                if '.' in v and v.split('.', 1)[1] == '':
-                    raise ValueError("This float is missing digits after "
-                                     "the point")
-                if v[0] not in '0123456789':
-                    raise ValueError("This float doesn't have a leading "
-                                     "digit")
-                v = float(v)
-                itype = "float"
-            elif len(lowerv) == 3 and (lowerv == 'inf' or lowerv == 'nan'):
-                v = float(v)
-                itype = "float"
-            if itype == "int":
-                v = int(v, 0)
-            if neg:
-                return (0 - v, itype)
-            return (v, itype)
-
-    def bounded_string(self, s):
-        if len(s) == 0:
-            return True
-        if s[-1] != s[0]:
-            return False
-        i = -2
-        backslash = False
-        while len(s) + i > 0:
-            if s[i] == "\\":
-                backslash = not backslash
-                i -= 1
-            else:
-                break
-        return not backslash
-
-    def _load_array_isstrarray(self, a):
-        a = a[1:-1].strip()
-        if a != '' and (a[0] == '"' or a[0] == "'"):
-            return True
-        return False
-
-    def load_array(self, a):
-        atype = None
-        retval = []
-        a = a.strip()
-        if '[' not in a[1:-1] or "" != a[1:-1].split('[')[0].strip():
-            strarray = self._load_array_isstrarray(a)
-            if not a[1:-1].strip().startswith('{'):
-                a = a[1:-1].split(',')
-            else:
-                # a is an inline object, we must find the matching parenthesis
-                # to define groups
-                new_a = []
-                start_group_index = 1
-                end_group_index = 2
-                open_bracket_count = 1 if a[start_group_index] == '{' else 0
-                in_str = False
-                while end_group_index < len(a[1:]):
-                    if a[end_group_index] == '"' or a[end_group_index] == "'":
-                        if in_str:
-                            backslash_index = end_group_index - 1
-                            while (backslash_index > -1 and
-                                   a[backslash_index] == '\\'):
-                                in_str = not in_str
-                                backslash_index -= 1
-                        in_str = not in_str
-                    if not in_str and a[end_group_index] == '{':
-                        open_bracket_count += 1
-                    if in_str or a[end_group_index] != '}':
-                        end_group_index += 1
-                        continue
-                    elif a[end_group_index] == '}' and open_bracket_count > 1:
-                        open_bracket_count -= 1
-                        end_group_index += 1
-                        continue
-
-                    # Increase end_group_index by 1 to get the closing bracket
-                    end_group_index += 1
-
-                    new_a.append(a[start_group_index:end_group_index])
-
-                    # The next start index is at least after the closing
-                    # bracket, a closing bracket can be followed by a comma
-                    # since we are in an array.
-                    start_group_index = end_group_index + 1
-                    while (start_group_index < len(a[1:]) and
-                           a[start_group_index] != '{'):
-                        start_group_index += 1
-                    end_group_index = start_group_index + 1
-                a = new_a
-            b = 0
-            if strarray:
-                while b < len(a) - 1:
-                    ab = a[b].strip()
-                    while (not self.bounded_string(ab) or
-                           (len(ab) > 2 and
-                            ab[0] == ab[1] == ab[2] and
-                            ab[-2] != ab[0] and
-                            ab[-3] != ab[0])):
-                        a[b] = a[b] + ',' + a[b + 1]
-                        ab = a[b].strip()
-                        if b < len(a) - 2:
-                            a = a[:b + 1] + a[b + 2:]
-                        else:
-                            a = a[:b + 1]
-                    b += 1
-        else:
-            al = list(a[1:-1])
-            a = []
-            openarr = 0
-            j = 0
-            for i in _range(len(al)):
-                if al[i] == '[':
-                    openarr += 1
-                elif al[i] == ']':
-                    openarr -= 1
-                elif al[i] == ',' and not openarr:
-                    a.append(''.join(al[j:i]))
-                    j = i + 1
-            a.append(''.join(al[j:]))
-        for i in _range(len(a)):
-            a[i] = a[i].strip()
-            if a[i] != '':
-                nval, ntype = self.load_value(a[i])
-                if atype:
-                    if ntype != atype:
-                        raise ValueError("Not a homogeneous array")
-                else:
-                    atype = ntype
-                retval.append(nval)
-        return retval
-
-    def preserve_comment(self, line_no, key, comment, beginline):
-        pass
-
-    def embed_comments(self, idx, currentlevel):
-        pass
-
-
-class TomlPreserveCommentDecoder(TomlDecoder):
-
-    def __init__(self, _dict=dict):
-        self.saved_comments = {}
-        super(TomlPreserveCommentDecoder, self).__init__(_dict)
-
-    def preserve_comment(self, line_no, key, comment, beginline):
-        self.saved_comments[line_no] = (key, comment, beginline)
-
-    def embed_comments(self, idx, currentlevel):
-        if idx not in self.saved_comments:
-            return
-
-        key, comment, beginline = self.saved_comments[idx]
-        currentlevel[key] = CommentValue(currentlevel[key], comment, beginline,
-                                         self._dict)
diff --git a/env/Lib/site-packages/pip/_vendor/toml/encoder.py b/env/Lib/site-packages/pip/_vendor/toml/encoder.py
deleted file mode 100644
index 7fb94da9..00000000
--- a/env/Lib/site-packages/pip/_vendor/toml/encoder.py
+++ /dev/null
@@ -1,304 +0,0 @@
-import datetime
-import re
-import sys
-from decimal import Decimal
-
-from pip._vendor.toml.decoder import InlineTableDict
-
-if sys.version_info >= (3,):
-    unicode = str
-
-
-def dump(o, f, encoder=None):
-    """Writes out dict as toml to a file
-
-    Args:
-        o: Object to dump into toml
-        f: File descriptor where the toml should be stored
-        encoder: The ``TomlEncoder`` to use for constructing the output string
-
-    Returns:
-        String containing the toml corresponding to dictionary
-
-    Raises:
-        TypeError: When anything other than file descriptor is passed
-    """
-
-    if not f.write:
-        raise TypeError("You can only dump an object to a file descriptor")
-    d = dumps(o, encoder=encoder)
-    f.write(d)
-    return d
-
-
-def dumps(o, encoder=None):
-    """Stringifies input dict as toml
-
-    Args:
-        o: Object to dump into toml
-        encoder: The ``TomlEncoder`` to use for constructing the output string
-
-    Returns:
-        String containing the toml corresponding to dict
-
-    Examples:
-        ```python
-        >>> import toml
-        >>> output = {
-        ... 'a': "I'm a string",
-        ... 'b': ["I'm", "a", "list"],
-        ... 'c': 2400
-        ... }
-        >>> toml.dumps(output)
-        'a = "I\'m a string"\nb = [ "I\'m", "a", "list",]\nc = 2400\n'
-        ```
-    """
-
-    retval = ""
-    if encoder is None:
-        encoder = TomlEncoder(o.__class__)
-    addtoretval, sections = encoder.dump_sections(o, "")
-    retval += addtoretval
-    outer_objs = [id(o)]
-    while sections:
-        section_ids = [id(section) for section in sections.values()]
-        for outer_obj in outer_objs:
-            if outer_obj in section_ids:
-                raise ValueError("Circular reference detected")
-        outer_objs += section_ids
-        newsections = encoder.get_empty_table()
-        for section in sections:
-            addtoretval, addtosections = encoder.dump_sections(
-                sections[section], section)
-
-            if addtoretval or (not addtoretval and not addtosections):
-                if retval and retval[-2:] != "\n\n":
-                    retval += "\n"
-                retval += "[" + section + "]\n"
-                if addtoretval:
-                    retval += addtoretval
-            for s in addtosections:
-                newsections[section + "." + s] = addtosections[s]
-        sections = newsections
-    return retval
-
-
-def _dump_str(v):
-    if sys.version_info < (3,) and hasattr(v, 'decode') and isinstance(v, str):
-        v = v.decode('utf-8')
-    v = "%r" % v
-    if v[0] == 'u':
-        v = v[1:]
-    singlequote = v.startswith("'")
-    if singlequote or v.startswith('"'):
-        v = v[1:-1]
-    if singlequote:
-        v = v.replace("\\'", "'")
-        v = v.replace('"', '\\"')
-    v = v.split("\\x")
-    while len(v) > 1:
-        i = -1
-        if not v[0]:
-            v = v[1:]
-        v[0] = v[0].replace("\\\\", "\\")
-        # No, I don't know why != works and == breaks
-        joinx = v[0][i] != "\\"
-        while v[0][:i] and v[0][i] == "\\":
-            joinx = not joinx
-            i -= 1
-        if joinx:
-            joiner = "x"
-        else:
-            joiner = "u00"
-        v = [v[0] + joiner + v[1]] + v[2:]
-    return unicode('"' + v[0] + '"')
-
-
-def _dump_float(v):
-    return "{}".format(v).replace("e+0", "e+").replace("e-0", "e-")
-
-
-def _dump_time(v):
-    utcoffset = v.utcoffset()
-    if utcoffset is None:
-        return v.isoformat()
-    # The TOML norm specifies that it's local time thus we drop the offset
-    return v.isoformat()[:-6]
-
-
-class TomlEncoder(object):
-
-    def __init__(self, _dict=dict, preserve=False):
-        self._dict = _dict
-        self.preserve = preserve
-        self.dump_funcs = {
-            str: _dump_str,
-            unicode: _dump_str,
-            list: self.dump_list,
-            bool: lambda v: unicode(v).lower(),
-            int: lambda v: v,
-            float: _dump_float,
-            Decimal: _dump_float,
-            datetime.datetime: lambda v: v.isoformat().replace('+00:00', 'Z'),
-            datetime.time: _dump_time,
-            datetime.date: lambda v: v.isoformat()
-        }
-
-    def get_empty_table(self):
-        return self._dict()
-
-    def dump_list(self, v):
-        retval = "["
-        for u in v:
-            retval += " " + unicode(self.dump_value(u)) + ","
-        retval += "]"
-        return retval
-
-    def dump_inline_table(self, section):
-        """Preserve inline table in its compact syntax instead of expanding
-        into subsection.
-
-        https://github.com/toml-lang/toml#user-content-inline-table
-        """
-        retval = ""
-        if isinstance(section, dict):
-            val_list = []
-            for k, v in section.items():
-                val = self.dump_inline_table(v)
-                val_list.append(k + " = " + val)
-            retval += "{ " + ", ".join(val_list) + " }\n"
-            return retval
-        else:
-            return unicode(self.dump_value(section))
-
-    def dump_value(self, v):
-        # Lookup function corresponding to v's type
-        dump_fn = self.dump_funcs.get(type(v))
-        if dump_fn is None and hasattr(v, '__iter__'):
-            dump_fn = self.dump_funcs[list]
-        # Evaluate function (if it exists) else return v
-        return dump_fn(v) if dump_fn is not None else self.dump_funcs[str](v)
-
-    def dump_sections(self, o, sup):
-        retstr = ""
-        if sup != "" and sup[-1] != ".":
-            sup += '.'
-        retdict = self._dict()
-        arraystr = ""
-        for section in o:
-            section = unicode(section)
-            qsection = section
-            if not re.match(r'^[A-Za-z0-9_-]+$', section):
-                qsection = _dump_str(section)
-            if not isinstance(o[section], dict):
-                arrayoftables = False
-                if isinstance(o[section], list):
-                    for a in o[section]:
-                        if isinstance(a, dict):
-                            arrayoftables = True
-                if arrayoftables:
-                    for a in o[section]:
-                        arraytabstr = "\n"
-                        arraystr += "[[" + sup + qsection + "]]\n"
-                        s, d = self.dump_sections(a, sup + qsection)
-                        if s:
-                            if s[0] == "[":
-                                arraytabstr += s
-                            else:
-                                arraystr += s
-                        while d:
-                            newd = self._dict()
-                            for dsec in d:
-                                s1, d1 = self.dump_sections(d[dsec], sup +
-                                                            qsection + "." +
-                                                            dsec)
-                                if s1:
-                                    arraytabstr += ("[" + sup + qsection +
-                                                    "." + dsec + "]\n")
-                                    arraytabstr += s1
-                                for s1 in d1:
-                                    newd[dsec + "." + s1] = d1[s1]
-                            d = newd
-                        arraystr += arraytabstr
-                else:
-                    if o[section] is not None:
-                        retstr += (qsection + " = " +
-                                   unicode(self.dump_value(o[section])) + '\n')
-            elif self.preserve and isinstance(o[section], InlineTableDict):
-                retstr += (qsection + " = " +
-                           self.dump_inline_table(o[section]))
-            else:
-                retdict[qsection] = o[section]
-        retstr += arraystr
-        return (retstr, retdict)
-
-
-class TomlPreserveInlineDictEncoder(TomlEncoder):
-
-    def __init__(self, _dict=dict):
-        super(TomlPreserveInlineDictEncoder, self).__init__(_dict, True)
-
-
-class TomlArraySeparatorEncoder(TomlEncoder):
-
-    def __init__(self, _dict=dict, preserve=False, separator=","):
-        super(TomlArraySeparatorEncoder, self).__init__(_dict, preserve)
-        if separator.strip() == "":
-            separator = "," + separator
-        elif separator.strip(' \t\n\r,'):
-            raise ValueError("Invalid separator for arrays")
-        self.separator = separator
-
-    def dump_list(self, v):
-        t = []
-        retval = "["
-        for u in v:
-            t.append(self.dump_value(u))
-        while t != []:
-            s = []
-            for u in t:
-                if isinstance(u, list):
-                    for r in u:
-                        s.append(r)
-                else:
-                    retval += " " + unicode(u) + self.separator
-            t = s
-        retval += "]"
-        return retval
-
-
-class TomlNumpyEncoder(TomlEncoder):
-
-    def __init__(self, _dict=dict, preserve=False):
-        import numpy as np
-        super(TomlNumpyEncoder, self).__init__(_dict, preserve)
-        self.dump_funcs[np.float16] = _dump_float
-        self.dump_funcs[np.float32] = _dump_float
-        self.dump_funcs[np.float64] = _dump_float
-        self.dump_funcs[np.int16] = self._dump_int
-        self.dump_funcs[np.int32] = self._dump_int
-        self.dump_funcs[np.int64] = self._dump_int
-
-    def _dump_int(self, v):
-        return "{}".format(int(v))
-
-
-class TomlPreserveCommentEncoder(TomlEncoder):
-
-    def __init__(self, _dict=dict, preserve=False):
-        from pip._vendor.toml.decoder import CommentValue
-        super(TomlPreserveCommentEncoder, self).__init__(_dict, preserve)
-        self.dump_funcs[CommentValue] = lambda v: v.dump(self.dump_value)
-
-
-class TomlPathlibEncoder(TomlEncoder):
-
-    def _dump_pathlib_path(self, v):
-        return _dump_str(str(v))
-
-    def dump_value(self, v):
-        if (3, 4) <= sys.version_info:
-            import pathlib
-            if isinstance(v, pathlib.PurePath):
-                v = str(v)
-        return super(TomlPathlibEncoder, self).dump_value(v)
diff --git a/env/Lib/site-packages/pip/_vendor/toml/ordered.py b/env/Lib/site-packages/pip/_vendor/toml/ordered.py
deleted file mode 100644
index 6052016e..00000000
--- a/env/Lib/site-packages/pip/_vendor/toml/ordered.py
+++ /dev/null
@@ -1,15 +0,0 @@
-from collections import OrderedDict
-from pip._vendor.toml import TomlEncoder
-from pip._vendor.toml import TomlDecoder
-
-
-class TomlOrderedDecoder(TomlDecoder):
-
-    def __init__(self):
-        super(self.__class__, self).__init__(_dict=OrderedDict)
-
-
-class TomlOrderedEncoder(TomlEncoder):
-
-    def __init__(self):
-        super(self.__class__, self).__init__(_dict=OrderedDict)
diff --git a/env/Lib/site-packages/pip/_vendor/toml/tz.py b/env/Lib/site-packages/pip/_vendor/toml/tz.py
deleted file mode 100644
index bf20593a..00000000
--- a/env/Lib/site-packages/pip/_vendor/toml/tz.py
+++ /dev/null
@@ -1,24 +0,0 @@
-from datetime import tzinfo, timedelta
-
-
-class TomlTz(tzinfo):
-    def __init__(self, toml_offset):
-        if toml_offset == "Z":
-            self._raw_offset = "+00:00"
-        else:
-            self._raw_offset = toml_offset
-        self._sign = -1 if self._raw_offset[0] == '-' else 1
-        self._hours = int(self._raw_offset[1:3])
-        self._minutes = int(self._raw_offset[4:6])
-
-    def __deepcopy__(self, memo):
-        return self.__class__(self._raw_offset)
-
-    def tzname(self, dt):
-        return "UTC" + self._raw_offset
-
-    def utcoffset(self, dt):
-        return self._sign * timedelta(hours=self._hours, minutes=self._minutes)
-
-    def dst(self, dt):
-        return timedelta(0)
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py b/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py
index fe86b59d..c6fa3821 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/__init__.py
@@ -19,6 +19,23 @@ from .util.retry import Retry
 from .util.timeout import Timeout
 from .util.url import get_host
 
+# === NOTE TO REPACKAGERS AND VENDORS ===
+# Please delete this block, this logic is only
+# for urllib3 being distributed via PyPI.
+# See: https://github.com/urllib3/urllib3/issues/2680
+try:
+    import urllib3_secure_extra  # type: ignore # noqa: F401
+except ImportError:
+    pass
+else:
+    warnings.warn(
+        "'urllib3[secure]' extra is deprecated and will be removed "
+        "in a future release of urllib3 2.x. Read more in this issue: "
+        "https://github.com/urllib3/urllib3/issues/2680",
+        category=DeprecationWarning,
+        stacklevel=2,
+    )
+
 __author__ = "Andrey Petrov (andrey.petrov@shazow.net)"
 __license__ = "MIT"
 __version__ = __version__
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index b0590e20ffb854e1fd19aaaddc309c7fee8edf69..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_collections.cpython-39.pyc
deleted file mode 100644
index 0d9be279d8b2c7d61f720aa03326b027a08b7f60..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 10812
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
LCJtscW&s}n=-SuF

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/_version.cpython-39.pyc
deleted file mode 100644
index c0bd79342a7aeb9d625633d06149e15b205ed032..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 241
zcmYe~<>g{vU|^UdaWK`Mfq~&Mh=Yt785kHG7#J9eIT#oiQW&BbQW%37G?}W{4E2o6
z^i2FT8E<jN$CsrR6=&w>#mBE?C}Lt@fDpeLoULL)i&Kk=V^VWcGK*sT^HN=kGRsmG
zbQMDVJi}arf;~eVgB3jeT>Sl9gFPK%f?a)GgF{?{6wG1*0(@c;O>}ee(=&@pGP7e+
z^U7j;GLvG8GfPr+3lfvF6Vp?RV+t}0^yAA?^HTDQ^h=9!ax#;QL42@d^a?6(aoFVM
Pr<CTT+JPMP8RRbjWu`)J

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connection.cpython-39.pyc
deleted file mode 100644
index fad7489d93a83a43191f25236d7f559d3a244f45..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 13397
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
QLpBFL2a5n38zT!d0F2=B!T<mO

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/connectionpool.cpython-39.pyc
deleted file mode 100644
index c25e2fb87d2531988733a761435734aac771227d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/exceptions.cpython-39.pyc
deleted file mode 100644
index b9f098e35685713970d82289a63bb3930bf72b52..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 11674
zcmYe~<>g{vU|^UdaWGX<fq~&Mh=Yt-85kHG7#J9e>zEiAQW#Pga~N_NqZk<(QkYVh
zbC`0OqgWUj+!<0>QdnCUQdm=2o0+57+!<2XQrKG<QrJ`3o0+3H+!<0hQaD=}QaDrD
znwg_G-5FB2Qn*_fQn*t&o0+4y+!<1MQg~Y!Qh34g-0lo1d@1}b3@Q9zK94&?ia?5B
z3qy(^n9u9ZkRp^K+`^C|4CeEt@<s8xGo*;5h_*1Kh^BHiGe-%yGo*;6h_^7Lh=cip
z?hGjsDUvM=DUx74LhcMHQYq3c3@OrJzOXw(icE@Z3qy)*s&Fb-GfR|+J41?GihK)0
zihQbYGjo)vJ41>>ied{xiejp0DrYlGl$bk1ic*Sl3qy)B*dOBV3@Iupsx1sDs$jl^
zJ41?Eih2t}ih3%@R+cC!cZL*=6wMZf6wOqrX67hqcZL+L6zvv<6m2kH#+@NWCq=h~
zAw?JLDp_}i6ulJv7KRl4RE}omC^>hA6oVAQ7KRkVRJms6D0z2=6r&X57KRjKFkiu)
zA;l!cw1pwX6wFt2XGk$iF>hf=F$eRN+!<0VQY>2-QY^vdDZ4YISfyCEFr-+6`6})V
zDK;s#Eet8PseGxD%`8!>?hGk*DfTT4DfVC&skt+xIHWkXFr+x9vZb;#vqUkwGo(1B
zIJYpQI73C$-5F9`Qe0aYQe44$G~5|d+)~_I7*gC*HB)7pS)#Pu8B#n_JX;u2JX0l`
znWMDb8B)AbyjvJjyumtj+!<1QQhZw&QhdRD-4wrI22KB$pp>b}c#A(VsW?BUv?Mh?
zGq)hWsN^Lh0|SF5<1IeVyyX1cf}GTn)S%SFlw^={WDHUUPRs%f3=F9ZQH&`JQA{a}
zQOqe!!3>(rw>UjQLIPZiit>x9l${cbQx#Gxl2Z#xGV}8kN{drd6p|_xN-{Ew6>{@a
zN^?^6{8qBu;)svWOUzA;kH5tg9}f|akH5teA75CSm;;qzkB?8uPmYgY$xy`2zyKkB
zH91?wgche3700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~xdwYW#ss_i
zx(0{11}T`u1O)iRB%0{v<fmsAmt<zgq~?{y_+%!<6la#C>J}s>XD6no7RMB17U;*9
zrRJsN7wMN4<>X{08SBG6RIFD}Sp>@59H7k2!oa}5!N|e{79ly<xIw`do>-KZnU`Lr
z2oAV%2oHO(6|uoW0TCWWJRmV%1_lN`6bFGsFdW1LE0h#4;xUD}g&~RsQXECGrmzJw
zXtLkp49L&VfyApm*m>|^P)N%!Qb+~Gc(FoqA~=%EGfOfu^Ar*l3i9)F^pcs85)g<D
za=SCgiE<1K3^j~34Dk#lj0>1*7*ZH(7;Bi)n8X+sGBGlwFa$GbGWk`psTNx)s1|E7
z-(mro2M%CRqRGt5EQyZ?2^Xj4q!sZqFfiO=&rK~ZPE1cl4;4^q6$e=fiY5j|HpVI;
zxQF!O;~_>RgAzB)tspiikiZTF74S6-Sqv$RX`p1z<fqBx=eLsa7H52Xa!z7#aeVwr
z#v(yb@WWFlI5t2jx+pcJG&wasUK(UQ$V3LFDiLJMVG8_KvK6s|%mAgQB2EwsWN#73
z?L}fBF2Zmy3mo5|xE28!4GL9I0_0#R0*O%^<2*sBg{7&*C6GwBz!K?jPZTSZWF(d-
zWF(fQDkK&c=O<?-mZYXAga-K(>m`Fj92%-1HYmq{162YP`%H+~uVJiVUdRlI_mzx(
zn#{MDON(;Ao&kq}CJQ8pK@nXf1qu%#5CIMfFaZt^P-rQG!UJR%IHpCBJ%T&3LF&Qo
z0+|YqY=#<!EXEXuG-gnw7fFH&NTwoCSVL?V#bP@sn$$tILnB%o&2D&H7lBeEQYuAw
z02C~sOj(Q+p&&7g2nD53d_^%waIg;~@+^ZAGeL!Kc}8lULU6E;LUL+RNoHDRa$-rU
zLRw;GPO$<gyXGl?N}*td<ovw6)MQYZt>=fkpaG?49gtT+0S8KWMIaFjSAsG;DE5m%
zenPG=+8NRqK`o#bjwqIP1{Q`W)?fxrmRno_Mfnw#5O?b!ySpSK70G1^CHbK81*8_@
z1Jq&$<R*~Kp!`&<!oa{#!cf9k!_dr>#RMv1(wS<Q7cmAg^f53p)PRy8GpMkEL@~=P
z*5cBF)S@C8Q2c_D(=ERIqRjNnyu_S%a5)D{h@gaWixn(%izTrry|_piqy-U`AkC(*
zAYx#YVyqHI_zs>D@nrj3ywCzBIW;FIJ{~E(fNcUNc#t!VV3vU60VIME4}?++w@Yer
zeo87N;H{AZKC!eUKR2-?Gg%=8q$D#hT_GtEl$`SO6rA((N>cMmbVDi&peYGok^$vQ
zD-@@KL`ZfjZ$MFgNq#b{KC(l0Y;k^WDyZ^FS18R(ttd!M1{FjZi3J6zdBqC3nJKzO
zkWx**D7CmCKd(3ypL;<G2b{w|$q5{^AQ24rf)W~78K_V~PU0!7Da<J>EsRkt;MNh_
zEneTmilEezB1rm9<Y8oBKz2MRiRUI(WagIUD&&>sCZ!fB<fkbVrIr+BrWPw?7K0m8
zsVS)`dR$xz3JMBV1&Kw8x!_vXN+AR_e}Jk=h@uiu+<>@N3Rd9S$||7_+L+NpWOa}N
zJy8C4hUb1z`JMnV17cBeNf9XaON(+K)<MG(RMZ#cAS;A74vO_$;qAYo)WqWaJc!QH
zyp+_UoJx>s;QRyej~_~90jelKWgxgvRs&TQ%%I95g|UXIh8fgIsAYjP8$da_hGiiO
zr0M`Q84P?AE8yV<attWY6hO@q1+e2)ixo7SA#IhUN(I#-O-<%oY!LSqfy!D)eZz`g
z-+&xZ1j_YD84;WZK^Z+9l(0eWWng4u;$f;1Ly2p6Zr5b=Tgi&Mo(C5m2m)-nDgy(9
zFUWLgGUO}*iI9*C+2F|#RK~L367a|`E^*FC%u7#Afn<1l<Ybtbr;u6!Y8L0EgVUBm
zdTL3rLZSjRy1@;;L=c&pnVzSRkzZV*_Y#x`aL1k!0|TgW$0Wv3%TmIyfUySD>|=t&
zSq&&wnLy<)DCRUniZWAEK&5+rK`N*TnU-G!w+1B!HJK4nb&DOENi;FyObb*b<BGE+
zP^d!UjDt~tu}Ts>VBpc_r^#5P2{H;)yCX$EII6(0q`|<z5DzjB8cR$?AQ6mMB2*3w
zhGgcZ=9iWPmn4=zOJhUi$SFuHE(T?r#5{$}yt2fc%oK%UkWx^PB`TCaG~=nZwHX)~
zGEkfe5+T`{JWyvslFxo*7bYqc=O<^UmcSeX=^QBJCnuK{6+=rd=fsla43Ia#ok4IB
zpirKflcSIfl2Ay>FUe4_O07t?N&xjjk?kr5moql#!gdJ?iFqkdJ<uWyMVo>R7E!wd
zJ+N_j!VA>I$wLY+wjz)S$>Ak{?%*mnykQ0jErs%o%$!t(qSWNn%ra1Lr6iUlDx?+V
z=PD#B6sH!Ir553Fx-J6)Lj{u4nTkLnBs*OgOTbk*5bt_e9g~+1Nuvbat;fK?(17A@
zkO;}{7V=9ihdMnoKM#^nJ&>JU4r#K0T$Nf}l9-f}S)8GesF0Uhj?~c9QwS|CP0Y!u
zRB(0n_wx&Kbqfu4b-~wa&}U#^XhU&6NQ7kP^SS00lvD=5yWP&nPKR`@6^cspiWTxp
zOF+#8STN`36@#-vUcN$Zeo?AIA_(W?<d>(W;B&PB0|P@3imO2)B)gj5IVZn3H3g@$
zVRcAqUP)>Zs8Rv7I}{SrN>YmyK+PX8HzToFAt^OAPazp>7(QnkGB7YqLUA@ogk)z6
z`Q#@jf_gk*i8-avV%G*az)Lbxi&8;NFhm2hyeK~}9a1GFDx_zYrRITpyb76l1*IkU
zoD6EL&p>f9NCd;lpdKW+RS9a4ptLHPU?Via44SOB;7$)nEGmXN-4@yD>8U00ph{XH
zzeu4tGdD9Qu?W&-0ww$ckS1`*hX(mT-JT4x8q{Y4VNk^ms?or$FwlSvXplyXp_U0+
zk28UWYQTdy@H$-BEip3(Qi+3&hm78U$8Eq3t6Lm7(9qUohBUEEKs76_N_rtEtYDQi
z4^x#iEUpk9MpV;9IO}I)1_p+CAfrIO0XODBA{fCA@-N8W#P(MOLW6vQlQU9tQ$zEz
z^YY8{s*I2WKM|286hO&3F;Ag1ueh`TH0GL`qEHOhsfQ8bAXk8JF|_5x2nlgWA9ev#
z4bwtKMo=4yAs*aw1+|={{qjo`5GI476Jk1O?2M&I78Jyw&L|`b*dTH%p%GvPk_ATq
zxMPWE)qq;It3ja#ivR(pDoJ!N!-Ky_5o8WnH<$n$25udJY+eB}2Ojz$5sc7>w~jCq
zeH2Rya};X|3pmm920^=TkYe2>6x1J01eGVr`FSOYnR%&2pa!Y}s3{8?npA)^?!n=c
z18QJ`#yb>HTj*61CHeUZxrup|&=w1<i&$Kx2A8P@HMUBN<3WApT6A@Onpj8hZt=Ri
z`nd*qI>);P1^EZv;tLLNb@p_F@v*ihEf^RWHi5zm6z-tZ%EDL#62l#0pqN4}Ccp#o
z{K2WorA3(~m9Wue0}vxMMFBh*RFGPfmS2<$YFZRS)hU3-s6Zl#;4z?LJS_}s1_p+m
zAXma;6(mBk8%2Xlld@8iOB{1b{1S6hK@J3sgFAs3FqgurH&`nIT%v({bcra#S-F|e
z_OU{+qaVIv*oJ|DVLyu7K_Vo(UCc8N9CE49kv@={L5|l4F<_3*P0R)dC@Axnr50tT
zfs!DovmFfURN-@}Edv9?Q52VgL`Zh2U~pw|Nop>rRSa?)$dM>%p%^R;Znc9ey3%6k
z@JUI&LQ<*%xVpoW7VH=p7*3<O5+p*hE5%{q8IY4$0!o`Ow|asYumA-OU?yhfDTMe0
z>w^b0^YhX&(@TrMbvVfNdHE#@iDikIIf+R*sS5d^o@4>kKzu=M&%nTN5ycZA5t2P2
z80_ci3rUC|SA&Au62yQxAC?}V1Fo<}5hyu>T64jEo(RX|b1tZTa2>_DAQ94?>ylcK
znwOHAmkci@lEM8VWH%?~DI}JZq~;csfWkL7F(nn$et^s#DkMTD^dQY4SRTv=Py8i9
zhK5pLc4Vd&>w!(jlb9SC7#Qv%d5pCPBto*sgkaT#Uw(;mMrmGlYD$$gOiUp!H8rIe
z<cXwIg=B~<XdFDhC<W9Q%?H&PDGHe-3W>!K>0*3Q;l#ke@C?btOhq6Ol3gs}l%G=R
zmtW#hQc{qUndF?GTaZ|inUs@S)ea6bkhDT^Mt*5d3Mf;;2J|vYN(%Inb23x&O2C77
zFh3?J<YZ>2f^}*@rf2dL(h5KkS(KSnT9OLtU?yjPhRRBd@`@FT63d}p)dW|cMX8A?
z@z9{r&?FdZpf=(gq%dGD0*PRR0jOaEZeoE3NRX>6<S7Bz{3Cd305k{5Rs^bKs?LEu
z1M{CkPHJ9yNrpm7erj=^dWk|Vc=!N5@CzHB_5rJc3^E3nCV@vmL477{!G}5lo&ZW8
ziJ<P2LS|lxLK&!g0CoXr)-xfYAhD<<GchLtqO2@GGese}C^fMJRNChx7Nw^u<b!Lr
zVo(uOTvC*pn46jcPFT=9fH64=@+2sLia}FJuvv=*;8_b$OB*y!2AQW|hBWCw>cLGq
zXj}RgJJe0LIAFnmZCc_lD4M|Se8wtqR4>C@a~SiXAa{Xcv>4RZNMQs`l7XhkKx46x
zsakzhlQdK_6_P4TQj5Vp)=^N+gmg(^4%5_RDslm}7+paGmiaW$G;dLAK~a1>10w@N
zF=%3xfsu)kg^}eS7FR=5u4KnOy6Oh92h^lSYI7mlsGy+y3JMo!n~R-?8Jy;*m4I&v
zc|u0)z(o-xO;%|`#US|(mY%`QQ)tFhfVD$Wr?^0o0dg^jE(YZ!<ixUoc_Bj$V-^c2
z$$&d&tl()bHbnAaha?{lP>6t{^A<}<YEI5A0Z4|5FG|f#%*@NoOTWbdv;GzvL=KwJ
zio8KueLw^_2*C}0a9bZ_92Y3QK-1R@j9iRd|5=#X7^|eAUPbag1!>Iy(=?6r{1R9Q
zsuqFM8zT9E5*ygH;1q`?u@!+*hakw^DCrElt08Hv$Q|T;u+PB+I3U1b018)jkXg{Q
z#Kgm11QNqYOYj~KDAbS(L-3Rl^DSPeH$74lQ&NknG(gil8DO?TK~a8LW(ufHkyxw%
z8kfk(FNX~Z<EyGba|se4w}FxmsBcjO62Wj8C}Dw%X(DHCg}`&0sC{8Wu$XUR9%xMl
zxRh1^walR1RPeY1hz;(NL3*UPyTYJ8Y7JuwV>VL}PYOdVV+~^pLn%X%R0>lqQyxbO
za}Cx`GAPAsviRNN1dTc5fO-v8c3?+=JLVaQDGGV{&~CU6tYR%LNh~UXG-W^)tChY!
zXzT>UEVk0uuX0A!kJ+DBP%Va=Ra%^?0MdzOh$gi7_5&p#P}CQhgIM4M1WroeR0NVx
z2E`PpYtF#T!N|hM!N|tU#K`oY=|2-ol{DBTC_xU-QMmi!AUowirb6SNr3fT~5&wiz
zrWlIlplHl5DoIVLvUN*^4(`KxIK}y;Maik4RU$?CrRf>aR&PO3eg$-16DbJsGztS4
z7#NI@+|5)362Wjc$>|o7wLqgunR)4u0R=zk7*0|pXhBPAQAs=`&&7iVv@-M3brh0H
zOBBk%D-z05i%LMvMDU7)ocwe>*vc)?P(f-gs7Z!W%Y#B4<VFw%uT21rs1<OeFhQ0+
z)iNU$<je~}>qJ2dp_u)uL_x`_G!Nv2)D#8KRDhL&YSArr=)e;!Nd<xu5-8<B*D2g$
zPf1NnO)e?E#S7CM57G>o$;6W4tYKly0Gbn%#ta@J(iq4Q7BF+bWei9JBd!RgG11Vx
zqSW%tycAG34%GIAM2{tO{#qe5FFC&yG?bj0f*9)ok8G3_foGRXK+SlN0Sbu<NuZ`R
z?gcHOpe1oAP6mniY3hMiaix`(loqAN#}|RxOi^;M6@q%jnH74u`DLladZ0`m4{3sf
zTMf6wKq5JrN%5$SqFbEsDRJ<S=q+|oFDo-Iy$G~W53<||H2MWzP6Jtl0$L?e1X_A<
ziyv)513VK9o@gurP2+**rogj2MW88@BGAM`5ojF02sA2wiwiNjT?86)E&`2!7J&xh
zz++2Apuw9W&?ra|Xn>&z)PFAm^?!>%y-IKo4BV*!x9Y*Q8MxxO#phUD3|deGon!%*
zCg7}D1d8(_P$(j`x8SAQEe@Mp@G4L{P%0<}l|ejAJgfq20&D_20z3k20vrNt0_-eo
t0zv|u0&D_YLL35YLLgZX$tA!gzz$Xm77<_*;1mL3At6BlHX#v^ZUB{IL+Stk

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/fields.cpython-39.pyc
deleted file mode 100644
index 56130a5219588566ba17d89f0b54fd2ab1a3bd1e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 8189
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
F1^}hfu!;Zx

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/filepost.cpython-39.pyc
deleted file mode 100644
index 4cab2f7c226b170283d267ba4b6af10d53616dfe..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2790
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
DhsDs|

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/poolmanager.cpython-39.pyc
deleted file mode 100644
index 76b6ecb0865fb55ce8ac8c0e6377b267c8537887..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 15192
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
DAr94p

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/request.cpython-39.pyc
deleted file mode 100644
index d45e5d369b6050a8e0bb4032ab07b627ea6a015b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5653
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
IVPazj05M>3B>(^b

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/__pycache__/response.cpython-39.pyc
deleted file mode 100644
index 1d8c0efa8688b1d8bfd74c549b9ba8e5c0061757..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 20864
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
JP(YM}7XS(J6ITEL

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/_version.py b/env/Lib/site-packages/pip/_vendor/urllib3/_version.py
index 97c98330..d69ca314 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/_version.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/_version.py
@@ -1,2 +1,2 @@
 # This file is protected via CODEOWNERS
-__version__ = "1.26.4"
+__version__ = "1.26.16"
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/connection.py b/env/Lib/site-packages/pip/_vendor/urllib3/connection.py
index 45580b7e..54b96b19 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/connection.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/connection.py
@@ -51,15 +51,16 @@ from .exceptions import (
     SubjectAltNameWarning,
     SystemTimeWarning,
 )
-from .packages.ssl_match_hostname import CertificateError, match_hostname
 from .util import SKIP_HEADER, SKIPPABLE_HEADERS, connection
 from .util.ssl_ import (
     assert_fingerprint,
     create_urllib3_context,
+    is_ipaddress,
     resolve_cert_reqs,
     resolve_ssl_version,
     ssl_wrap_socket,
 )
+from .util.ssl_match_hostname import CertificateError, match_hostname
 
 log = logging.getLogger(__name__)
 
@@ -67,7 +68,7 @@ port_by_scheme = {"http": 80, "https": 443}
 
 # When it comes time to update this value as a part of regular maintenance
 # (ie test_recent_date is failing) update it to ~6 months before the current date.
-RECENT_DATE = datetime.date(2020, 7, 1)
+RECENT_DATE = datetime.date(2022, 1, 1)
 
 _CONTAINS_CONTROL_CHAR_RE = re.compile(r"[^-!#$%&'*+.^_`|~0-9a-zA-Z]")
 
@@ -107,6 +108,10 @@ class HTTPConnection(_HTTPConnection, object):
     #: Whether this connection verifies the host's certificate.
     is_verified = False
 
+    #: Whether this proxy connection (if used) verifies the proxy host's
+    #: certificate.
+    proxy_is_verified = None
+
     def __init__(self, *args, **kw):
         if not six.PY2:
             kw.pop("strict", None)
@@ -201,7 +206,7 @@ class HTTPConnection(_HTTPConnection, object):
         self._prepare_conn(conn)
 
     def putrequest(self, method, url, *args, **kwargs):
-        """"""
+        """ """
         # Empty docstring because the indentation of CPython's implementation
         # is broken but we don't want this method in our documentation.
         match = _CONTAINS_CONTROL_CHAR_RE.search(method)
@@ -214,7 +219,7 @@ class HTTPConnection(_HTTPConnection, object):
         return _HTTPConnection.putrequest(self, method, url, *args, **kwargs)
 
     def putheader(self, header, *values):
-        """"""
+        """ """
         if not any(isinstance(v, str) and v == SKIP_HEADER for v in values):
             _HTTPConnection.putheader(self, header, *values)
         elif six.ensure_str(header.lower()) not in SKIPPABLE_HEADERS:
@@ -224,6 +229,11 @@ class HTTPConnection(_HTTPConnection, object):
             )
 
     def request(self, method, url, body=None, headers=None):
+        # Update the inner socket's timeout value to send the request.
+        # This only triggers if the connection is re-used.
+        if getattr(self, "sock", None) is not None:
+            self.sock.settimeout(self.timeout)
+
         if headers is None:
             headers = {}
         else:
@@ -249,7 +259,7 @@ class HTTPConnection(_HTTPConnection, object):
             self.putheader("User-Agent", _get_default_user_agent())
         for header, value in headers.items():
             self.putheader(header, value)
-        if "transfer-encoding" not in headers:
+        if "transfer-encoding" not in header_keys:
             self.putheader("Transfer-Encoding", "chunked")
         self.endheaders()
 
@@ -350,17 +360,15 @@ class HTTPSConnection(HTTPConnection):
 
     def connect(self):
         # Add certificate verification
-        conn = self._new_conn()
+        self.sock = conn = self._new_conn()
         hostname = self.host
         tls_in_tls = False
 
         if self._is_using_tunnel():
             if self.tls_in_tls_required:
-                conn = self._connect_tls_proxy(hostname, conn)
+                self.sock = conn = self._connect_tls_proxy(hostname, conn)
                 tls_in_tls = True
 
-            self.sock = conn
-
             # Calls self._set_hostport(), so self.host is
             # self._tunnel_host below.
             self._tunnel()
@@ -490,14 +498,10 @@ class HTTPSConnection(HTTPConnection):
             self.ca_cert_dir,
             self.ca_cert_data,
         )
-        # By default urllib3's SSLContext disables `check_hostname` and uses
-        # a custom check. For proxies we're good with relying on the default
-        # verification.
-        ssl_context.check_hostname = True
 
         # If no cert was provided, use only the default options for server
         # certificate validation
-        return ssl_wrap_socket(
+        socket = ssl_wrap_socket(
             sock=conn,
             ca_certs=self.ca_certs,
             ca_cert_dir=self.ca_cert_dir,
@@ -506,8 +510,37 @@ class HTTPSConnection(HTTPConnection):
             ssl_context=ssl_context,
         )
 
+        if ssl_context.verify_mode != ssl.CERT_NONE and not getattr(
+            ssl_context, "check_hostname", False
+        ):
+            # While urllib3 attempts to always turn off hostname matching from
+            # the TLS library, this cannot always be done. So we check whether
+            # the TLS Library still thinks it's matching hostnames.
+            cert = socket.getpeercert()
+            if not cert.get("subjectAltName", ()):
+                warnings.warn(
+                    (
+                        "Certificate for {0} has no `subjectAltName`, falling back to check for a "
+                        "`commonName` for now. This feature is being removed by major browsers and "
+                        "deprecated by RFC 2818. (See https://github.com/urllib3/urllib3/issues/497 "
+                        "for details.)".format(hostname)
+                    ),
+                    SubjectAltNameWarning,
+                )
+            _match_hostname(cert, hostname)
+
+        self.proxy_is_verified = ssl_context.verify_mode == ssl.CERT_REQUIRED
+        return socket
+
 
 def _match_hostname(cert, asserted_hostname):
+    # Our upstream implementation of ssl.match_hostname()
+    # only applies this normalization to IP addresses so it doesn't
+    # match DNS SANs so we do the same thing!
+    stripped_hostname = asserted_hostname.strip("u[]")
+    if is_ipaddress(stripped_hostname):
+        asserted_hostname = stripped_hostname
+
     try:
         match_hostname(cert, asserted_hostname)
     except CertificateError as e:
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py b/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py
index 4708c5bf..96844d93 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/connectionpool.py
@@ -2,6 +2,7 @@ from __future__ import absolute_import
 
 import errno
 import logging
+import re
 import socket
 import sys
 import warnings
@@ -35,7 +36,6 @@ from .exceptions import (
 )
 from .packages import six
 from .packages.six.moves import queue
-from .packages.ssl_match_hostname import CertificateError
 from .request import RequestMethods
 from .response import HTTPResponse
 from .util.connection import is_connection_dropped
@@ -44,11 +44,19 @@ from .util.queue import LifoQueue
 from .util.request import set_file_position
 from .util.response import assert_header_parsing
 from .util.retry import Retry
+from .util.ssl_match_hostname import CertificateError
 from .util.timeout import Timeout
 from .util.url import Url, _encode_target
 from .util.url import _normalize_host as normalize_host
 from .util.url import get_host, parse_url
 
+try:  # Platform-specific: Python 3
+    import weakref
+
+    weakref_finalize = weakref.finalize
+except AttributeError:  # Platform-specific: Python 2
+    from .packages.backports.weakref_finalize import weakref_finalize
+
 xrange = six.moves.xrange
 
 log = logging.getLogger(__name__)
@@ -219,6 +227,16 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
             self.conn_kw["proxy"] = self.proxy
             self.conn_kw["proxy_config"] = self.proxy_config
 
+        # Do not pass 'self' as callback to 'finalize'.
+        # Then the 'finalize' would keep an endless living (leak) to self.
+        # By just passing a reference to the pool allows the garbage collector
+        # to free self if nobody else has a reference to it.
+        pool = self.pool
+
+        # Close all the HTTPConnections in the pool before the
+        # HTTPConnectionPool object is garbage collected.
+        weakref_finalize(self, _close_pool_connections, pool)
+
     def _new_conn(self):
         """
         Return a fresh :class:`HTTPConnection`.
@@ -301,8 +319,11 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
             pass
         except queue.Full:
             # This should never happen if self.block == True
-            log.warning("Connection pool is full, discarding connection: %s", self.host)
-
+            log.warning(
+                "Connection pool is full, discarding connection: %s. Connection pool size: %s",
+                self.host,
+                self.pool.qsize(),
+            )
         # Connection never got put back into the pool, close it.
         if conn:
             conn.close()
@@ -318,7 +339,7 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
         pass
 
     def _get_timeout(self, timeout):
-        """ Helper that always returns a :class:`urllib3.util.Timeout` """
+        """Helper that always returns a :class:`urllib3.util.Timeout`"""
         if timeout is _Default:
             return self.timeout.clone()
 
@@ -375,7 +396,7 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
 
         timeout_obj = self._get_timeout(timeout)
         timeout_obj.start_connect()
-        conn.timeout = timeout_obj.connect_timeout
+        conn.timeout = Timeout.resolve_default_timeout(timeout_obj.connect_timeout)
 
         # Trigger any extra validation we need to do.
         try:
@@ -485,14 +506,8 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
         # Disable access to the pool
         old_pool, self.pool = self.pool, None
 
-        try:
-            while True:
-                conn = old_pool.get(block=False)
-                if conn:
-                    conn.close()
-
-        except queue.Empty:
-            pass  # Done.
+        # Close all the HTTPConnections in the pool.
+        _close_pool_connections(old_pool)
 
     def is_same_host(self, url):
         """
@@ -745,7 +760,35 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
             # Discard the connection for these exceptions. It will be
             # replaced during the next _get_conn() call.
             clean_exit = False
-            if isinstance(e, (BaseSSLError, CertificateError)):
+
+            def _is_ssl_error_message_from_http_proxy(ssl_error):
+                # We're trying to detect the message 'WRONG_VERSION_NUMBER' but
+                # SSLErrors are kinda all over the place when it comes to the message,
+                # so we try to cover our bases here!
+                message = " ".join(re.split("[^a-z]", str(ssl_error).lower()))
+                return (
+                    "wrong version number" in message or "unknown protocol" in message
+                )
+
+            # Try to detect a common user error with proxies which is to
+            # set an HTTP proxy to be HTTPS when it should be 'http://'
+            # (ie {'http': 'http://proxy', 'https': 'https://proxy'})
+            # Instead we add a nice error message and point to a URL.
+            if (
+                isinstance(e, BaseSSLError)
+                and self.proxy
+                and _is_ssl_error_message_from_http_proxy(e)
+                and conn.proxy
+                and conn.proxy.scheme == "https"
+            ):
+                e = ProxyError(
+                    "Your proxy appears to only use HTTP and not HTTPS, "
+                    "try changing your proxy URL to be HTTP. See: "
+                    "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html"
+                    "#https-proxy-error-http-proxy",
+                    SSLError(e),
+                )
+            elif isinstance(e, (BaseSSLError, CertificateError)):
                 e = SSLError(e)
             elif isinstance(e, (SocketError, NewConnectionError)) and self.proxy:
                 e = ProxyError("Cannot connect to proxy.", e)
@@ -830,7 +873,7 @@ class HTTPConnectionPool(ConnectionPool, RequestMethods):
             )
 
         # Check if we should retry the HTTP response.
-        has_retry_after = bool(response.getheader("Retry-After"))
+        has_retry_after = bool(response.headers.get("Retry-After"))
         if retries.is_retry(method, response.status, has_retry_after):
             try:
                 retries = retries.increment(method, url, response=response, _pool=self)
@@ -1014,12 +1057,23 @@ class HTTPSConnectionPool(HTTPConnectionPool):
                 (
                     "Unverified HTTPS request is being made to host '%s'. "
                     "Adding certificate verification is strongly advised. See: "
-                    "https://urllib3.readthedocs.io/en/latest/advanced-usage.html"
+                    "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html"
                     "#ssl-warnings" % conn.host
                 ),
                 InsecureRequestWarning,
             )
 
+        if getattr(conn, "proxy_is_verified", None) is False:
+            warnings.warn(
+                (
+                    "Unverified HTTPS connection done to an HTTPS proxy. "
+                    "Adding certificate verification is strongly advised. See: "
+                    "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html"
+                    "#ssl-warnings"
+                ),
+                InsecureRequestWarning,
+            )
+
 
 def connection_from_url(url, **kw):
     """
@@ -1065,3 +1119,14 @@ def _normalize_host(host, scheme):
     if host.startswith("[") and host.endswith("]"):
         host = host[1:-1]
     return host
+
+
+def _close_pool_connections(pool):
+    """Drains a queue of connections and closes each one."""
+    try:
+        while True:
+            conn = pool.get(block=False)
+            if conn:
+                conn.close()
+    except queue.Empty:
+        pass  # Done.
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 40e6d611f523e4472813c5a5e4ea2ff113b25b3d..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 227
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<>TtG-
z2`x@7Dvn9bNy#jV@y|<jDatHMRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-2
z4N@?R2?+3sNi@;T$xqKLF3HS}NzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+Bk
xFVZh9%E`%0GS*Md&nqd)Owx~!&&<m#iI3MSsJz8tlbfGXnv-e=a^Yu?PXL)cJ(U0e

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/_appengine_environ.cpython-39.pyc
deleted file mode 100644
index 3e32e8d745d2691a7f5293dae56899ced8c6f0d7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1447
zcmYe~<>g{vU|^UdaWHi+GXuk85C<7EF)%PVFfcF_TQD#%q%cG=q%fv1<uFDurZA_l
zv@k?5rLd;3wJ=06r?97Rv@k@mq;RHiwJ=1nrf{e5v@k@mr7#6EX!2G$afM`L7AxfD
zr<CTTDijpumu04;7AxeYCgv3@l;kU<q?V*6mnf8Eq$)TT6ezgnrDx`)Dx~I>WftY<
z<)-G9=yAOSxyvsZL?UBG1_lOakPCSj7#K<zni&eXN*J3Nf*CX!{WO_w31t??=j10R
z=ENr!6r_TUy(O4g9A8kBpMnrt$xy_?zyKkBO>(x12`x@7Dvn9bNy#jV@y|<jDatHM
zRnS!k_45pK4GQ)QaST@Q^mFm|a}D-%j0tx2bqx-24N@?R2?+3sNi@;T$xqKLF3HS}
zNzE&Z@ySezDb6fO)h$R&&Q45EEsiP3EYOcHOU+BkFVZh9%E`%0GS*Md&nqd)Owva<
zDjw>6y@JYHJekD^2@a5VK{3O?Sj5J_z<?1ZAUSZDh(N<6U#NsJiz$Usk|BjD8x$kV
ziOP%&3_+;{`9&qg3Ylr(kWVZqP{=G+C@Rg%%gjqx$jk$arezitmnfvC=A{-TmSpDV
zDHJE>r6lE7=y7o=C@3g|WTYw-rzYp;r68**D$Og&%uOv;NGwWKC`nDu$jeMl%*m-#
zC@#s&$pIOi2s1}VA*r-PA+rQ*8YqpFCTA$*q!t$|6r~oI6lErtWR|7sC=};I%?FuM
znO~|<oRMFelai-iqL7!GngU8h$r-81*$Qd-MGBcEdSK&<Q&SZ(N=gcft@QPibMi}5
z^wRV5({obwlJj%*;R!-NB|o`XzqlkZFD0=kMIYvNunD&W9RmVf{oFnMT;qd6{X#r_
zU2ky|RF-7q=NXx6GK0ha7E^xlEp}*ZArcaV#md0Ia7zR^`r@Gh2uiTUpr~SCFXF})
zji4k6jz&39=3^{j$YLyG$d>`p3z$-vQkWMqEnrSzS;!d7pvmf2#168FKiD-W%rz)J
z*xxNA+%d@Y7DE+}OKMqaPJRI>8|klPDdGgBbWpax#hjj6a*M0DB(bQZxID8Y1L9(k
zwGbA_?L{CLih)ubNDBj_03*wP7AB^DU~!C;2hvNTlZ!y%P{hl?z)&UR4vrn9B0#^0
z59C^qu@EPLSzvcDGcYj7U~v~n9K&7kQUatu1r%URRopJA1x2aJi6yBidTvOjgOotH
zAbW0!VU!l}xn;S<N+7F2VZ*>wB*?(PpviuVJw84qKRG@g62hRI3658ANELyc1y%?#
f8qE?8n_O_wXa{m=F(^b>SU8wDSU9*i*f`h#l_g?R

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/appengine.cpython-39.pyc
deleted file mode 100644
index baa44069aba7776faed88519d3ff6eae68581e63..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/ntlmpool.cpython-39.pyc
deleted file mode 100644
index 4470deba90c92bfb21b4b8dff348fd5d12b54a10..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/pyopenssl.cpython-39.pyc
deleted file mode 100644
index 86e6bed6938f93244b2d9763c4905e02d23f1776..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 15559
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
Bp8x;=

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/securetransport.cpython-39.pyc
deleted file mode 100644
index 3ea8ac016dae5f4200b945e5593622933a9881df..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/__pycache__/socks.cpython-39.pyc
deleted file mode 100644
index 8bbdbfc62c257f22db850c24fb51b81e5cc42215..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 7a98112d02adb973bace1e0d5af4cdc2621eae0b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 244
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<n(1s6
z6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&5
z8l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6
zU!-4Jl#`R0WUQZ@pI1_pnWP_IoSIx(lv+}hm{(koUsR$WAD@|*SrQ+wS5SG2!zMRB
Pr8Fni4&>y|Ag=)cGfYIN

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/bindings.cpython-39.pyc
deleted file mode 100644
index 5530fef9006d1747934f5a357781467c698c22f7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 10751
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
L#K*|TEWil>Z@#hF

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/__pycache__/low_level.cpython-39.pyc
deleted file mode 100644
index f7b77d6125dde46e61d6fd9ac1b5d34a06c6f2ee..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9200
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
E03bD+(f|Me

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py
index 42526be7..264d564d 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/bindings.py
@@ -48,7 +48,7 @@ from ctypes import (
 )
 from ctypes.util import find_library
 
-from pip._vendor.urllib3.packages.six import raise_from
+from ...packages.six import raise_from
 
 if platform.system() != "Darwin":
     raise ImportError("Only macOS is supported")
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py
index ed812019..fa0b245d 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/_securetransport/low_level.py
@@ -188,6 +188,7 @@ def _cert_array_from_pem(pem_bundle):
         # We only want to do that if an error occurs: otherwise, the caller
         # should free.
         CoreFoundation.CFRelease(cert_array)
+        raise
 
     return cert_array
 
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py
index b9d2a690..1717ee22 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/appengine.py
@@ -111,7 +111,7 @@ class AppEngineManager(RequestMethods):
         warnings.warn(
             "urllib3 is using URLFetch on Google App Engine sandbox instead "
             "of sockets. To use sockets directly instead of URLFetch see "
-            "https://urllib3.readthedocs.io/en/latest/reference/urllib3.contrib.html.",
+            "https://urllib3.readthedocs.io/en/1.26.x/reference/urllib3.contrib.html.",
             AppEnginePlatformWarning,
         )
 
@@ -224,7 +224,7 @@ class AppEngineManager(RequestMethods):
                 )
 
         # Check if we should retry the HTTP response.
-        has_retry_after = bool(http_response.getheader("Retry-After"))
+        has_retry_after = bool(http_response.headers.get("Retry-After"))
         if retries.is_retry(method, http_response.status, has_retry_after):
             retries = retries.increment(method, url, response=http_response, _pool=self)
             log.debug("Retry: %s", url)
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py
index b2df45dc..47166575 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/ntlmpool.py
@@ -5,6 +5,7 @@ Issue #10, see: http://code.google.com/p/urllib3/issues/detail?id=10
 """
 from __future__ import absolute_import
 
+import warnings
 from logging import getLogger
 
 from ntlm import ntlm
@@ -12,6 +13,14 @@ from ntlm import ntlm
 from .. import HTTPSConnectionPool
 from ..packages.six.moves.http_client import HTTPSConnection
 
+warnings.warn(
+    "The 'urllib3.contrib.ntlmpool' module is deprecated and will be removed "
+    "in urllib3 v2.0 release, urllib3 is not able to support it properly due "
+    "to reasons listed in issue: https://github.com/urllib3/urllib3/issues/2282. "
+    "If you are a user of this module please comment in the mentioned issue.",
+    DeprecationWarning,
+)
+
 log = getLogger(__name__)
 
 
@@ -60,7 +69,7 @@ class NTLMConnectionPool(HTTPSConnectionPool):
         log.debug("Request headers: %s", headers)
         conn.request("GET", self.authurl, None, headers)
         res = conn.getresponse()
-        reshdr = dict(res.getheaders())
+        reshdr = dict(res.headers)
         log.debug("Response status: %s %s", res.status, res.reason)
         log.debug("Response headers: %s", reshdr)
         log.debug("Response data: %s [...]", res.read(100))
@@ -92,7 +101,7 @@ class NTLMConnectionPool(HTTPSConnectionPool):
         conn.request("GET", self.authurl, None, headers)
         res = conn.getresponse()
         log.debug("Response status: %s %s", res.status, res.reason)
-        log.debug("Response headers: %s", dict(res.getheaders()))
+        log.debug("Response headers: %s", dict(res.headers))
         log.debug("Response data: %s [...]", res.read()[:100])
         if res.status != 200:
             if res.status == 401:
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py
index bc5c114f..19e4aa97 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/pyopenssl.py
@@ -28,8 +28,8 @@ like this:
 .. code-block:: python
 
     try:
-        import urllib3.contrib.pyopenssl
-        urllib3.contrib.pyopenssl.inject_into_urllib3()
+        import pip._vendor.urllib3.contrib.pyopenssl as pyopenssl
+        pyopenssl.inject_into_urllib3()
     except ImportError:
         pass
 
@@ -47,10 +47,10 @@ compression in Python 2 (see `CRIME attack`_).
 """
 from __future__ import absolute_import
 
+import OpenSSL.crypto
 import OpenSSL.SSL
 from cryptography import x509
 from cryptography.hazmat.backends.openssl import backend as openssl_backend
-from cryptography.hazmat.backends.openssl.x509 import _Certificate
 
 try:
     from cryptography.x509 import UnsupportedExtension
@@ -73,9 +73,19 @@ except ImportError:  # Platform-specific: Python 3
 import logging
 import ssl
 import sys
+import warnings
 
 from .. import util
 from ..packages import six
+from ..util.ssl_ import PROTOCOL_TLS_CLIENT
+
+warnings.warn(
+    "'urllib3.contrib.pyopenssl' module is deprecated and will be removed "
+    "in a future release of urllib3 2.x. Read more in this issue: "
+    "https://github.com/urllib3/urllib3/issues/2680",
+    category=DeprecationWarning,
+    stacklevel=2,
+)
 
 __all__ = ["inject_into_urllib3", "extract_from_urllib3"]
 
@@ -85,6 +95,7 @@ HAS_SNI = True
 # Map from urllib3 to PyOpenSSL compatible parameter-values.
 _openssl_versions = {
     util.PROTOCOL_TLS: OpenSSL.SSL.SSLv23_METHOD,
+    PROTOCOL_TLS_CLIENT: OpenSSL.SSL.SSLv23_METHOD,
     ssl.PROTOCOL_TLSv1: OpenSSL.SSL.TLSv1_METHOD,
 }
 
@@ -217,9 +228,8 @@ def get_subj_alt_name(peer_cert):
     if hasattr(peer_cert, "to_cryptography"):
         cert = peer_cert.to_cryptography()
     else:
-        # This is technically using private APIs, but should work across all
-        # relevant versions before PyOpenSSL got a proper API for this.
-        cert = _Certificate(openssl_backend, peer_cert._x509)
+        der = OpenSSL.crypto.dump_certificate(OpenSSL.crypto.FILETYPE_ASN1, peer_cert)
+        cert = x509.load_der_x509_certificate(der, openssl_backend)
 
     # We want to find the SAN extension. Ask Cryptography to locate it (it's
     # faster than looping in Python)
@@ -404,7 +414,6 @@ if _fileobject:  # Platform-specific: Python 2
         self._makefile_refs += 1
         return _fileobject(self, mode, bufsize, close=True)
 
-
 else:  # Platform-specific: Python 3
     makefile = backport_makefile
 
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py
index 8f058f50..4a06bc69 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/securetransport.py
@@ -19,8 +19,8 @@ contrib module. So...here we are.
 
 To use this module, simply import and inject it::
 
-    import urllib3.contrib.securetransport
-    urllib3.contrib.securetransport.inject_into_urllib3()
+    import pip._vendor.urllib3.contrib.securetransport as securetransport
+    securetransport.inject_into_urllib3()
 
 Happy TLSing!
 
@@ -67,6 +67,7 @@ import weakref
 from pip._vendor import six
 
 from .. import util
+from ..util.ssl_ import PROTOCOL_TLS_CLIENT
 from ._securetransport.bindings import CoreFoundation, Security, SecurityConst
 from ._securetransport.low_level import (
     _assert_no_error,
@@ -154,7 +155,8 @@ CIPHER_SUITES = [
 # TLSv1 and a high of TLSv1.2. For everything else, we pin to that version.
 # TLSv1 to 1.2 are supported on macOS 10.8+
 _protocol_to_min_max = {
-    util.PROTOCOL_TLS: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12)
+    util.PROTOCOL_TLS: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12),
+    PROTOCOL_TLS_CLIENT: (SecurityConst.kTLSProtocol1, SecurityConst.kTLSProtocol12),
 }
 
 if hasattr(ssl, "PROTOCOL_SSLv2"):
@@ -768,7 +770,6 @@ if _fileobject:  # Platform-specific: Python 2
         self._makefile_refs += 1
         return _fileobject(self, mode, bufsize, close=True)
 
-
 else:  # Platform-specific: Python 3
 
     def makefile(self, mode="r", buffering=None, *args, **kwargs):
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py
index 93df8325..c326e80d 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/contrib/socks.py
@@ -51,7 +51,7 @@ except ImportError:
         (
             "SOCKS support in urllib3 requires the installation of optional "
             "dependencies: specifically, PySocks.  For more information, see "
-            "https://urllib3.readthedocs.io/en/latest/contrib.html#socks-proxies"
+            "https://urllib3.readthedocs.io/en/1.26.x/contrib.html#socks-proxies"
         ),
         DependencyWarning,
     )
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py
index fce4caa6..e69de29b 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__init__.py
@@ -1,5 +0,0 @@
-from __future__ import absolute_import
-
-from . import ssl_match_hostname
-
-__all__ = ("ssl_match_hostname",)
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 02aa51fa15e346b938ec39b1ff8d34076c0ab5e2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 341
zcmYe~<>g{vU|^UdaWFN9fq~&Mh=Yuo7#J8F7#J9e6&M&8QW#Pga~N_NqZk<(QkYVh
zbC`0OqnH^PQkbJyQdoi+G+AGQ^lCER;!jK}&d(_=NsZ6UEyyn_dCADYz@W)^OQ^Uw
zCq6f^Bsn8KBfq#LFEKaOPm}c)SA2Y0X-R2OYJ7YV$i`a?MJx;q47b?h;}dgo;^S8`
z6mc*xK!{(R&Q>v@#i>QbF{wEznME=Fd8sZ%nPsU8x(cCwo?)&*!JZ+G!3v&!F8+S5
z!JdvW!LGip!6B|e3T80@0X{K_Cb~KK>6yhPnb|R^d1Wy^nMpClnI);Z1&PVoiRr1u
zF$I|g`tfC{c`5lt`lUrVIhjeu`Y=iT`1s7c%#!$cy@JYH95%W6DWy57b|CK+gPhF6
H#KQytyA58^

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/__pycache__/six.cpython-39.pyc
deleted file mode 100644
index a62240feffc825fce5986b0c7e43ef59b2e74fa2..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 801ef48ec8379dbb973b0eef1967c6e3c3f0bfdb..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 238
zcmYe~<>g{vU|^UdaWEA`KL!!Vn2~{j!GVE+p_qk%fgyz<m_d`#ZzV$!NEku<n(S;9
z6Iz^FR2-9<lag5!<DZx6Qj}Sis-UY7>gO5e8Wijq;ux&p>F46_=Njzk7!&O3>lz&5
z8l+$r6A<7NlW3xwlb@bhT#}g`lbTl+<CB>bQ=D0ns#}nloSm4SS{zf5S)d<ZmYSE6
zU!-4Jl#`R0WULR9)K5xG&MwF=Dk;{FkI&4@EQycTE2zB1VUwGmQks)$2XgFZkf#89
CDnaG|

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/backports/__pycache__/makefile.cpython-39.pyc
deleted file mode 100644
index 51dce1992154739169f3e848cbcd7c28112c0c8b..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1336
zcmYe~<>g{vU|^UdaWJ)$m4V?gh=Yt-85kHG7#J9e)fgBUQW&BbQW#U1au}l+Qy5d2
zbC`0OqnH^PQrJ^iQ`lM<qgYayf*CY9s^)SfB_?MV<QJ6`>*Xe9r>14*q;l0^04^>k
zm@<Wuj8uhy%94!yJOyKggoNV!<m}WExaNceh1}GVjQkXZwEQB4(&AKw^30M9g~Ytd
zl8nr}bcK?P#1gLZ#JrMXg_3-Q<f7EXl2nC61*Npa>{KNMh+zu(Nm;4MC3;*hK_2we
zWW2=@47SD7{}y9WG8;$~ig_6r7(jeykk9!T85l|!Y8aatGZ<1B7c*uv7R!||rZCko
zrZI{!G&43arZCqqmNC?_rLchL0;3u>9)?=>8uns`8n$8wFNP+@6jqQ-Ek_DlEoTjT
zQA7=A3X3^IEoTi|QA!PG3NwgZ!c@ah!`aMK%T>d`!jQ$B!fwvM#1PM1!<52N%23pi
z!dc5y!<536%}_M0ge8j=%3~^8SHn@fs)R9x8|0Q6u3&~5_M&4oY(>XPSQfC=aMf_t
zFfC-R<<3*9VK2H-!m@xJEW%XFohMSmR{Q|uz7m!N95B%uj-oF$+`$YbEDJbmxNDee
zSZY`ovefd_FxK$IbJg$!GidTuS#c>SC@8?9Pa!`IYn-JO<>$g<RnJrptjUg<fq~%`
zV|fvTPO4JN%qvUG$xKnm%}+^HP%To>$j{5ER4CF>DA!R)Qb^3n$uCb$(JW$NU|;}i
zDgvd-TMRE585kJ+UjG08|9=sPS*2K-msFaTmRgjWqEK8?l$w}ZtdLt;T%wSas*seK
zmsnJ($$g8tIJM*!S6E_BX{u{cQGQVo69WT76kj|noyHfXrWM~}%FMqd?BeR?80r%e
z?-c6h<{A_q>>1^Hi_ZyaLr{1?VrCH%KQ%EW6^S2Slv$Embc;76wW7q+KfEZhpdhvA
z77NIan!LAIic@paiUdI+!3lA5W?uR&j?}#5{1gz2EfwUp;#=%_spUDDd8xP9%ZoBg
zKr-w_sfiFJ5HH<gFG?&2nR<)4D6#w&8^p9*EG4NGB`X<<<QNzjeoc0^iU}=FEh>&l
z%}L2Dit*1&bt%d$OI6TS2=(&}a}5gi3~>xr@bq)>_j3*Qbc_jh^>qynaSc*1iwOwu
ziAglk&B;&CEH25+j!Dfci}A@!iYd-4N!2Y#OwLYBPc4oq$Sly0FH6l!$uH6`Ey~Hs
zOfuGoN$SH31ASN^>lIYq5`+oEgC3Oaib16f1DgONA0r1NA0rPV2O|q33z+0!<N}L=
zcx+G+5L<weg^`bmgOLZUQh<?-u}Fb|fkBfMoLKz){QNXoZ?VV6r{pKc#}{#f!ki6K
qB!J@{tQZ_lNQ68{6^Bi3eoARhsvRha6mu{zFtD(5F!Hc4{09J(DSyuZ

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py
index 31442409..f099a3dc 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/packages/six.py
@@ -1,4 +1,4 @@
-# Copyright (c) 2010-2019 Benjamin Peterson
+# Copyright (c) 2010-2020 Benjamin Peterson
 #
 # Permission is hereby granted, free of charge, to any person obtaining a copy
 # of this software and associated documentation files (the "Software"), to deal
@@ -29,7 +29,7 @@ import sys
 import types
 
 __author__ = "Benjamin Peterson <benjamin@python.org>"
-__version__ = "1.12.0"
+__version__ = "1.16.0"
 
 
 # Useful for very coarse version differentiation.
@@ -71,6 +71,11 @@ else:
             MAXSIZE = int((1 << 63) - 1)
         del X
 
+if PY34:
+    from importlib.util import spec_from_loader
+else:
+    spec_from_loader = None
+
 
 def _add_doc(func, doc):
     """Add documentation to a function."""
@@ -182,6 +187,11 @@ class _SixMetaPathImporter(object):
             return self
         return None
 
+    def find_spec(self, fullname, path, target=None):
+        if fullname in self.known_modules:
+            return spec_from_loader(fullname, self)
+        return None
+
     def __get_module(self, fullname):
         try:
             return self.known_modules[fullname]
@@ -220,6 +230,12 @@ class _SixMetaPathImporter(object):
 
     get_source = get_code  # same as get_code
 
+    def create_module(self, spec):
+        return self.load_module(spec.name)
+
+    def exec_module(self, module):
+        pass
+
 
 _importer = _SixMetaPathImporter(__name__)
 
@@ -260,9 +276,19 @@ _moved_attributes = [
     ),
     MovedModule("builtins", "__builtin__"),
     MovedModule("configparser", "ConfigParser"),
+    MovedModule(
+        "collections_abc",
+        "collections",
+        "collections.abc" if sys.version_info >= (3, 3) else "collections",
+    ),
     MovedModule("copyreg", "copy_reg"),
     MovedModule("dbm_gnu", "gdbm", "dbm.gnu"),
-    MovedModule("_dummy_thread", "dummy_thread", "_dummy_thread"),
+    MovedModule("dbm_ndbm", "dbm", "dbm.ndbm"),
+    MovedModule(
+        "_dummy_thread",
+        "dummy_thread",
+        "_dummy_thread" if sys.version_info < (3, 9) else "_thread",
+    ),
     MovedModule("http_cookiejar", "cookielib", "http.cookiejar"),
     MovedModule("http_cookies", "Cookie", "http.cookies"),
     MovedModule("html_entities", "htmlentitydefs", "html.entities"),
@@ -307,7 +333,9 @@ _moved_attributes = [
 ]
 # Add windows specific modules.
 if sys.platform == "win32":
-    _moved_attributes += [MovedModule("winreg", "_winreg")]
+    _moved_attributes += [
+        MovedModule("winreg", "_winreg"),
+    ]
 
 for attr in _moved_attributes:
     setattr(_MovedItems, attr.name, attr)
@@ -476,7 +504,7 @@ class Module_six_moves_urllib_robotparser(_LazyModule):
 
 
 _urllib_robotparser_moved_attributes = [
-    MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser")
+    MovedAttribute("RobotFileParser", "robotparser", "urllib.robotparser"),
 ]
 for attr in _urllib_robotparser_moved_attributes:
     setattr(Module_six_moves_urllib_robotparser, attr.name, attr)
@@ -678,9 +706,11 @@ if PY3:
     if sys.version_info[1] <= 1:
         _assertRaisesRegex = "assertRaisesRegexp"
         _assertRegex = "assertRegexpMatches"
+        _assertNotRegex = "assertNotRegexpMatches"
     else:
         _assertRaisesRegex = "assertRaisesRegex"
         _assertRegex = "assertRegex"
+        _assertNotRegex = "assertNotRegex"
 else:
 
     def b(s):
@@ -707,6 +737,7 @@ else:
     _assertCountEqual = "assertItemsEqual"
     _assertRaisesRegex = "assertRaisesRegexp"
     _assertRegex = "assertRegexpMatches"
+    _assertNotRegex = "assertNotRegexpMatches"
 _add_doc(b, """Byte literal""")
 _add_doc(u, """Text literal""")
 
@@ -723,6 +754,10 @@ def assertRegex(self, *args, **kwargs):
     return getattr(self, _assertRegex)(*args, **kwargs)
 
 
+def assertNotRegex(self, *args, **kwargs):
+    return getattr(self, _assertNotRegex)(*args, **kwargs)
+
+
 if PY3:
     exec_ = getattr(moves.builtins, "exec")
 
@@ -737,7 +772,6 @@ if PY3:
             value = None
             tb = None
 
-
 else:
 
     def exec_(_code_, _globs_=None, _locs_=None):
@@ -750,7 +784,7 @@ else:
             del frame
         elif _locs_ is None:
             _locs_ = _globs_
-        exec("""exec _code_ in _globs_, _locs_""")
+        exec ("""exec _code_ in _globs_, _locs_""")
 
     exec_(
         """def reraise(tp, value, tb=None):
@@ -762,18 +796,7 @@ else:
     )
 
 
-if sys.version_info[:2] == (3, 2):
-    exec_(
-        """def raise_from(value, from_value):
-    try:
-        if from_value is None:
-            raise value
-        raise value from from_value
-    finally:
-        value = None
-"""
-    )
-elif sys.version_info[:2] > (3, 2):
+if sys.version_info[:2] > (3,):
     exec_(
         """def raise_from(value, from_value):
     try:
@@ -863,19 +886,41 @@ if sys.version_info[:2] < (3, 3):
 _add_doc(reraise, """Reraise an exception.""")
 
 if sys.version_info[0:2] < (3, 4):
+    # This does exactly the same what the :func:`py3:functools.update_wrapper`
+    # function does on Python versions after 3.2. It sets the ``__wrapped__``
+    # attribute on ``wrapper`` object and it doesn't raise an error if any of
+    # the attributes mentioned in ``assigned`` and ``updated`` are missing on
+    # ``wrapped`` object.
+    def _update_wrapper(
+        wrapper,
+        wrapped,
+        assigned=functools.WRAPPER_ASSIGNMENTS,
+        updated=functools.WRAPPER_UPDATES,
+    ):
+        for attr in assigned:
+            try:
+                value = getattr(wrapped, attr)
+            except AttributeError:
+                continue
+            else:
+                setattr(wrapper, attr, value)
+        for attr in updated:
+            getattr(wrapper, attr).update(getattr(wrapped, attr, {}))
+        wrapper.__wrapped__ = wrapped
+        return wrapper
+
+    _update_wrapper.__doc__ = functools.update_wrapper.__doc__
 
     def wraps(
         wrapped,
         assigned=functools.WRAPPER_ASSIGNMENTS,
         updated=functools.WRAPPER_UPDATES,
     ):
-        def wrapper(f):
-            f = functools.wraps(wrapped, assigned, updated)(f)
-            f.__wrapped__ = wrapped
-            return f
-
-        return wrapper
+        return functools.partial(
+            _update_wrapper, wrapped=wrapped, assigned=assigned, updated=updated
+        )
 
+    wraps.__doc__ = functools.wraps.__doc__
 
 else:
     wraps = functools.wraps
@@ -888,7 +933,15 @@ def with_metaclass(meta, *bases):
     # the actual metaclass.
     class metaclass(type):
         def __new__(cls, name, this_bases, d):
-            return meta(name, bases, d)
+            if sys.version_info[:2] >= (3, 7):
+                # This version introduced PEP 560 that requires a bit
+                # of extra care (we mimic what is done by __build_class__).
+                resolved_bases = types.resolve_bases(bases)
+                if resolved_bases is not bases:
+                    d["__orig_bases__"] = bases
+            else:
+                resolved_bases = bases
+            return meta(name, resolved_bases, d)
 
         @classmethod
         def __prepare__(cls, name, this_bases):
@@ -928,12 +981,11 @@ def ensure_binary(s, encoding="utf-8", errors="strict"):
       - `str` -> encoded to `bytes`
       - `bytes` -> `bytes`
     """
+    if isinstance(s, binary_type):
+        return s
     if isinstance(s, text_type):
         return s.encode(encoding, errors)
-    elif isinstance(s, binary_type):
-        return s
-    else:
-        raise TypeError("not expecting type '%s'" % type(s))
+    raise TypeError("not expecting type '%s'" % type(s))
 
 
 def ensure_str(s, encoding="utf-8", errors="strict"):
@@ -947,12 +999,15 @@ def ensure_str(s, encoding="utf-8", errors="strict"):
       - `str` -> `str`
       - `bytes` -> decoded to `str`
     """
-    if not isinstance(s, (text_type, binary_type)):
-        raise TypeError("not expecting type '%s'" % type(s))
+    # Optimization: Fast return for the common case.
+    if type(s) is str:
+        return s
     if PY2 and isinstance(s, text_type):
-        s = s.encode(encoding, errors)
+        return s.encode(encoding, errors)
     elif PY3 and isinstance(s, binary_type):
-        s = s.decode(encoding, errors)
+        return s.decode(encoding, errors)
+    elif not isinstance(s, (text_type, binary_type)):
+        raise TypeError("not expecting type '%s'" % type(s))
     return s
 
 
@@ -977,7 +1032,7 @@ def ensure_text(s, encoding="utf-8", errors="strict"):
 
 def python_2_unicode_compatible(klass):
     """
-    A decorator that defines __unicode__ and __str__ methods under Python 2.
+    A class decorator that defines __unicode__ and __str__ methods under Python 2.
     Under Python 3 it does nothing.
 
     To support Python 2 and 3 with a single code base, define a __str__ method
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py
deleted file mode 100644
index 6b12fd90..00000000
--- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__init__.py
+++ /dev/null
@@ -1,22 +0,0 @@
-import sys
-
-try:
-    # Our match_hostname function is the same as 3.5's, so we only want to
-    # import the match_hostname function if it's at least that good.
-    if sys.version_info < (3, 5):
-        raise ImportError("Fallback to vendored code")
-
-    from ssl import CertificateError, match_hostname
-except ImportError:
-    try:
-        # Backport of the function from a pypi module
-        from backports.ssl_match_hostname import (  # type: ignore
-            CertificateError,
-            match_hostname,
-        )
-    except ImportError:
-        # Our vendored copy
-        from ._implementation import CertificateError, match_hostname  # type: ignore
-
-# Not needed, but documenting what we provide.
-__all__ = ("CertificateError", "match_hostname")
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 4c8deda5a4c951151d1e1a6c9be59dfe23c4c621..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 578
zcmYe~<>g{vU|^UdaWM5O69dCz5C<7^GcYhXFfcF_H!(0Uq%fo~<}gGtRH>yhWHF{N
zWiu4Xq%x&2H#0UdrZA+i<S^&5M6u+uMzJz7gfrxMu`r}ERaP)EfMAsfSOpu33MH_L
zB9J^ILkepOOAb3iK9V7i$$$Yurm#eDq%a0EXtKQoxz10M=_NA*1H(&J1_p*INw>tD
zoTS9$Y=x41g|gJVl>DO96ousclvGWoTLR9hMJ1VOnaPPIsjfvu`9-(*auZ9EGvYJy
zi%aqnb5mb3GB7Y`a^7Mtt}MRAQ<hp(oSB~&pP84Ie~a5Qw;;c$1fq?(xHzYXg@J*g
z2xMuL49G%|Y_VQ(aZWs{nNj@lnYjfysky0nC5a`O`FXe4<Kq)^a^mAxG8FNE%m5L;
z<~Uo$gche3700CJq+}Mw_~)g%6lIpBD(EVN`gw-A1_gVDI0h?t`nmY~xdwYW#ss_i
zx(0{11}T`u1O)iRB%0{v<fmsAmt<zgq~?{y_+%!<6la#C>J}s>XD6no7RMB17U;)A
zf<(WxC?_W~$ygsIsgLPy{rLFIyv&mLc)fzkTO2mI`6;D2sdk_MDi&d2VBlb4V&-Dx
SU=m^EVPs+wVc}ttVFm!YI-s=x

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/__pycache__/_implementation.cpython-39.pyc
deleted file mode 100644
index d3d2d92d3417ed330295530a81a606b993b2cac4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3331
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
AeE<Le

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py b/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py
deleted file mode 100644
index 689208d3..00000000
--- a/env/Lib/site-packages/pip/_vendor/urllib3/packages/ssl_match_hostname/_implementation.py
+++ /dev/null
@@ -1,160 +0,0 @@
-"""The match_hostname() function from Python 3.3.3, essential when using SSL."""
-
-# Note: This file is under the PSF license as the code comes from the python
-# stdlib.   http://docs.python.org/3/license.html
-
-import re
-import sys
-
-# ipaddress has been backported to 2.6+ in pypi.  If it is installed on the
-# system, use it to handle IPAddress ServerAltnames (this was added in
-# python-3.5) otherwise only do DNS matching.  This allows
-# backports.ssl_match_hostname to continue to be used in Python 2.7.
-try:
-    import ipaddress
-except ImportError:
-    ipaddress = None
-
-__version__ = "3.5.0.1"
-
-
-class CertificateError(ValueError):
-    pass
-
-
-def _dnsname_match(dn, hostname, max_wildcards=1):
-    """Matching according to RFC 6125, section 6.4.3
-
-    http://tools.ietf.org/html/rfc6125#section-6.4.3
-    """
-    pats = []
-    if not dn:
-        return False
-
-    # Ported from python3-syntax:
-    # leftmost, *remainder = dn.split(r'.')
-    parts = dn.split(r".")
-    leftmost = parts[0]
-    remainder = parts[1:]
-
-    wildcards = leftmost.count("*")
-    if wildcards > max_wildcards:
-        # Issue #17980: avoid denials of service by refusing more
-        # than one wildcard per fragment.  A survey of established
-        # policy among SSL implementations showed it to be a
-        # reasonable choice.
-        raise CertificateError(
-            "too many wildcards in certificate DNS name: " + repr(dn)
-        )
-
-    # speed up common case w/o wildcards
-    if not wildcards:
-        return dn.lower() == hostname.lower()
-
-    # RFC 6125, section 6.4.3, subitem 1.
-    # The client SHOULD NOT attempt to match a presented identifier in which
-    # the wildcard character comprises a label other than the left-most label.
-    if leftmost == "*":
-        # When '*' is a fragment by itself, it matches a non-empty dotless
-        # fragment.
-        pats.append("[^.]+")
-    elif leftmost.startswith("xn--") or hostname.startswith("xn--"):
-        # RFC 6125, section 6.4.3, subitem 3.
-        # The client SHOULD NOT attempt to match a presented identifier
-        # where the wildcard character is embedded within an A-label or
-        # U-label of an internationalized domain name.
-        pats.append(re.escape(leftmost))
-    else:
-        # Otherwise, '*' matches any dotless string, e.g. www*
-        pats.append(re.escape(leftmost).replace(r"\*", "[^.]*"))
-
-    # add the remaining fragments, ignore any wildcards
-    for frag in remainder:
-        pats.append(re.escape(frag))
-
-    pat = re.compile(r"\A" + r"\.".join(pats) + r"\Z", re.IGNORECASE)
-    return pat.match(hostname)
-
-
-def _to_unicode(obj):
-    if isinstance(obj, str) and sys.version_info < (3,):
-        obj = unicode(obj, encoding="ascii", errors="strict")
-    return obj
-
-
-def _ipaddress_match(ipname, host_ip):
-    """Exact matching of IP addresses.
-
-    RFC 6125 explicitly doesn't define an algorithm for this
-    (section 1.7.2 - "Out of Scope").
-    """
-    # OpenSSL may add a trailing newline to a subjectAltName's IP address
-    # Divergence from upstream: ipaddress can't handle byte str
-    ip = ipaddress.ip_address(_to_unicode(ipname).rstrip())
-    return ip == host_ip
-
-
-def match_hostname(cert, hostname):
-    """Verify that *cert* (in decoded format as returned by
-    SSLSocket.getpeercert()) matches the *hostname*.  RFC 2818 and RFC 6125
-    rules are followed, but IP addresses are not accepted for *hostname*.
-
-    CertificateError is raised on failure. On success, the function
-    returns nothing.
-    """
-    if not cert:
-        raise ValueError(
-            "empty or no certificate, match_hostname needs a "
-            "SSL socket or SSL context with either "
-            "CERT_OPTIONAL or CERT_REQUIRED"
-        )
-    try:
-        # Divergence from upstream: ipaddress can't handle byte str
-        host_ip = ipaddress.ip_address(_to_unicode(hostname))
-    except ValueError:
-        # Not an IP address (common case)
-        host_ip = None
-    except UnicodeError:
-        # Divergence from upstream: Have to deal with ipaddress not taking
-        # byte strings.  addresses should be all ascii, so we consider it not
-        # an ipaddress in this case
-        host_ip = None
-    except AttributeError:
-        # Divergence from upstream: Make ipaddress library optional
-        if ipaddress is None:
-            host_ip = None
-        else:
-            raise
-    dnsnames = []
-    san = cert.get("subjectAltName", ())
-    for key, value in san:
-        if key == "DNS":
-            if host_ip is None and _dnsname_match(value, hostname):
-                return
-            dnsnames.append(value)
-        elif key == "IP Address":
-            if host_ip is not None and _ipaddress_match(value, host_ip):
-                return
-            dnsnames.append(value)
-    if not dnsnames:
-        # The subject is only checked when there is no dNSName entry
-        # in subjectAltName
-        for sub in cert.get("subject", ()):
-            for key, value in sub:
-                # XXX according to RFC 2818, the most specific Common Name
-                # must be used.
-                if key == "commonName":
-                    if _dnsname_match(value, hostname):
-                        return
-                    dnsnames.append(value)
-    if len(dnsnames) > 1:
-        raise CertificateError(
-            "hostname %r "
-            "doesn't match either of %s" % (hostname, ", ".join(map(repr, dnsnames)))
-        )
-    elif len(dnsnames) == 1:
-        raise CertificateError("hostname %r doesn't match %r" % (hostname, dnsnames[0]))
-    else:
-        raise CertificateError(
-            "no appropriate commonName or subjectAltName fields were found"
-        )
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py b/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py
index 3a31a285..14b10daf 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/poolmanager.py
@@ -34,6 +34,7 @@ SSL_KEYWORDS = (
     "ca_cert_dir",
     "ssl_context",
     "key_password",
+    "server_hostname",
 )
 
 # All known keyword arguments that could be provided to the pool manager, its
@@ -170,7 +171,7 @@ class PoolManager(RequestMethods):
     def __init__(self, num_pools=10, headers=None, **connection_pool_kw):
         RequestMethods.__init__(self, headers)
         self.connection_pool_kw = connection_pool_kw
-        self.pools = RecentlyUsedContainer(num_pools, dispose_func=lambda p: p.close())
+        self.pools = RecentlyUsedContainer(num_pools)
 
         # Locally set the pool classes and keys so other PoolManagers can
         # override them.
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/response.py b/env/Lib/site-packages/pip/_vendor/urllib3/response.py
index 38693f4f..8909f845 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/response.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/response.py
@@ -2,16 +2,16 @@ from __future__ import absolute_import
 
 import io
 import logging
+import sys
+import warnings
 import zlib
 from contextlib import contextmanager
 from socket import error as SocketError
 from socket import timeout as SocketTimeout
 
-try:
-    import brotli
-except ImportError:
-    brotli = None
+brotli = None
 
+from . import util
 from ._collections import HTTPHeaderDict
 from .connection import BaseSSLError, HTTPException
 from .exceptions import (
@@ -478,6 +478,54 @@ class HTTPResponse(io.IOBase):
             if self._original_response and self._original_response.isclosed():
                 self.release_conn()
 
+    def _fp_read(self, amt):
+        """
+        Read a response with the thought that reading the number of bytes
+        larger than can fit in a 32-bit int at a time via SSL in some
+        known cases leads to an overflow error that has to be prevented
+        if `amt` or `self.length_remaining` indicate that a problem may
+        happen.
+
+        The known cases:
+          * 3.8 <= CPython < 3.9.7 because of a bug
+            https://github.com/urllib3/urllib3/issues/2513#issuecomment-1152559900.
+          * urllib3 injected with pyOpenSSL-backed SSL-support.
+          * CPython < 3.10 only when `amt` does not fit 32-bit int.
+        """
+        assert self._fp
+        c_int_max = 2 ** 31 - 1
+        if (
+            (
+                (amt and amt > c_int_max)
+                or (self.length_remaining and self.length_remaining > c_int_max)
+            )
+            and not util.IS_SECURETRANSPORT
+            and (util.IS_PYOPENSSL or sys.version_info < (3, 10))
+        ):
+            buffer = io.BytesIO()
+            # Besides `max_chunk_amt` being a maximum chunk size, it
+            # affects memory overhead of reading a response by this
+            # method in CPython.
+            # `c_int_max` equal to 2 GiB - 1 byte is the actual maximum
+            # chunk size that does not lead to an overflow error, but
+            # 256 MiB is a compromise.
+            max_chunk_amt = 2 ** 28
+            while amt is None or amt != 0:
+                if amt is not None:
+                    chunk_amt = min(amt, max_chunk_amt)
+                    amt -= chunk_amt
+                else:
+                    chunk_amt = max_chunk_amt
+                data = self._fp.read(chunk_amt)
+                if not data:
+                    break
+                buffer.write(data)
+                del data  # to reduce peak memory usage by `max_chunk_amt`.
+            return buffer.getvalue()
+        else:
+            # StringIO doesn't like amt=None
+            return self._fp.read(amt) if amt is not None else self._fp.read()
+
     def read(self, amt=None, decode_content=None, cache_content=False):
         """
         Similar to :meth:`http.client.HTTPResponse.read`, but with two additional
@@ -510,13 +558,11 @@ class HTTPResponse(io.IOBase):
         fp_closed = getattr(self._fp, "closed", False)
 
         with self._error_catcher():
+            data = self._fp_read(amt) if not fp_closed else b""
             if amt is None:
-                # cStringIO doesn't like amt=None
-                data = self._fp.read() if not fp_closed else b""
                 flush_decoder = True
             else:
                 cache_content = False
-                data = self._fp.read(amt) if not fp_closed else b""
                 if (
                     amt != 0 and not data
                 ):  # Platform-specific: Buggy versions of Python.
@@ -612,9 +658,21 @@ class HTTPResponse(io.IOBase):
 
     # Backwards-compatibility methods for http.client.HTTPResponse
     def getheaders(self):
+        warnings.warn(
+            "HTTPResponse.getheaders() is deprecated and will be removed "
+            "in urllib3 v2.1.0. Instead access HTTPResponse.headers directly.",
+            category=DeprecationWarning,
+            stacklevel=2,
+        )
         return self.headers
 
     def getheader(self, name, default=None):
+        warnings.warn(
+            "HTTPResponse.getheader() is deprecated and will be removed "
+            "in urllib3 v2.1.0. Instead use HTTPResponse.headers.get(name, default).",
+            category=DeprecationWarning,
+            stacklevel=2,
+        )
         return self.headers.get(name, default)
 
     # Backwards compatibility for http.cookiejar
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index 4b38bab0daaa82c515278469603046675949dc42..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1137
zcmYe~<>g{vU|^UdaWJ)+g@NHQh=Yuo7#J8F7#J9ew=gg;q%fo~<}l<kMlmunq%fs0
z=P>0mM=^uhEIBN>tWm7FY*B2v>{0AsG1eT8T+S#?Fq<uhE0;Tp8_Z_U;mPHV;?3oY
z;>+ca;?EU`637*d63i8f63P{h63!Kg63G>f63rEh5(BH}$Pv$#h?2;ajFJTNIdi0P
zrK6;CWujzqWus(s<)Y-k;#@iMxe8GVxr$MWj0`E<QA#O1!3>(bFG2p%WW2?nm{gpf
zQ(BT5pP5^bUsUpvk%56hlkt{lW^sISeqLT`a!F=>UVKVXenCNMiYD_d?qF}vfOrpA
zM;F(iTY?}?fTNR-D^w)-7Ef+sc4~Y^YGO)iQL!fDEuPHc__Tuf<edEC)D%s|TdYB;
zB}J8*T(|ffeFFUA1A_cR{GI)Mf^V^VI0nZD`+45t@eGa+i1ZI|^$QO6xh3Qo93SlJ
z92(>r66EL?9N-@ma*GG1D?Y?0_!d`iu#a<oUP)?2$t|J8;^NezlK8aDy!6zff}+g4
zl3RjBsm1v@WvTJWAeo}n!s1)PFrnh&ocOZTqT<Z_yj%PrPI*ycL40w3a&~HoCetnU
zkj&iF{L+$JJjta+MX7lu@g<qLshTXem_v(lZgHfimc(b|7nj`PEJ!RWPK_@u%DKf|
zT#%CqazIfr$OPW<L=Z2(D848)G36E?oLgR$S(2(LQN+!_z)-{kB6vXrKZxK15uhYk
z#0g@FfCw=VApjyoK?Dnk-~bWgAVLB}u!9Ie5FrF2Bte8Qh>!vi(jbBrM6fY1F!*UI
z-{OjoPb)1cElQ1#F9Id$TU>}3F9KO`i@hkdur#%}qzJCB2xQ4Ej-u4!g8aPV)FO}*
zZm|}D;uP%ITP&bZECM?o&1+y^f&B;e2Ew5rH{N0gg=~IlNfFq$AV1z>E-lI_0{a``
zN06s(v4BFc2=1#}?D6r5IXUt1D;bK^Kpq4UzgnHGVnT~ki;81Xb5b&kV*K+`U5YZx
zQWbO+Lj63$T!Vr=LmYz@JpEk!{ak}R9b<xBeO-e?T!R$MVgdquViHYsbMn(Oi%T-I
zV^Z_VVtg`_Vu~|MQgsUwld}`kQ;TB?G7I$M%Tn`F@{9CKi*j-@lZ^FCOEPox<Kr{)
tGE3s)^$IF)aoFVMr<CTT+JQ1wF(_hqn0XjQ7<m|Z7!7y?7$q15m;gjeFq{AY

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/connection.cpython-39.pyc
deleted file mode 100644
index 36f120ff5056d4d4a8dac8cbebf80bbccb921c3f..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3491
zcmYe~<>g{vU|^UdaWK_Nn1SIjh=Yuo85kHG7#J9e+ZY%aQW#Pga~N_NqZk=MY^EHh
zD5eyK6y_Y}T$U&nMurrY6xJNpT(&4SFq<uhJ(nYjgOMSHJ%uBOGnXrhE0;Tpn~@=f
zGli>#A&MuJDT_CSDTOJGIfXlgr-d<!FNHUSuZ1CsKZQR<poJkyAVn}msD&X)FjX)`
zxS26ZD1|AQK~v-<$c37WxA+s2it}?yOH$)Aa|`l|O8hh#ZwdM2CnuI<=H~?@78R$u
z78T_ey<}owU;s(QCl(Z>=A~!mrN*b`m1P#?=V>zDVlK|Cc*zJ-!E{T~FF!o7G9*7d
zF|))izbH6AIXkrkY{o6#^2E%N__X|@_@dOrlw^<wkSjnKWIP801A{XtoO~D<7)lsw
z7*ZHhn3|bu8EY6*m`WLnBtR~&VN78zWhhcfVF_la;wu5kv8J%~GKDh)Gq5m}FjcxS
zGJs$t14y+2Lke>+gC={T3L^spmx6+VLQrZ+X;EIWLP$|*szPR(LP<udLUMjyUTQMP
z!wQ+j3MobT1qG=o3W<3s3dI@ur8y}INvR6SIr+t@DSBLBL#zrCixP9e`mDeLAd{_<
za}tY-tr9XyN(%Inb23x&O7uKJLIRxOrY9)mCuOB3mq1PN%P&c_QgF*JQYgqtEJ@2R
z$}LvN$;?hwa4aZr1qZQ?LP<tuu|j!fPL4uiPI+Qwu|g5p{R#;QZizX?sR;=RCHY_%
z<fN8>{Q@&eAtNy_B?rZCMXAY^$vK&M=?W!9iFw5ZiAAY-B{`J}Y57G8rNw$+V{Wk&
z=O<^o`Gur|Vg-aX8E>(dWag&kmzHQU-(pWsElDgXDJtS*U|=ZXfJ8Y9C;*E<nP4SD
z5g!8s!>@K{tC-N@)S}{;)SQ&eq8R_YRF|U6vQ!0Kg-}1wFxQ}9&k)C81y4U0e?Qk?
zPsf;GS6|oQ5Z53DvzUMYpO{1w-JJaN%;J*F?3mQNvKXJtq?qE&l2qM-#N_P6^wi>*
zg3JQ___EZzl>8$7(xRN4%p_y|(vr*^eUMuqk*QZuc}q02I36Jq4~<(MP%0Aw`HqW+
zk%N&1jG37D7<m|r1Q-|?l374<Pz(~_h9ylCMh1o&h8U(=mRi;tmIVwcj0+iyWNKIz
zFs3jqWUOULVXkE>VQOZmWv}9^VOhYO!m^N&ks+KRPmP74grzbHlr$L`N>~@Lm9VF<
z*06{%G&80!FJxk4h-3(6FkmR*Sio7sQo~xqUc!;ZwUEVyA$CPAM-4{|Yb|FjS1orf
zPc3f>b1h$$UkS$ojvCGyt{U!z%(Z+a+%<eP%*{-U3^j};99cZ2j76Jj_!jWiFoNu_
zVJbRM!?%F1h6&8$Tfkq#3t@#bFflMfvJOX<zy!uh5k`hueny5WwHp3fwi><^=2FH9
zj71DJd<z5@GB7fL><(v$1kwC;{DpZb%(eV={00mL425|$Y*5u|HEd0cB^(O`QrH$U
zHZel8U^Wv212iuvl;kUDC8nelr4|=!fioI3S%Y#TC;_IHpk@{4{JgT%yv)?R<Wz;U
z(mZfp)l*QwYMe%*f{|`XX+ch^LPCN@Mt*UL4mfFpN;l1f1Wo+*DJTRa78ipvNk*zd
zegUXdNX!8npasnaS_<IopIVYy1j(Ak(7XqgSIEx;XGN$-GV_W{67!N%!Db|-rsWr<
zDkPSaq~;csfUU^~mm{EJK|#SYO(8E|0bx;Qu|jcaK|xMtY6_?<fS8e<lb@8BqmYuC
zmROooq5!kCIJE?9AS5VLQxuXa6|6vkWt9MNiC%hY2~-nQPXgFYnZ*jFpt22Yy;gC4
zX;E@&JUn(lPDm|L$ShIFEiEnq6@`fkkkHLfQ-B1o0yt>FW`W8Qq)05uS4hgtOHoKH
zR!CHUn5+ObSpgapxry1}U_dE{A%&4+o&qTP6!Oy))YTP0<z#+QiGqPbNor0`F*u0*
zgF#8Dv^W*agL)34`4?k!6;pJq-z}ERl)S_$S#{N7bsdGA#H7?51yI;mf($Il&sWIF
z&r7dT1eI$kDMguiY5CAHwpbxC52`XJv$#Z4=oVLTNn%k+ad~D*#x2(3lA_FlTSAFB
zIr-(ODe>uvnel0fxtTeYx7bqilJiqiZ}EiYWr7&s%CCrxfq~%`S5abSacX>8QGRX_
zs9A7}4H7lCxRLC?#U1SL>>VE*66EUWdrLUJIJG1mqAVVg9*b{@$GiLZJ30EqySTbJ
zhWdoWhj{wB`iF+x;sU1vaA|#u1r+qR*rCPWE!I>}MShDFT$5=E++v4DL=mWPyTu2I
z9ay}B_@Ig#ZX*jQCT_8SV)_<yYEjWGHmGlzi&BekF(szm;sCj^q_QCO7HdIKeo6i<
z&g8_r{Jgxx+|*l4#fjkh;TB^mxPpKX{GcEaOfE`IEJ;NwrPV;CvmL1P72;szV&r0E
zVP#`tVg!}WEQ~z=xmd&)`50LknHc$)xtPH6U{zd9LX0eoT#OuyGE7{IEKEg)ppqQa
zumBka!k`cbVQ?cug@J*ghB1Yql%a?xg&~-shS7x~mamqnh9QfghN+K%k)cokB(BK_
zY7&9M739DCf)Y(;h*#KQk-?l_Py+D~sO~EQ`Km~Ufq@|v<PT64$pETfm^c{0qRAka
zz%Zx@1j1k!iGZ6uS&X#|B}_#EB@9{2wG1^3!3>&=RhvUV?Ep|_29-zPR!VAdW_n&~
z3Ml=T=NDxwWI_s^<ovvn)QS>?{4{WWL`qgV3gsE8MX3sqc(VohCbdM*(JemIFF3%}
z8DuCZ=Rz|PsFVbo0B(E~q!xkNCklxQE`GrZ#i@x!$r<2wLsEW8hJt56nHfkuh+(2o
zl$xAhlv1px$x<W<iePp}w|GxK*N|Hr9*)8Bo&jNIw>aUpYBCmSf?5*bkOLFo;1gwF
zV913BA1fOp3nLq25l9rJ)d-4APymC2F9FoLW~^mQVX9>+VOYSpkfBHf)CMeJ%3>}G
zs8T9nTEJAol*O`;5!9kwz*@tQ!kh-K5K~xcnZg<Jgjg6#*ed-XRdggn9+Lq>4P#ME
z4dViKP}NrhYB#f1nPF{07FQORq~<ClC+0y5ygX1~n86A=Jq16vB2Yw!XmS*>f<i?k
zvlyu<U7VPgl9XQo2{4X~#NznOf-<vP9MGUME0PE4;dHG?P6gLUMM|KS7jqFPtAJBu
zktJp*-r|ghnN$G^OHi6*U}9lpVdG$AVPa!rV&q}uW8`4uVPs<hHGzt37#J9;n60b~
zHHB|+#mA?WmXsEy#>W?d@(|c*QE~;D1$xkCmmaj)rI!kGRWYPY1C=->MVUzuk8;48
zY>*O=1=I%sHyj~NNKoslNEYOHP<9395O6$$9aCfmk^m<Q1OZAQw>WHa^HWN5Qtd#2
jS`6|T4-*Fy4-*d~52FAxhYYBAVEV&l&%wdL%^?Q>Av(O#

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/proxy.cpython-39.pyc
deleted file mode 100644
index 476231a2cf4013ef8d11179c6c76b5d4a106cab7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1373
zcmYe~<>g{vU|^UdaWK_|je+4Yh=Yuo85kHG7#J9ebr={JQW#Pga~N_NqZo6UqL^}-
zqnH^PQrJ_NQ&?IUqgYZnQdm>iS{S2PQ<#DoG&x@~GB7Y`GT#zQE=o--NsTWp%E`%0
zGLBEq&nro-D7htAlv<phQ<fT^oLW>8UzA!{d`lQ6R9u`BUzS=_oSC2Jmke?P%uOIR
z69WT-GssOQ3=9l43@MDI3`IO3J8PIyn6sIRB*1KjEQS=8Y^EZE8b%P#Vk|NMiKnmz
zGib6U+A}gRa49G#C<LXJlosU`D})r4rYdBnDU@WSDkSIU<)tQ<Waj576r~oHW)`Iu
zD<tMAc!Y!mC^-B3`MElWD3oLr<(H;sfYlci<yTbdae>XVDo89!%vA^t@=*W_gS>48
zmI2uY63&NM0+!VS%Ru!6fQ)g@&r8cphw4oRa}e6WDnQOl%S<mVN(8$wttdZNp&&m$
zCpR%KF+H_Nub>jy(BhIJg_P9dlFU4?^7!K9jMUszgpnZ`sR|G=1*pT2RO=~dWa_0V
zWR#Q?6zhN~9fj1AWKFOIer~r|Kr**jL1b}=Cetl8h)K63N{dtD)AEbT6N^$Z^U^`g
zc(5W(=3AU#kAs5c77v68@#QTcB#WWWT**+x!@$7stI63aCbT%Us5mAyCnd8e#y>CB
zr6{v3RY6xF)Xy`_H7M9K#4%XG)6d1<&o$W7F(%m6*EKlAHAulMCLq8kCecJUCqF&2
zxFj<>CN-}t#wRl=rZ}@CRkt89IXf{uwK%3Avp_$-EHy7BzepdNQ1weoGIR97PSh)?
zyd{rF6`;gg3Q84VPsNv%=H;d4uz*se1Sp;IaWJwlb1<^7aQtUtV*1C#%<`9sm4&&8
zkAZ<9nH8i0irE+#7(m*<iP?;SfuV$<gt3O9nX!bahOwD3g|U~ZmbHed*r<lN*r<l3
z*r<fLhBbw$nW@OAhIIkULIy^L8c=d(u8IN2h<j>YYEfbdD77l2q^2d7=9EAZl0tED
z4k+1x@*OCV=jWv=WF!{nsh21urKaYA6qRMBq^2k&Re};U*s#*#)FMdo)MUEFjg%p8
zaUwFTP)>egN<7pqa7HfHWGw<^&?1n>ia^=*7JEiwabihHQIR01KwvB4XJB9`5@29p
zxW$p22+?$l8_J4L$t=3X1Lq``Btq<l78>B>03mom21r257H}-ZgB%G}s0xY=8BjR0
zGcmF;vi)OYWrD^A(_bbQjz3In985*xAO|t~`T1#r3AS4-AR{2|2RR+$2~fO&l|n2A
jrAP=1>;w**-29Z%oK!ndaaYX2z`!8F!tkF<iQzv0oMDNV

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/queue.cpython-39.pyc
deleted file mode 100644
index ad5b7f43da3c90bad6d8062c2995ccb02e817cf4..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1092
zcmYe~<>g{vU|^UdaWM50BLl-@5C<8vFfcGUFfcF_yD%^?q%fo~<}gGtq%fs0=P>3n
zMKLjg*ep5BxhzpEj0~wvS*%5RU{!2U?CuOHtSM|Q3@L1>ELm*L%uyUEjKK_=>@Pv)
z`@LjhU|`T>yv1CcS+SDw7HeT?YH4aRND3J<!>l)8U|>jPh+<4(h+;}%Okrwah+<A<
zNn=c5PGM<bjADgY6~&gqp2E?>5XGLt8O)%`b&Jy{Gc7+5Y&6I|n9(3M2s?v(#>c?G
zP{Oc)aUnwuLp)OoLomZiMn6sFTinU{IXS7xC7Jno#kW{fQVUB{i&#O9X1c{voSKt%
zi!pvBLlF-H1H-Q-XRDad;?$zznADt<%%T|oyi}K>%(7GkU4>9T&oI}ZV9yZ8U<FS<
z7k@w3U{A-GU{_z);1Jg!1+$od0H2sd6WyHr^vvRt%<P!dys{Xd%%qs&%#u{yg2d$P
z#PrnSn1aj#{rIxfyp;SR{nDbGoXjL+{nC=m9DQ)O=@nGoVvWzt%Pavorx@fl2F5CW
zxaal2a>-zEXc&OlAPf!yP#UOVtYOGvXl4v%C}L+|U?>8`ye3l-Na_}IPHG<5rx1dd
zfq~%`TYO=0W>qRbC<s9YF)&sMAXx~O#IO+*pI{pW7#J8p_AOwnVO+?_$N&m<u)Ug0
z;6T2`mRL}bnwJ7|0ZV2{YA(cfkQa-<PGE^IC@m2}asVHa0}4t@k{O|%1yLY2$em#8
zLB4`mzmNgyVVK3t1^ES<j9`Cb+LxYMB8tPl^wbhRO^#a}@$q?yxvBB-x47ctbMsS5
zb3kmK`1r!o#2koB5h%qKfdZ}w6bwbepx_1>i)0_%lSOO{3=G^LJ2@B_7&sU?n0c5v
zn8Bi&oJAn9TO6=dQUnU#C?ObEuQ;<pFE_s|wHOkl%mI-`w^+fsAxb2^G_SNcH3jBG
huqfD6Y>v3aVFU4s9VirwL7~UN#KXwL#Ky$I3;>K<>M#HR

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/request.cpython-39.pyc
deleted file mode 100644
index 98be7c28afb8b1f4d975ff29946c63fb10233bad..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3480
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
ZpuEn*$i~FM#Kr>d{6O;NFD?%bApkm}=L-M;

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/response.cpython-39.pyc
deleted file mode 100644
index c074f5247b59fc475cbe9b46f44b6bb5c9fcea87..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2377
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
bN@-3isCZ>4=3!u9;9(K~r7>m>c@8rGigJ*r

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/retry.cpython-39.pyc
deleted file mode 100644
index 0cd5e28e0363729af88574bbefc54ec4514fb3dd..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 15994
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
X#lpnM@t=i_jafjAgHfoS0Rlw;OI1j4

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssl_.cpython-39.pyc
deleted file mode 100644
index d042504c017a559495708b2f2d1f32f85b4dcb78..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 11055
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
HF9$aOsZsz)

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/ssltransport.cpython-39.pyc
deleted file mode 100644
index 218adca57277a39ada6f19f46a67f7b701b337e9..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 7543
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
Rl^mc^F%BjkMjj>>W&rDP7a;%u

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/timeout.cpython-39.pyc
deleted file mode 100644
index 32587903fb663fc956d83adf48903c45aa24c356..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/url.cpython-39.pyc
deleted file mode 100644
index 0a4b62b6136e95016e31300d89d9fefd9ae3ab9e..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

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

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/urllib3/util/__pycache__/wait.cpython-39.pyc
deleted file mode 100644
index 32922559841fde664bda32b4ee90639fdca557c7..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3160
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
TY#icT!dxO8EF8QX{9Nn+2Zg@w

diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py
index f1e5d37f..6af1138f 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/connection.py
@@ -2,9 +2,8 @@ from __future__ import absolute_import
 
 import socket
 
-from pip._vendor.urllib3.exceptions import LocationParseError
-
 from ..contrib import _appengine_environ
+from ..exceptions import LocationParseError
 from ..packages import six
 from .wait import NoWayToWaitForSocketError, wait_for_read
 
@@ -118,7 +117,7 @@ def allowed_gai_family():
 
 
 def _has_ipv6(host):
-    """ Returns True if the system can bind an IPv6 address. """
+    """Returns True if the system can bind an IPv6 address."""
     sock = None
     has_ipv6 = False
 
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py
index 34f884d5..2199cc7b 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/proxy.py
@@ -45,6 +45,7 @@ def create_proxy_ssl_context(
         ssl_version=resolve_ssl_version(ssl_version),
         cert_reqs=resolve_cert_reqs(cert_reqs),
     )
+
     if (
         not ca_certs
         and not ca_cert_dir
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py
index 25103383..330766ef 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/request.py
@@ -13,12 +13,6 @@ SKIP_HEADER = "@@@SKIP_HEADER@@@"
 SKIPPABLE_HEADERS = frozenset(["accept-encoding", "host", "user-agent"])
 
 ACCEPT_ENCODING = "gzip,deflate"
-try:
-    import brotli as _unused_module_brotli  # noqa: F401
-except ImportError:
-    pass
-else:
-    ACCEPT_ENCODING += ",br"
 
 _FAILEDTELL = object()
 
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py
index d25a41b4..2490d5e5 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/retry.py
@@ -37,7 +37,7 @@ class _RetryMeta(type):
     def DEFAULT_METHOD_WHITELIST(cls):
         warnings.warn(
             "Using 'Retry.DEFAULT_METHOD_WHITELIST' is deprecated and "
-            "will be removed in v2.0. Use 'Retry.DEFAULT_METHODS_ALLOWED' instead",
+            "will be removed in v2.0. Use 'Retry.DEFAULT_ALLOWED_METHODS' instead",
             DeprecationWarning,
         )
         return cls.DEFAULT_ALLOWED_METHODS
@@ -69,6 +69,24 @@ class _RetryMeta(type):
         )
         cls.DEFAULT_REMOVE_HEADERS_ON_REDIRECT = value
 
+    @property
+    def BACKOFF_MAX(cls):
+        warnings.warn(
+            "Using 'Retry.BACKOFF_MAX' is deprecated and "
+            "will be removed in v2.0. Use 'Retry.DEFAULT_BACKOFF_MAX' instead",
+            DeprecationWarning,
+        )
+        return cls.DEFAULT_BACKOFF_MAX
+
+    @BACKOFF_MAX.setter
+    def BACKOFF_MAX(cls, value):
+        warnings.warn(
+            "Using 'Retry.BACKOFF_MAX' is deprecated and "
+            "will be removed in v2.0. Use 'Retry.DEFAULT_BACKOFF_MAX' instead",
+            DeprecationWarning,
+        )
+        cls.DEFAULT_BACKOFF_MAX = value
+
 
 @six.add_metaclass(_RetryMeta)
 class Retry(object):
@@ -181,7 +199,7 @@ class Retry(object):
 
         seconds. If the backoff_factor is 0.1, then :func:`.sleep` will sleep
         for [0.0s, 0.2s, 0.4s, ...] between retries. It will never be longer
-        than :attr:`Retry.BACKOFF_MAX`.
+        than :attr:`Retry.DEFAULT_BACKOFF_MAX`.
 
         By default, backoff is disabled (set to 0).
 
@@ -220,7 +238,7 @@ class Retry(object):
     DEFAULT_REMOVE_HEADERS_ON_REDIRECT = frozenset(["Authorization"])
 
     #: Maximum backoff time.
-    BACKOFF_MAX = 120
+    DEFAULT_BACKOFF_MAX = 120
 
     def __init__(
         self,
@@ -321,7 +339,7 @@ class Retry(object):
 
     @classmethod
     def from_int(cls, retries, redirect=True, default=None):
-        """ Backwards-compatibility for the old retries format."""
+        """Backwards-compatibility for the old retries format."""
         if retries is None:
             retries = default if default is not None else cls.DEFAULT
 
@@ -348,7 +366,7 @@ class Retry(object):
             return 0
 
         backoff_value = self.backoff_factor * (2 ** (consecutive_errors_len - 1))
-        return min(self.BACKOFF_MAX, backoff_value)
+        return min(self.DEFAULT_BACKOFF_MAX, backoff_value)
 
     def parse_retry_after(self, retry_after):
         # Whitespace: https://tools.ietf.org/html/rfc7230#section-3.2.4
@@ -374,9 +392,9 @@ class Retry(object):
         return seconds
 
     def get_retry_after(self, response):
-        """ Get the value of Retry-After in seconds. """
+        """Get the value of Retry-After in seconds."""
 
-        retry_after = response.getheader("Retry-After")
+        retry_after = response.headers.get("Retry-After")
 
         if retry_after is None:
             return None
@@ -468,7 +486,7 @@ class Retry(object):
         )
 
     def is_exhausted(self):
-        """ Are we out of retries? """
+        """Are we out of retries?"""
         retry_counts = (
             self.total,
             self.connect,
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py
index 763da82b..2b45d391 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssl_.py
@@ -71,6 +71,11 @@ except ImportError:
     except ImportError:
         PROTOCOL_SSLv23 = PROTOCOL_TLS = 2
 
+try:
+    from ssl import PROTOCOL_TLS_CLIENT
+except ImportError:
+    PROTOCOL_TLS_CLIENT = PROTOCOL_TLS
+
 
 try:
     from ssl import OP_NO_COMPRESSION, OP_NO_SSLv2, OP_NO_SSLv3
@@ -159,7 +164,7 @@ except ImportError:
                 "urllib3 from configuring SSL appropriately and may cause "
                 "certain SSL connections to fail. You can upgrade to a newer "
                 "version of Python to solve this. For more information, see "
-                "https://urllib3.readthedocs.io/en/latest/advanced-usage.html"
+                "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html"
                 "#ssl-warnings",
                 InsecurePlatformWarning,
             )
@@ -278,7 +283,11 @@ def create_urllib3_context(
         Constructed SSLContext object with specified options
     :rtype: SSLContext
     """
-    context = SSLContext(ssl_version or PROTOCOL_TLS)
+    # PROTOCOL_TLS is deprecated in Python 3.10
+    if not ssl_version or ssl_version == PROTOCOL_TLS:
+        ssl_version = PROTOCOL_TLS_CLIENT
+
+    context = SSLContext(ssl_version)
 
     context.set_ciphers(ciphers or DEFAULT_CIPHERS)
 
@@ -313,13 +322,25 @@ def create_urllib3_context(
     ) is not None:
         context.post_handshake_auth = True
 
-    context.verify_mode = cert_reqs
-    if (
-        getattr(context, "check_hostname", None) is not None
-    ):  # Platform-specific: Python 3.2
-        # We do our own verification, including fingerprints and alternative
-        # hostnames. So disable it here
-        context.check_hostname = False
+    def disable_check_hostname():
+        if (
+            getattr(context, "check_hostname", None) is not None
+        ):  # Platform-specific: Python 3.2
+            # We do our own verification, including fingerprints and alternative
+            # hostnames. So disable it here
+            context.check_hostname = False
+
+    # The order of the below lines setting verify_mode and check_hostname
+    # matter due to safe-guards SSLContext has to prevent an SSLContext with
+    # check_hostname=True, verify_mode=NONE/OPTIONAL. This is made even more
+    # complex because we don't know whether PROTOCOL_TLS_CLIENT will be used
+    # or not so we don't know the initial state of the freshly created SSLContext.
+    if cert_reqs == ssl.CERT_REQUIRED:
+        context.verify_mode = cert_reqs
+        disable_check_hostname()
+    else:
+        disable_check_hostname()
+        context.verify_mode = cert_reqs
 
     # Enable logging of TLS session keys via defacto standard environment variable
     # 'SSLKEYLOGFILE', if the feature is available (Python 3.8+). Skip empty values.
@@ -401,7 +422,7 @@ def ssl_wrap_socket(
     try:
         if hasattr(context, "set_alpn_protocols"):
             context.set_alpn_protocols(ALPN_PROTOCOLS)
-    except NotImplementedError:
+    except NotImplementedError:  # Defensive: in CI, we always have set_alpn_protocols
         pass
 
     # If we detect server_hostname is an IP address then the SNI
@@ -419,7 +440,7 @@ def ssl_wrap_socket(
             "This may cause the server to present an incorrect TLS "
             "certificate, which can cause validation failures. You can upgrade to "
             "a newer version of Python to solve this. For more information, see "
-            "https://urllib3.readthedocs.io/en/latest/advanced-usage.html"
+            "https://urllib3.readthedocs.io/en/1.26.x/advanced-usage.html"
             "#ssl-warnings",
             SNIMissingWarning,
         )
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py
index ca00233c..4a7105d1 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/ssltransport.py
@@ -2,8 +2,8 @@ import io
 import socket
 import ssl
 
-from pip._vendor.urllib3.exceptions import ProxySchemeUnsupported
-from pip._vendor.urllib3.packages import six
+from ..exceptions import ProxySchemeUnsupported
+from ..packages import six
 
 SSL_BLOCKSIZE = 16384
 
@@ -193,7 +193,7 @@ class SSLTransport:
                 raise
 
     def _ssl_io_loop(self, func, *args):
-        """ Performs an I/O loop between incoming/outgoing and the socket."""
+        """Performs an I/O loop between incoming/outgoing and the socket."""
         should_loop = True
         ret = None
 
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py
index ff69593b..78e18a62 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/timeout.py
@@ -2,9 +2,8 @@ from __future__ import absolute_import
 
 import time
 
-# The default socket timeout, used by httplib to indicate that no timeout was
-# specified by the user
-from socket import _GLOBAL_DEFAULT_TIMEOUT
+# The default socket timeout, used by httplib to indicate that no timeout was; specified by the user
+from socket import _GLOBAL_DEFAULT_TIMEOUT, getdefaulttimeout
 
 from ..exceptions import TimeoutStateError
 
@@ -116,6 +115,10 @@ class Timeout(object):
     # __str__ provided for backwards compatibility
     __str__ = __repr__
 
+    @classmethod
+    def resolve_default_timeout(cls, timeout):
+        return getdefaulttimeout() if timeout is cls.DEFAULT_TIMEOUT else timeout
+
     @classmethod
     def _validate_timeout(cls, value, name):
         """Check that a timeout attribute is valid.
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py
index 66c8795b..a960b2f3 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/url.py
@@ -50,7 +50,7 @@ _variations = [
     "(?:(?:%(hex)s:){0,6}%(hex)s)?::",
 ]
 
-UNRESERVED_PAT = r"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._!\-~"
+UNRESERVED_PAT = r"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._\-~"
 IPV6_PAT = "(?:" + "|".join([x % _subs for x in _variations]) + ")"
 ZONE_ID_PAT = "(?:%25|%)(?:[" + UNRESERVED_PAT + "]|%[a-fA-F0-9]{2})+"
 IPV6_ADDRZ_PAT = r"\[" + IPV6_PAT + r"(?:" + ZONE_ID_PAT + r")?\]"
@@ -63,12 +63,12 @@ IPV6_ADDRZ_RE = re.compile("^" + IPV6_ADDRZ_PAT + "$")
 BRACELESS_IPV6_ADDRZ_RE = re.compile("^" + IPV6_ADDRZ_PAT[2:-2] + "$")
 ZONE_ID_RE = re.compile("(" + ZONE_ID_PAT + r")\]$")
 
-SUBAUTHORITY_PAT = (u"^(?:(.*)@)?(%s|%s|%s)(?::([0-9]{0,5}))?$") % (
+_HOST_PORT_PAT = ("^(%s|%s|%s)(?::0*?(|0|[1-9][0-9]{0,4}))?$") % (
     REG_NAME_PAT,
     IPV4_PAT,
     IPV6_ADDRZ_PAT,
 )
-SUBAUTHORITY_RE = re.compile(SUBAUTHORITY_PAT, re.UNICODE | re.DOTALL)
+_HOST_PORT_RE = re.compile(_HOST_PORT_PAT, re.UNICODE | re.DOTALL)
 
 UNRESERVED_CHARS = set(
     "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789._-~"
@@ -279,6 +279,9 @@ def _normalize_host(host, scheme):
         if scheme in NORMALIZABLE_SCHEMES:
             is_ipv6 = IPV6_ADDRZ_RE.match(host)
             if is_ipv6:
+                # IPv6 hosts of the form 'a::b%zone' are encoded in a URL as
+                # such per RFC 6874: 'a::b%25zone'. Unquote the ZoneID
+                # separator as necessary to return a valid RFC 4007 scoped IP.
                 match = ZONE_ID_RE.search(host)
                 if match:
                     start, end = match.span(1)
@@ -300,7 +303,7 @@ def _normalize_host(host, scheme):
 
 
 def _idna_encode(name):
-    if name and any([ord(x) > 128 for x in name]):
+    if name and any(ord(x) >= 128 for x in name):
         try:
             from pip._vendor import idna
         except ImportError:
@@ -331,7 +334,7 @@ def parse_url(url):
     """
     Given a url, return a parsed :class:`.Url` namedtuple. Best-effort is
     performed to parse incomplete urls. Fields not provided will be None.
-    This parser is RFC 3986 compliant.
+    This parser is RFC 3986 and RFC 6874 compliant.
 
     The parser logic and helper functions are based heavily on
     work done in the ``rfc3986`` module.
@@ -365,7 +368,9 @@ def parse_url(url):
             scheme = scheme.lower()
 
         if authority:
-            auth, host, port = SUBAUTHORITY_RE.match(authority).groups()
+            auth, _, host_port = authority.rpartition("@")
+            auth = auth or None
+            host, port = _HOST_PORT_RE.match(host_port).groups()
             if auth and normalize_uri:
                 auth = _encode_invalid_chars(auth, USERINFO_CHARS)
             if port == "":
diff --git a/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py b/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py
index c280646c..21b4590b 100644
--- a/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py
+++ b/env/Lib/site-packages/pip/_vendor/urllib3/util/wait.py
@@ -42,7 +42,6 @@ if sys.version_info >= (3, 5):
     def _retry_on_intr(fn, timeout):
         return fn(timeout)
 
-
 else:
     # Old and broken Pythons.
     def _retry_on_intr(fn, timeout):
diff --git a/env/Lib/site-packages/pip/_vendor/vendor.txt b/env/Lib/site-packages/pip/_vendor/vendor.txt
index 6c9732e9..4ab2915f 100644
--- a/env/Lib/site-packages/pip/_vendor/vendor.txt
+++ b/env/Lib/site-packages/pip/_vendor/vendor.txt
@@ -1,22 +1,23 @@
-appdirs==1.4.4
-CacheControl==0.12.6
-colorama==0.4.4
-distlib==0.3.1
-distro==1.5.0
-html5lib==1.1
-msgpack==1.0.2
-packaging==20.9
-pep517==0.10.0
-progress==1.5
-pyparsing==2.4.7
-requests==2.25.1
-    certifi==2020.12.05
-    chardet==4.0.0
-    idna==3.1
-    urllib3==1.26.4
-resolvelib==0.7.0
-setuptools==44.0.0
-six==1.15.0
-tenacity==7.0.0
-toml==0.10.2
+CacheControl==0.12.11  # Make sure to update the license in pyproject.toml for this.
+colorama==0.4.6
+distlib==0.3.6
+distro==1.8.0
+msgpack==1.0.5
+packaging==21.3
+platformdirs==3.8.1
+pyparsing==3.1.0
+pyproject-hooks==1.0.0
+requests==2.31.0
+    certifi==2023.5.7
+    chardet==5.1.0
+    idna==3.4
+    urllib3==1.26.16
+rich==13.4.2
+    pygments==2.15.1
+    typing_extensions==4.7.1
+resolvelib==1.0.1
+setuptools==68.0.0
+six==1.16.0
+tenacity==8.2.2
+tomli==2.0.1
 webencodings==0.5.1
diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/__init__.cpython-39.pyc
deleted file mode 100644
index fcdd9887065062532204f48c133c95c606a5caed..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 9751
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
TVjSFjd|Wad3VZ?_Tmr@b_<Ae)

diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/labels.cpython-39.pyc
deleted file mode 100644
index 73c17f1c89e2d66c3a7e254eef7bd576669cab77..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 3865
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
Xj49s0$iToNz{EHThe!xCFsuRqg|HFv

diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/mklabels.cpython-39.pyc
deleted file mode 100644
index df8605f830f49418442d79feebbf5d5abfdd9974..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 1935
zcmYe~<>g{vU|^UdaWGYqm4V?gh=Ytd7#J8F7#J9eQy3T+QW&BbQW#U1au}l+s{~RQ
zQ<!s@a+#x;85zPE^5j?;Qdugk7#TniEXN9wi)6@SGGItyNnveah+<1&OJQ$eh+<FW
zNa4t4DoRM@Ol42uY-Vg`WMoKT3TDvcsyf8QrJ$goP@bBUnwOlPl9`uYte2aelbDp6
zQw)}=!v-Llf>P5{^Ad{^OHvg|GEz~^fS90=o1apeld1<%Z<U;1P+63jo>5|@;0$9b
z7#SEEDI`@Y1ZU>v=P3jy7G&muEw;+ZOis-!PPI~S3U<*^C{9gP@bPqZ^$T`YNXsu$
zNJ%Y8%*-j)<KlV=3PV3l##`*AMLGEesd>qaAQ31Av6&ed7@R=?E5g9QP{UBeuz+D9
zLpD>ffEPm(V+}(v!%9Ywe%74)^3)<t##?N~B}JKe=_?tE*cccXeziJV#e^2878S>&
z=A>j6#rWr?x)f!Wr7Gwug!*}gxdsJ$hByW*c>1~c`?&^tI>rRM`nm>(xCSYh#RLTS
z#3Y*N=H#bm7MEmZ$E4<!#rR|<#S~|jr0NzVCTAz6rxwQ)WESYhm!;;V<QM59M}<Bt
zD)b5}Z}B7+7pE4L#DiT4@<}lZ$d8Nyj76Z7gW_wDk3nt+(Zy+?<iwcHSj(8gl)~J?
zP{Oc)v4p9Hp_y?3^FoFNEGaAt85c6TFf=pPGL^8Vu%@uJFw`)C_|1%+3^j}k*xDJ=
z7*p6&*jhLs;tLrWLE`Kw93WN-=K_uz#)XWa1m%|~%*eo?q@)Cia%9iwLDB>`a<L>T
zhz8%p0tHw~RDftuD9Hz<ugoHayu@4@rzNn%l@%f)A{1Qm74q^+6jD<%OBA`36+$vH
zixtu`b5a#Dixm<}OY(CQOEQxab8;#b(o^$NLAf9Wl#G#LjEl?1(aF^(Six4InhPa*
zKoJLuvtUr7^kHCNNN1>Fh;^xDtYJ)HkYsRSh&8Kas$oiD1hX}2nM)W-7;Bh8Id=h5
z3e!Ty5{4S46lO_K6oUC_OcPlOWeNofS%MifS#EK{g0T1&8zc~KF_zw90fnC?^DUO5
z)Pf>#nz_Z614`-znk=`N^bBrsBqx@nrso$`-r|56aEleJADj^&1Umx*!!0hGoXp~q
z<ow(MI~|Z8co-NM*qE6Zc^G;A2rvr#uabcUik?kQesW??v7H`5%PrQ#;^fRslpq16
zR1hu(87BqKr?EmYOtqji$xy@C%oxVN$WX|X!Vt_*1X8z>@fLGVYTiobB7O!2h9V&l
z0dfVzk)X6+1a>K>4ag-G1x0p73=9mPK{=*M8YBdYF(k)<gg~k=90fAP8009BM{5{j
zRUnQ^VW?qDVeDWi0Xt5DL4=`(DUDf-0qRUp>B?Ni2P#`ti>*|P6;z9LxPCDz_!WtQ
zTq@4Mz_60>7JF`DMSM<b9>mcgn~EeD7#P6Tfzk*I6Wjk=jJ3BIG&ygvWEJP<-D1tj
zPfRH;Vgf}1OHpcK$}P5()a3k>)LYECi50ilQY%VQ^HOfHB^DHbXqK$}%sfrzTg;_J
zIk#8~5{pWTi$IkS#6oG1Q$V)f;sALc6e5x!pMnY(21Yg^HfFKEY-~b|d`wLLIGDK@
zi!?#ja>U2yCT8Zv$5-iPl#~=$>FdK1i(YX-YO-E=Mq){Mx?X-!I$WYy59D}Fu3PN!
z@hSPq@$p6SAd}cii*j-@lOVp~_RKBFFDh{@D#|aq#RrkmD@rXaO)V|~Csw%apky2$
xe~Y!CC^N4F;uCOug9(UtY#<en9jNp#2Bi%a9u7t(Mgc}1Mj>VnRt`lDMgV5O_bmVb

diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/tests.cpython-39.pyc
deleted file mode 100644
index 5ea0109cb3369e363f18fd05d2eb7e5182b97e17..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 5099
zcmYe~<>g{vU|^UdaWHkUBm=`^5C<7EF)%PVFfcF_cQ7z8q%cG=q%fv1<uK+lMKLil
zq%fzj<S^&5M6u+uMzQ9yMX}|wN3rK}L~-PDMsenHMRDbFM{(!!MDZ{(q_C#2wJ=2S
zrm&}Qv@k^RrEsQjwJ=2Sr*Nn6v@k>or0}NjwJ<~prtqf-v@k>or3j`7wJ<~prwFHr
zv@k@8q==@7wJ=19riceKXi8LV;^I<JP*5mOO-jv6&QHnAOE1<dNi8lZ1`F3=0Elu&
zg`~vd%wz?SN`>Om%#u`vwEQ9kSEvzs5LH&m`303lnduoNRtnBArh<`yp^-vTr9yCK
zZhoFZaAHAb9@s9coXq6Zyy8?V1*c#a9fji5R0SVTXIH;qSFqVBsU?Y-ImLQhTrWZ4
zs>ygupfoQtIX@*eJ}0vzwJ0&C_$4C)1A`{#Ew-He{Or<#TWmg#POd(|x7borLF#U?
zfxVb|iyNdq9x4doKxKqH^OB2Fb5rw55_4R@nu=~Ai-A3uT6BvgG{ns!85E}=w}3DU
z0|NsG0|SFUD2^={7#OOAY8Y#nG8t-^moWA*GBSiS<cY8_)G$=4F*1N)Btr^AFoOX@
z2}25F4TBg%Gh-7YNJNv#uS(D*GesdUzeJ%ZF|#;TLA6*<lkpaxV{vh6QAuWgo@-H2
zevu~2EzZ=6<kSL?$Ssbv(!69aizTrrz4#Veb~%V%$xtN3z`*dU$=NC<v^ce>I3_hG
zC9^2TKQGm#D6=e8L02Kv&oj(5DA+T^F<8OV&&A)*HQ3WJCfL>2H8{jINWm;7AiyUk
z(L^^VKRvU!Br`iEHLonjCo?IgII|>Gw;(Y&J25@AIHn-8KtH}LH7_N<NFO;d>4TC;
zv0g#tE#5@1`{TiWDi#5S6FAE-GBFA<@-T8R6@kQ(L4k>kL4oWHQq05101m8X#w^AZ
z#%!iyAuom|#uA1UCb)<SRD>BWVg?mqfs1%xh(tj}SmA1NpdxH=kvgaddoyDSLn%XX
zAC%7l<<EoiIl(%(vYCoEKt;IWB8Q+NJaCaKP!V3Z$TO%2AJp7$P(D9|KY_8B10(`Y
zC<1;}tfeJsx)xQep-?KsP1oWUOKC}(1z5^Lp^8I+mkY$_yv0;%QOeH1zyQ{AXh9W6
zXt1thu(PLU6;F9)UP^v>v96(!sZkYIW^ul*g@vi5uHh}VoWzpMJi{n9AIA_+Kf@|^
zFkjaYY><y*$dL_xhMG)8pu~TRB`+~I6`b6V2w?^WhFjdAG!UPYn3S4REDMTCIZy;M
z3ZXy&Mgb<6hyY`eBm)BjN?HIposEHk0h|^%z-hsSA@)`+LkS}&12r?HFqJUXFf=o!
zF=aCqD}h3(ggFHy!URq&CLoa%W*3H7ms-XWmK4Tx#u`Quh8l)urWmGLrds9_)*7Z}
z#&m{krs4#U+7i|hwiG6WDyW<VNUqSLgdJp8ElUl{0>%`^g^Vd6TW5geYFI$&GleCE
zwU-Gjx(*~-!U0y#TEn`4IfZE<Bn6)U$<(lBF{dy=)q~PC3rMt(rG&GDVFA}dhGs?=
zhFGy$wi2cqP<rI9VasMJegjtX2AmGq{62%i^A>|9a}lTnEMjJ0V0g*Hz`ziq$#{!3
zEi*4MN0X<Bm4Shw2o!?g=qdt*XA!8xy2X-{SzJ=Y36ch7$Rch~oG}-tmfT`1OUx-v
zEiRG(m8<NxSiw<vi>)ZNAT_b%7F&L4NkM7JEynm;?2y8==oUMqAT0uGK~D$#;B=6f
zlLJi)28gu4!6?Nj#K^%Y!YIHf$H>7b#3%+PC71*li`3E60?4}{?|{=n2m`2GC}AvN
z0#&KaEQ|~#3?+;u%qh$%OmH4cI;fn0$+4pF*ix99nW4JaA#8BCviN-lS@M4O{=+M8
zv1jI$CFW$Nd<B(9hgWKHfJ>`e+&<u{23#UT0v8^xXd#Le7@#7#2%Iy7z##%P8WJjC
zKY=2Tfsqdic^Hdyumu4q+kusD17`=Y_nA_dOBg{#A~+jJfszTRhJlDRqsoGlatQ+{
z=`}N@u$3^TutKv>5L6#a2@{$OtY~COVQ*$i;V5BDVTbBzgX-Y~%OIP!04l=;m*Ix$
z*#(v1fy?khWne`kA6SOJgfRuC=N(j!09*#DX98m}7gSC#MF{F{sICc&#cEJF;S>?5
z973NHTuu~2E)FgSG84%q6BvuDpmKs>GeL3)GpE7jKxU%KZ34-G6PcLbXHcGPC=v%1
z&7hq7sA<h-NFpl|1?5RCP<CWZEKbhM{0fTk!_9|Q7HKdrFnk8_{{3fo`HKTorW=|i
zrGkb2|9i;*6Us>~hNybUPzo~q-I4~d!2f>?FTu7jysY8~4RO;oG;?wV3%q223HZ2H
zu|cFXnIUN#WK<C-ZDLK#kYXNE68M0!wgM=hGD<PZF-k!o6NHvwl3|o#gpft%*itsg
zso<1d0M6X7l#NvBGp4XKGo`R*GZn)seS`?C(q~LzYi3Ge&t@uyRr-u698eKhrO%kc
z+02vzs<6Q+8yqLxenp@_2S*7wc3whaLJ!oGVuOTrkr^m%OhAMYh%f~ek&KX16`a2j
z1URQd0tZq$CV>J66pRc=HDHkydO(2E1w0@s7#YA_h8Bieh8l)+h7{&zrWBTJrebgw
zuVF}GO=pCQ>4B104MPeWR16dZ;3Qtdkir2K<IH9%4uh)WO5sjt0_z5ef&-$4A%!P}
z7fG}Us+JF`pFf+a7@Wjw7*YhFVjz1~LDZ!)qzEp8xCkVA04^#76&22AD!v966@iL^
z)Pn1_8io{6sHrU3OcNN3nILLY#Gs<$U{MLEs037$9V`m-za)yN3q)-?Ly8o_wh4^I
zF>rC|MT{vj%}gn>U{gv!;@|`!=ZDeO2SrRUC>}v|V+lhILk%OWA(6tkfU$;YA!9Iu
zCX-*0G$>&(L2KHq{LDN}mRqcud7z3@FfB1BCn+&GJ06@aGV{`lltG!D6TwGIMWRSO
zm-v$W_~MeH%)Im*kUKzm6I5kXfm_`1NDB3Aa`KZCbBgWskOUFB!O0x#%pxgJN(Oaa
z!0EpjRQqM5=H%o@v4W{$P_dMe`WfW+oSb}cK?0Hh=aKv(Q1&PS)#>2UNs}3@?)~ol
zVClnPa-}A7krSxs0;TQ5B2X4D1vxzN{r<h0Y+(Dr>fVEyV4@gg+wT2`i(EjC18D|3
z<Na>1#>49m?JhC|$ryve8OezMVBKH>tl{5Fu*slC63Cliv5c2Rpg#F8z6#ya;?yGD
zl+?7$ywntM>o(*4{FOO5`QVaHld;GiWCvPo2taD@lGGw-XEGZU5ul=vfsun*h*1O#
z#TdoFGzTNoe<ntz{~S!%SRhp(43p!6t19wBFBm|@DkyG1!B>0-G@ih?fT4sD+^B&y
zEx{Qh1uUMzoDOOcz+{ZT$r>WV0+#`mq&^6lbcPhRMKE0;xeN?B_GXZY9NA38Ef{i~
za5-?@4{-<7OfIk-cQ#Y;9u$2%ix^XQ!E$`rOvN|Aaty%?n*4s?NJL7e;KCV{Of^{`
z=@u*i%4iU-B`B`2mCq36;DiH;Ua;yYW>749f?^I7rWr4Da`H8qimX9qfZN1~NC&gP
zr8!c}gR^dGJ4ipMC}3ce0M~Wk8jewhk%y7#KMNz%{~~YnSOjGzP}&E_A}ATAFxE1p
zFx4`qFxN7qu+%bwN|hAWW~LfOq?VZ$C|pXIYCvr@rW#OZ#Ren-E~eQ0iUk-L7>smy
zxTXAWDxc;*xx3{2ic_Va?iNJw{rs8A@8@^(zn|ave%|hq_w)PT&s*_+eit}5Bql~N
zB_<Yuf&!(&2eoK5nP5%(6j)<F1)Mb?1UOKH!P%iA9+Z{hp;>7%C|n>_9Sb7_N--As
zF)%RrX^P!qkB?8uPmYhj#T6f)R$5Y8lo}sj1PT{$%s~1nph$tVK0xjOm!s${YmoWi
z<~X?52<|R`8_eLg1-M=X=OJ(ufbE7j8XTQq0_=Pao80`A(wtN~kOPXv7#J8>czBp}
VSU5O2ggJycI61^PI5}iEcmSJql8gWV

diff --git a/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc b/env/Lib/site-packages/pip/_vendor/webencodings/__pycache__/x_user_defined.cpython-39.pyc
deleted file mode 100644
index 674582f58a3b1ead98ea0a0d25e86af1322b89e3..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 2695
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
DxG5GX

diff --git a/env/Lib/site-packages/pip/py.typed b/env/Lib/site-packages/pip/py.typed
index 0b44fd9b..493b53e4 100644
--- a/env/Lib/site-packages/pip/py.typed
+++ b/env/Lib/site-packages/pip/py.typed
@@ -1,4 +1,4 @@
 pip is a command line program. While it is implemented in Python, and so is
 available for import, you must not use pip's internal APIs in this way. Typing
-information is provided as a convenience only and is not a gaurantee. Expect
+information is provided as a convenience only and is not a guarantee. Expect
 unannounced changes to the API and types in releases.
diff --git a/env/Scripts/Activate.ps1 b/env/Scripts/Activate.ps1
index e06da144..e4891d86 100644
--- a/env/Scripts/Activate.ps1
+++ b/env/Scripts/Activate.ps1
@@ -96,6 +96,11 @@ function global:deactivate ([switch]$NonDestructive) {
         Remove-Item -Path env:VIRTUAL_ENV
     }
 
+    # Just remove VIRTUAL_ENV_PROMPT altogether.
+    if (Test-Path -Path Env:VIRTUAL_ENV_PROMPT) {
+        Remove-Item -Path env:VIRTUAL_ENV_PROMPT
+    }
+
     # Just remove the _PYTHON_VENV_PROMPT_PREFIX altogether:
     if (Get-Variable -Name "_PYTHON_VENV_PROMPT_PREFIX" -ErrorAction SilentlyContinue) {
         Remove-Variable -Name _PYTHON_VENV_PROMPT_PREFIX -Scope Global -Force
@@ -197,7 +202,7 @@ else {
         $Prompt = $pyvenvCfg['prompt'];
     }
     else {
-        Write-Verbose "  Setting prompt based on parent's directory's name. (Is the directory name passed to venv module when creating the virutal environment)"
+        Write-Verbose "  Setting prompt based on parent's directory's name. (Is the directory name passed to venv module when creating the virtual environment)"
         Write-Verbose "  Got leaf-name of $VenvDir='$(Split-Path -Path $venvDir -Leaf)'"
         $Prompt = Split-Path -Path $venvDir -Leaf
     }
@@ -228,6 +233,7 @@ if (-not $Env:VIRTUAL_ENV_DISABLE_PROMPT) {
         Write-Host -NoNewline -ForegroundColor Green "($_PYTHON_VENV_PROMPT_PREFIX) "
         _OLD_VIRTUAL_PROMPT
     }
+    $env:VIRTUAL_ENV_PROMPT = $Prompt
 }
 
 # Clear PYTHONHOME
@@ -241,159 +247,256 @@ Copy-Item -Path Env:PATH -Destination Env:_OLD_VIRTUAL_PATH
 $Env:PATH = "$VenvExecDir$([System.IO.Path]::PathSeparator)$Env:PATH"
 
 # SIG # Begin signature block
-# MIIc+AYJKoZIhvcNAQcCoIIc6TCCHOUCAQExDzANBglghkgBZQMEAgEFADB5Bgor
+# MIIvJAYJKoZIhvcNAQcCoIIvFTCCLxECAQExDzANBglghkgBZQMEAgEFADB5Bgor
 # BgEEAYI3AgEEoGswaTA0BgorBgEEAYI3AgEeMCYCAwEAAAQQH8w7YFlLCE63JNLG
-# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCAwnDYwEHaCQq0n
-# 8NAvsN7H7BO7/48rXCNwrg891FS5vaCCC38wggUwMIIEGKADAgECAhAECRgbX9W7
-# ZnVTQ7VvlVAIMA0GCSqGSIb3DQEBCwUAMGUxCzAJBgNVBAYTAlVTMRUwEwYDVQQK
-# EwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xJDAiBgNV
-# BAMTG0RpZ2lDZXJ0IEFzc3VyZWQgSUQgUm9vdCBDQTAeFw0xMzEwMjIxMjAwMDBa
-# Fw0yODEwMjIxMjAwMDBaMHIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2Vy
-# dCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xMTAvBgNVBAMTKERpZ2lD
-# ZXJ0IFNIQTIgQXNzdXJlZCBJRCBDb2RlIFNpZ25pbmcgQ0EwggEiMA0GCSqGSIb3
-# DQEBAQUAA4IBDwAwggEKAoIBAQD407Mcfw4Rr2d3B9MLMUkZz9D7RZmxOttE9X/l
-# qJ3bMtdx6nadBS63j/qSQ8Cl+YnUNxnXtqrwnIal2CWsDnkoOn7p0WfTxvspJ8fT
-# eyOU5JEjlpB3gvmhhCNmElQzUHSxKCa7JGnCwlLyFGeKiUXULaGj6YgsIJWuHEqH
-# CN8M9eJNYBi+qsSyrnAxZjNxPqxwoqvOf+l8y5Kh5TsxHM/q8grkV7tKtel05iv+
-# bMt+dDk2DZDv5LVOpKnqagqrhPOsZ061xPeM0SAlI+sIZD5SlsHyDxL0xY4PwaLo
-# LFH3c7y9hbFig3NBggfkOItqcyDQD2RzPJ6fpjOp/RnfJZPRAgMBAAGjggHNMIIB
-# yTASBgNVHRMBAf8ECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUEDDAK
-# BggrBgEFBQcDAzB5BggrBgEFBQcBAQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6Ly9v
-# Y3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3aHR0cDovL2NhY2VydHMuZGln
-# aWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNydDCBgQYDVR0fBHow
-# eDA6oDigNoY0aHR0cDovL2NybDQuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJl
-# ZElEUm9vdENBLmNybDA6oDigNoY0aHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0Rp
-# Z2lDZXJ0QXNzdXJlZElEUm9vdENBLmNybDBPBgNVHSAESDBGMDgGCmCGSAGG/WwA
-# AgQwKjAoBggrBgEFBQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzAK
-# BghghkgBhv1sAzAdBgNVHQ4EFgQUWsS5eyoKo6XqcQPAYPkt9mV1DlgwHwYDVR0j
-# BBgwFoAUReuir/SSy4IxLVGLp6chnfNtyA8wDQYJKoZIhvcNAQELBQADggEBAD7s
-# DVoks/Mi0RXILHwlKXaoHV0cLToaxO8wYdd+C2D9wz0PxK+L/e8q3yBVN7Dh9tGS
-# dQ9RtG6ljlriXiSBThCk7j9xjmMOE0ut119EefM2FAaK95xGTlz/kLEbBw6RFfu6
-# r7VRwo0kriTGxycqoSkoGjpxKAI8LpGjwCUR4pwUR6F6aGivm6dcIFzZcbEMj7uo
-# +MUSaJ/PQMtARKUT8OZkDCUIQjKyNookAv4vcn4c10lFluhZHen6dGRrsutmQ9qz
-# sIzV6Q3d9gEgzpkxYz0IGhizgZtPxpMQBvwHgfqL2vmCSfdibqFT+hKUGIUukpHq
-# aGxEMrJmoecYpJpkUe8wggZHMIIFL6ADAgECAhADPtXtoGXRuMkd/PkqbJvYMA0G
-# CSqGSIb3DQEBCwUAMHIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ
-# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xMTAvBgNVBAMTKERpZ2lDZXJ0
-# IFNIQTIgQXNzdXJlZCBJRCBDb2RlIFNpZ25pbmcgQ0EwHhcNMTgxMjE4MDAwMDAw
-# WhcNMjExMjIyMTIwMDAwWjCBgzELMAkGA1UEBhMCVVMxFjAUBgNVBAgTDU5ldyBI
-# YW1wc2hpcmUxEjAQBgNVBAcTCVdvbGZlYm9ybzEjMCEGA1UEChMaUHl0aG9uIFNv
-# ZnR3YXJlIEZvdW5kYXRpb24xIzAhBgNVBAMTGlB5dGhvbiBTb2Z0d2FyZSBGb3Vu
-# ZGF0aW9uMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAqr2kS7J1uW7o
-# JRxlsdrETAjKarfoH5TI8PWST6Yb2xPooP7vHT4iaVXyL5Lze1f53Jw67Sp+u524
-# fJXf30qHViEWxumy2RWG0nciU2d+mMqzjlaAWSZNF0u4RcvyDJokEV0RUOqI5CG5
-# zPI3W9uQ6LiUk3HCYW6kpH177A5T3pw/Po8O8KErJGn1anaqtIICq99ySxrMad/2
-# hPMBRf6Ndah7f7HPn1gkSSTAoejyuqF5h+B0qI4+JK5+VLvz659VTbAWJsYakkxZ
-# xVWYpFv4KeQSSwoo0DzMvmERsTzNvVBMWhu9OriJNg+QfFmf96zVTu93cZ+r7xMp
-# bXyfIOGKhHMaRuZ8ihuWIx3gI9WHDFX6fBKR8+HlhdkaiBEWIsXRoy+EQUyK7zUs
-# +FqOo2sRYttbs8MTF9YDKFZwyPjn9Wn+gLGd5NUEVyNvD9QVGBEtN7vx87bduJUB
-# 8F4DylEsMtZTfjw/au6AmOnmneK5UcqSJuwRyZaGNk7y3qj06utx+HTTqHgi975U
-# pxfyrwAqkovoZEWBVSpvku8PVhkBXcLmNe6MEHlFiaMoiADAeKmX5RFRkN+VrmYG
-# Tg4zajxfdHeIY8TvLf48tTfmnQJd98geJQv/01NUy/FxuwqAuTkaez5Nl1LxP0Cp
-# THhghzO4FRD4itT2wqTh4jpojw9QZnsCAwEAAaOCAcUwggHBMB8GA1UdIwQYMBaA
-# FFrEuXsqCqOl6nEDwGD5LfZldQ5YMB0GA1UdDgQWBBT8Kr9+1L6s84KcpM97IgE7
-# uI8H8jAOBgNVHQ8BAf8EBAMCB4AwEwYDVR0lBAwwCgYIKwYBBQUHAwMwdwYDVR0f
-# BHAwbjA1oDOgMYYvaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL3NoYTItYXNzdXJl
-# ZC1jcy1nMS5jcmwwNaAzoDGGL2h0dHA6Ly9jcmw0LmRpZ2ljZXJ0LmNvbS9zaGEy
-# LWFzc3VyZWQtY3MtZzEuY3JsMEwGA1UdIARFMEMwNwYJYIZIAYb9bAMBMCowKAYI
-# KwYBBQUHAgEWHGh0dHBzOi8vd3d3LmRpZ2ljZXJ0LmNvbS9DUFMwCAYGZ4EMAQQB
-# MIGEBggrBgEFBQcBAQR4MHYwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2lj
-# ZXJ0LmNvbTBOBggrBgEFBQcwAoZCaHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29t
-# L0RpZ2lDZXJ0U0hBMkFzc3VyZWRJRENvZGVTaWduaW5nQ0EuY3J0MAwGA1UdEwEB
-# /wQCMAAwDQYJKoZIhvcNAQELBQADggEBAEt1oS21X0axiafPjyY+vlYqjWKuUu/Y
-# FuYWIEq6iRRaFabNDhj9RBFQF/aJiE5msrQEOfAD6/6gVSH91lZWBqg6NEeG9T9S
-# XbiAPvJ9CEWFsdkXUrjbWhvCnuZ7kqUuU5BAumI1QRbpYgZL3UA+iZXkmjbGh1ln
-# 8rUhWIxbBYL4Sg2nqpB44p7CUFYkPj/MbwU2gvBV2pXjj5WaskoZtsACMv5g42BN
-# oVLoRAi+ev6s07POt+JtHRIm87lTyuc8wh0swTPUwksKbLU1Zdj9CpqtzXnuVE0w
-# 50exJvRSK3Vt4g+0vigpI3qPmDdpkf9+4Mvy0XMNcqrthw20R+PkIlMxghDPMIIQ
-# ywIBATCBhjByMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkw
-# FwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYDVQQDEyhEaWdpQ2VydCBTSEEy
-# IEFzc3VyZWQgSUQgQ29kZSBTaWduaW5nIENBAhADPtXtoGXRuMkd/PkqbJvYMA0G
-# CWCGSAFlAwQCAQUAoIGYMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisG
-# AQQBgjcCAQsxDjAMBgorBgEEAYI3AgEVMCwGCisGAQQBgjcCAQwxHjAcoBqAGABQ
-# AHkAdABoAG8AbgAgADMALgA5AC4ANjAvBgkqhkiG9w0BCQQxIgQgBrni4mcRv7sM
-# JHsxpROjRopOz2wuQVrJnn+lD7X7y+gwDQYJKoZIhvcNAQEBBQAEggIAKBxtIIh2
-# APcTqLi9A0nTuTBMVUsNOQNQzSI9fW92jLmXUh0OGygpOMC9GiVVRnHNGmCWt9FV
-# pMkolylPuI7wj08VFv5xvsnWo9EKM2+M0zZ1fN+/zNDvrRPKmhUTQ/fGIP9OWF3x
-# qbUCGSXrzVf/wSvYmhdBXa7pTrivIx8JOS8fhK5dqSiCmtJOPQ45ZEFNzfgB5i9e
-# 9lfNQ0wXKfKHo2zdqS19VEbuIUN8GjSlos7rGHP20aMjb0ZgKWBkYHHm4yNAgJCU
-# AJ8K+mL2+KRJDyxwH1oFjgkFKAvEHMVo8by3TigZIxmIkNlYBYx3oh7S3wgKKtNf
-# wZqX6/iDYOBmj49CxOEfoN4jtg5kg1slzbham+EPAE2pkNmg+RMkF0j9lJ5KTWrt
-# tUZvWJI17UQV0bRlbp4bYiI7OxGDD3LNU1iQo69J3q8rFc+yyplD7lJzKb7h/mH/
-# oMBa6TVHNBuSBSMGLN6xOoshcwWMo0hhfdOqyjFNgdMHO8cEwXGhwJFPimXXt+NW
-# KeKaW9i7dSzt1uNnqNXqXauk5A4upOxLceMFhmnoUwcsyxRxSFrti+uyUVMXOs1a
-# Q8YyQZFfjy5CeOjq7ohDbBRarX5JwJrkB/BYya6TA9SKfRYwIxfiwYFf6yGLrjAy
-# E0Qjhz5Np39AYpfcaWk31MeLse8NVtgVPPmhgg1+MIINegYKKwYBBAGCNwMDATGC
-# DWowgg1mBgkqhkiG9w0BBwKggg1XMIINUwIBAzEPMA0GCWCGSAFlAwQCAQUAMHgG
-# CyqGSIb3DQEJEAEEoGkEZzBlAgEBBglghkgBhv1sBwEwMTANBglghkgBZQMEAgEF
-# AAQgUVAItwy7RQCrM4tGC7KCANd0O7DgaULOpzirVGSU8QMCEQDLPomRSCQZjdG/
-# GAILYuAXGA8yMDIxMDYyODE1MzMxNVqgggo3MIIE/jCCA+agAwIBAgIQDUJK4L46
-# iP9gQCHOFADw3TANBgkqhkiG9w0BAQsFADByMQswCQYDVQQGEwJVUzEVMBMGA1UE
-# ChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYD
-# VQQDEyhEaWdpQ2VydCBTSEEyIEFzc3VyZWQgSUQgVGltZXN0YW1waW5nIENBMB4X
-# DTIxMDEwMTAwMDAwMFoXDTMxMDEwNjAwMDAwMFowSDELMAkGA1UEBhMCVVMxFzAV
-# BgNVBAoTDkRpZ2lDZXJ0LCBJbmMuMSAwHgYDVQQDExdEaWdpQ2VydCBUaW1lc3Rh
-# bXAgMjAyMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMLmYYRnxYr1
-# DQikRcpja1HXOhFCvQp1dU2UtAxQtSYQ/h3Ib5FrDJbnGlxI70Tlv5thzRWRYlq4
-# /2cLnGP9NmqB+in43Stwhd4CGPN4bbx9+cdtCT2+anaH6Yq9+IRdHnbJ5MZ2djpT
-# 0dHTWjaPxqPhLxs6t2HWc+xObTOKfF1FLUuxUOZBOjdWhtyTI433UCXoZObd048v
-# V7WHIOsOjizVI9r0TXhG4wODMSlKXAwxikqMiMX3MFr5FK8VX2xDSQn9JiNT9o1j
-# 6BqrW7EdMMKbaYK02/xWVLwfoYervnpbCiAvSwnJlaeNsvrWY4tOpXIc7p96AXP4
-# Gdb+DUmEvQECAwEAAaOCAbgwggG0MA4GA1UdDwEB/wQEAwIHgDAMBgNVHRMBAf8E
-# AjAAMBYGA1UdJQEB/wQMMAoGCCsGAQUFBwMIMEEGA1UdIAQ6MDgwNgYJYIZIAYb9
-# bAcBMCkwJwYIKwYBBQUHAgEWG2h0dHA6Ly93d3cuZGlnaWNlcnQuY29tL0NQUzAf
-# BgNVHSMEGDAWgBT0tuEgHf4prtLkYaWyoiWyyBc1bjAdBgNVHQ4EFgQUNkSGjqS6
-# sGa+vCgtHUQ23eNqerwwcQYDVR0fBGowaDAyoDCgLoYsaHR0cDovL2NybDMuZGln
-# aWNlcnQuY29tL3NoYTItYXNzdXJlZC10cy5jcmwwMqAwoC6GLGh0dHA6Ly9jcmw0
-# LmRpZ2ljZXJ0LmNvbS9zaGEyLWFzc3VyZWQtdHMuY3JsMIGFBggrBgEFBQcBAQR5
-# MHcwJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBPBggrBgEF
-# BQcwAoZDaHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0U0hBMkFz
-# c3VyZWRJRFRpbWVzdGFtcGluZ0NBLmNydDANBgkqhkiG9w0BAQsFAAOCAQEASBzc
-# temaI7znGucgDo5nRv1CclF0CiNHo6uS0iXEcFm+FKDlJ4GlTRQVGQd58NEEw4bZ
-# O73+RAJmTe1ppA/2uHDPYuj1UUp4eTZ6J7fz51Kfk6ftQ55757TdQSKJ+4eiRgNO
-# /PT+t2R3Y18jUmmDgvoaU+2QzI2hF3MN9PNlOXBL85zWenvaDLw9MtAby/Vh/HUI
-# AHa8gQ74wOFcz8QRcucbZEnYIpp1FUL1LTI4gdr0YKK6tFL7XOBhJCVPst/JKahz
-# Q1HavWPWH1ub9y4bTxMd90oNcX6Xt/Q/hOvB46NJofrOp79Wz7pZdmGJX36ntI5n
-# ePk2mOHLKNpbh6aKLzCCBTEwggQZoAMCAQICEAqhJdbWMht+QeQF2jaXwhUwDQYJ
-# KoZIhvcNAQELBQAwZTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IElu
+# KX7zUQIBAAIBAAIBAAIBAAIBADAxMA0GCWCGSAFlAwQCAQUABCBnL745ElCYk8vk
+# dBtMuQhLeWJ3ZGfzKW4DHCYzAn+QB6CCE8MwggWQMIIDeKADAgECAhAFmxtXno4h
+# MuI5B72nd3VcMA0GCSqGSIb3DQEBDAUAMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQK
+# EwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNV
+# BAMTGERpZ2lDZXJ0IFRydXN0ZWQgUm9vdCBHNDAeFw0xMzA4MDExMjAwMDBaFw0z
+# ODAxMTUxMjAwMDBaMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ
+# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNVBAMTGERpZ2lDZXJ0
+# IFRydXN0ZWQgUm9vdCBHNDCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIB
+# AL/mkHNo3rvkXUo8MCIwaTPswqclLskhPfKK2FnC4SmnPVirdprNrnsbhA3EMB/z
+# G6Q4FutWxpdtHauyefLKEdLkX9YFPFIPUh/GnhWlfr6fqVcWWVVyr2iTcMKyunWZ
+# anMylNEQRBAu34LzB4TmdDttceItDBvuINXJIB1jKS3O7F5OyJP4IWGbNOsFxl7s
+# Wxq868nPzaw0QF+xembud8hIqGZXV59UWI4MK7dPpzDZVu7Ke13jrclPXuU15zHL
+# 2pNe3I6PgNq2kZhAkHnDeMe2scS1ahg4AxCN2NQ3pC4FfYj1gj4QkXCrVYJBMtfb
+# BHMqbpEBfCFM1LyuGwN1XXhm2ToxRJozQL8I11pJpMLmqaBn3aQnvKFPObURWBf3
+# JFxGj2T3wWmIdph2PVldQnaHiZdpekjw4KISG2aadMreSx7nDmOu5tTvkpI6nj3c
+# AORFJYm2mkQZK37AlLTSYW3rM9nF30sEAMx9HJXDj/chsrIRt7t/8tWMcCxBYKqx
+# YxhElRp2Yn72gLD76GSmM9GJB+G9t+ZDpBi4pncB4Q+UDCEdslQpJYls5Q5SUUd0
+# viastkF13nqsX40/ybzTQRESW+UQUOsxxcpyFiIJ33xMdT9j7CFfxCBRa2+xq4aL
+# T8LWRV+dIPyhHsXAj6KxfgommfXkaS+YHS312amyHeUbAgMBAAGjQjBAMA8GA1Ud
+# EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgGGMB0GA1UdDgQWBBTs1+OC0nFdZEzf
+# Lmc/57qYrhwPTzANBgkqhkiG9w0BAQwFAAOCAgEAu2HZfalsvhfEkRvDoaIAjeNk
+# aA9Wz3eucPn9mkqZucl4XAwMX+TmFClWCzZJXURj4K2clhhmGyMNPXnpbWvWVPjS
+# PMFDQK4dUPVS/JA7u5iZaWvHwaeoaKQn3J35J64whbn2Z006Po9ZOSJTROvIXQPK
+# 7VB6fWIhCoDIc2bRoAVgX+iltKevqPdtNZx8WorWojiZ83iL9E3SIAveBO6Mm0eB
+# cg3AFDLvMFkuruBx8lbkapdvklBtlo1oepqyNhR6BvIkuQkRUNcIsbiJeoQjYUIp
+# 5aPNoiBB19GcZNnqJqGLFNdMGbJQQXE9P01wI4YMStyB0swylIQNCAmXHE/A7msg
+# dDDS4Dk0EIUhFQEI6FUy3nFJ2SgXUE3mvk3RdazQyvtBuEOlqtPDBURPLDab4vri
+# RbgjU2wGb2dVf0a1TD9uKFp5JtKkqGKX0h7i7UqLvBv9R0oN32dmfrJbQdA75PQ7
+# 9ARj6e/CVABRoIoqyc54zNXqhwQYs86vSYiv85KZtrPmYQ/ShQDnUBrkG5WdGaG5
+# nLGbsQAe79APT0JsyQq87kP6OnGlyE0mpTX9iV28hWIdMtKgK1TtmlfB2/oQzxm3
+# i0objwG2J5VT6LaJbVu8aNQj6ItRolb58KaAoNYes7wPD1N1KarqE3fk3oyBIa0H
+# EEcRrYc9B9F1vM/zZn4wggawMIIEmKADAgECAhAIrUCyYNKcTJ9ezam9k67ZMA0G
+# CSqGSIb3DQEBDAUAMGIxCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJ
+# bmMxGTAXBgNVBAsTEHd3dy5kaWdpY2VydC5jb20xITAfBgNVBAMTGERpZ2lDZXJ0
+# IFRydXN0ZWQgUm9vdCBHNDAeFw0yMTA0MjkwMDAwMDBaFw0zNjA0MjgyMzU5NTla
+# MGkxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5EaWdpQ2VydCwgSW5jLjFBMD8GA1UE
+# AxM4RGlnaUNlcnQgVHJ1c3RlZCBHNCBDb2RlIFNpZ25pbmcgUlNBNDA5NiBTSEEz
+# ODQgMjAyMSBDQTEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDVtC9C
+# 0CiteLdd1TlZG7GIQvUzjOs9gZdwxbvEhSYwn6SOaNhc9es0JAfhS0/TeEP0F9ce
+# 2vnS1WcaUk8OoVf8iJnBkcyBAz5NcCRks43iCH00fUyAVxJrQ5qZ8sU7H/Lvy0da
+# E6ZMswEgJfMQ04uy+wjwiuCdCcBlp/qYgEk1hz1RGeiQIXhFLqGfLOEYwhrMxe6T
+# SXBCMo/7xuoc82VokaJNTIIRSFJo3hC9FFdd6BgTZcV/sk+FLEikVoQ11vkunKoA
+# FdE3/hoGlMJ8yOobMubKwvSnowMOdKWvObarYBLj6Na59zHh3K3kGKDYwSNHR7Oh
+# D26jq22YBoMbt2pnLdK9RBqSEIGPsDsJ18ebMlrC/2pgVItJwZPt4bRc4G/rJvmM
+# 1bL5OBDm6s6R9b7T+2+TYTRcvJNFKIM2KmYoX7BzzosmJQayg9Rc9hUZTO1i4F4z
+# 8ujo7AqnsAMrkbI2eb73rQgedaZlzLvjSFDzd5Ea/ttQokbIYViY9XwCFjyDKK05
+# huzUtw1T0PhH5nUwjewwk3YUpltLXXRhTT8SkXbev1jLchApQfDVxW0mdmgRQRNY
+# mtwmKwH0iU1Z23jPgUo+QEdfyYFQc4UQIyFZYIpkVMHMIRroOBl8ZhzNeDhFMJlP
+# /2NPTLuqDQhTQXxYPUez+rbsjDIJAsxsPAxWEQIDAQABo4IBWTCCAVUwEgYDVR0T
+# AQH/BAgwBgEB/wIBADAdBgNVHQ4EFgQUaDfg67Y7+F8Rhvv+YXsIiGX0TkIwHwYD
+# VR0jBBgwFoAU7NfjgtJxXWRM3y5nP+e6mK4cD08wDgYDVR0PAQH/BAQDAgGGMBMG
+# A1UdJQQMMAoGCCsGAQUFBwMDMHcGCCsGAQUFBwEBBGswaTAkBggrBgEFBQcwAYYY
+# aHR0cDovL29jc3AuZGlnaWNlcnQuY29tMEEGCCsGAQUFBzAChjVodHRwOi8vY2Fj
+# ZXJ0cy5kaWdpY2VydC5jb20vRGlnaUNlcnRUcnVzdGVkUm9vdEc0LmNydDBDBgNV
+# HR8EPDA6MDigNqA0hjJodHRwOi8vY3JsMy5kaWdpY2VydC5jb20vRGlnaUNlcnRU
+# cnVzdGVkUm9vdEc0LmNybDAcBgNVHSAEFTATMAcGBWeBDAEDMAgGBmeBDAEEATAN
+# BgkqhkiG9w0BAQwFAAOCAgEAOiNEPY0Idu6PvDqZ01bgAhql+Eg08yy25nRm95Ry
+# sQDKr2wwJxMSnpBEn0v9nqN8JtU3vDpdSG2V1T9J9Ce7FoFFUP2cvbaF4HZ+N3HL
+# IvdaqpDP9ZNq4+sg0dVQeYiaiorBtr2hSBh+3NiAGhEZGM1hmYFW9snjdufE5Btf
+# Q/g+lP92OT2e1JnPSt0o618moZVYSNUa/tcnP/2Q0XaG3RywYFzzDaju4ImhvTnh
+# OE7abrs2nfvlIVNaw8rpavGiPttDuDPITzgUkpn13c5UbdldAhQfQDN8A+KVssIh
+# dXNSy0bYxDQcoqVLjc1vdjcshT8azibpGL6QB7BDf5WIIIJw8MzK7/0pNVwfiThV
+# 9zeKiwmhywvpMRr/LhlcOXHhvpynCgbWJme3kuZOX956rEnPLqR0kq3bPKSchh/j
+# wVYbKyP/j7XqiHtwa+aguv06P0WmxOgWkVKLQcBIhEuWTatEQOON8BUozu3xGFYH
+# Ki8QxAwIZDwzj64ojDzLj4gLDb879M4ee47vtevLt/B3E+bnKD+sEq6lLyJsQfmC
+# XBVmzGwOysWGw/YmMwwHS6DTBwJqakAwSEs0qFEgu60bhQjiWQ1tygVQK+pKHJ6l
+# /aCnHwZ05/LWUpD9r4VIIflXO7ScA+2GRfS0YW6/aOImYIbqyK+p/pQd52MbOoZW
+# eE4wggd3MIIFX6ADAgECAhAHHxQbizANJfMU6yMM0NHdMA0GCSqGSIb3DQEBCwUA
+# MGkxCzAJBgNVBAYTAlVTMRcwFQYDVQQKEw5EaWdpQ2VydCwgSW5jLjFBMD8GA1UE
+# AxM4RGlnaUNlcnQgVHJ1c3RlZCBHNCBDb2RlIFNpZ25pbmcgUlNBNDA5NiBTSEEz
+# ODQgMjAyMSBDQTEwHhcNMjIwMTE3MDAwMDAwWhcNMjUwMTE1MjM1OTU5WjB8MQsw
+# CQYDVQQGEwJVUzEPMA0GA1UECBMGT3JlZ29uMRIwEAYDVQQHEwlCZWF2ZXJ0b24x
+# IzAhBgNVBAoTGlB5dGhvbiBTb2Z0d2FyZSBGb3VuZGF0aW9uMSMwIQYDVQQDExpQ
+# eXRob24gU29mdHdhcmUgRm91bmRhdGlvbjCCAiIwDQYJKoZIhvcNAQEBBQADggIP
+# ADCCAgoCggIBAKgc0BTT+iKbtK6f2mr9pNMUTcAJxKdsuOiSYgDFfwhjQy89koM7
+# uP+QV/gwx8MzEt3c9tLJvDccVWQ8H7mVsk/K+X+IufBLCgUi0GGAZUegEAeRlSXx
+# xhYScr818ma8EvGIZdiSOhqjYc4KnfgfIS4RLtZSrDFG2tN16yS8skFa3IHyvWdb
+# D9PvZ4iYNAS4pjYDRjT/9uzPZ4Pan+53xZIcDgjiTwOh8VGuppxcia6a7xCyKoOA
+# GjvCyQsj5223v1/Ig7Dp9mGI+nh1E3IwmyTIIuVHyK6Lqu352diDY+iCMpk9Zanm
+# SjmB+GMVs+H/gOiofjjtf6oz0ki3rb7sQ8fTnonIL9dyGTJ0ZFYKeb6BLA66d2GA
+# LwxZhLe5WH4Np9HcyXHACkppsE6ynYjTOd7+jN1PRJahN1oERzTzEiV6nCO1M3U1
+# HbPTGyq52IMFSBM2/07WTJSbOeXjvYR7aUxK9/ZkJiacl2iZI7IWe7JKhHohqKuc
+# eQNyOzxTakLcRkzynvIrk33R9YVqtB4L6wtFxhUjvDnQg16xot2KVPdfyPAWd81w
+# tZADmrUtsZ9qG79x1hBdyOl4vUtVPECuyhCxaw+faVjumapPUnwo8ygflJJ74J+B
+# Yxf6UuD7m8yzsfXWkdv52DjL74TxzuFTLHPyARWCSCAbzn3ZIly+qIqDAgMBAAGj
+# ggIGMIICAjAfBgNVHSMEGDAWgBRoN+Drtjv4XxGG+/5hewiIZfROQjAdBgNVHQ4E
+# FgQUt/1Teh2XDuUj2WW3siYWJgkZHA8wDgYDVR0PAQH/BAQDAgeAMBMGA1UdJQQM
+# MAoGCCsGAQUFBwMDMIG1BgNVHR8Ega0wgaowU6BRoE+GTWh0dHA6Ly9jcmwzLmRp
+# Z2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNENvZGVTaWduaW5nUlNBNDA5NlNI
+# QTM4NDIwMjFDQTEuY3JsMFOgUaBPhk1odHRwOi8vY3JsNC5kaWdpY2VydC5jb20v
+# RGlnaUNlcnRUcnVzdGVkRzRDb2RlU2lnbmluZ1JTQTQwOTZTSEEzODQyMDIxQ0Ex
+# LmNybDA+BgNVHSAENzA1MDMGBmeBDAEEATApMCcGCCsGAQUFBwIBFhtodHRwOi8v
+# d3d3LmRpZ2ljZXJ0LmNvbS9DUFMwgZQGCCsGAQUFBwEBBIGHMIGEMCQGCCsGAQUF
+# BzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wXAYIKwYBBQUHMAKGUGh0dHA6
+# Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNENvZGVTaWdu
+# aW5nUlNBNDA5NlNIQTM4NDIwMjFDQTEuY3J0MAwGA1UdEwEB/wQCMAAwDQYJKoZI
+# hvcNAQELBQADggIBABxv4AeV/5ltkELHSC63fXAFYS5tadcWTiNc2rskrNLrfH1N
+# s0vgSZFoQxYBFKI159E8oQQ1SKbTEubZ/B9kmHPhprHya08+VVzxC88pOEvz68nA
+# 82oEM09584aILqYmj8Pj7h/kmZNzuEL7WiwFa/U1hX+XiWfLIJQsAHBla0i7QRF2
+# de8/VSF0XXFa2kBQ6aiTsiLyKPNbaNtbcucaUdn6vVUS5izWOXM95BSkFSKdE45O
+# q3FForNJXjBvSCpwcP36WklaHL+aHu1upIhCTUkzTHMh8b86WmjRUqbrnvdyR2yd
+# I5l1OqcMBjkpPpIV6wcc+KY/RH2xvVuuoHjlUjwq2bHiNoX+W1scCpnA8YTs2d50
+# jDHUgwUo+ciwpffH0Riq132NFmrH3r67VaN3TuBxjI8SIZM58WEDkbeoriDk3hxU
+# 8ZWV7b8AW6oyVBGfM06UgkfMb58h+tJPrFx8VI/WLq1dTqMfZOm5cuclMnUHs2uq
+# rRNtnV8UfidPBL4ZHkTcClQbCoz0UbLhkiDvIS00Dn+BBcxw/TKqVL4Oaz3bkMSs
+# M46LciTeucHY9ExRVt3zy7i149sd+F4QozPqn7FrSVHXmem3r7bjyHTxOgqxRCVa
+# 18Vtx7P/8bYSBeS+WHCKcliFCecspusCDSlnRUjZwyPdP0VHxaZg2unjHY3rMYIa
+# tzCCGrMCAQEwfTBpMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQsIElu
+# Yy4xQTA/BgNVBAMTOERpZ2lDZXJ0IFRydXN0ZWQgRzQgQ29kZSBTaWduaW5nIFJT
+# QTQwOTYgU0hBMzg0IDIwMjEgQ0ExAhAHHxQbizANJfMU6yMM0NHdMA0GCWCGSAFl
+# AwQCAQUAoIHIMBkGCSqGSIb3DQEJAzEMBgorBgEEAYI3AgEEMBwGCisGAQQBgjcC
+# AQsxDjAMBgorBgEEAYI3AgEVMC8GCSqGSIb3DQEJBDEiBCBnAZ6P7YvTwq0fbF62
+# o7E75R0LxsW5OtyYiFESQckLhjBcBgorBgEEAYI3AgEMMU4wTKBGgEQAQgB1AGkA
+# bAB0ADoAIABSAGUAbABlAGEAcwBlAF8AdgAzAC4AMQAyAC4AMABfADIAMAAyADMA
+# MQAwADAAMgAuADAAMaECgAAwDQYJKoZIhvcNAQEBBQAEggIAk+1ya4KYmJwPdyhn
+# UCoARJ3l7b9UN3AATHE7oO50+piT9AvRbtmqgY0Tper2DQmBe8FRDBu/52l6nBtc
+# 30SBrwPvs3zgvQSfhtjozpOo8bAv23MQaNbMlzW07aVBU+4Vd0v+65FwIkBiCuDk
+# CprYElSno9fsRpktxYJ9lsmdxsgyxdFg6VDzkwwp0wJBT1VVdtBNx3143gVExXE2
+# g+zSfMug1+o3Jj054gmK0BYYvg7T+qHRRjYmVvuXMLXRgY5so6vVHjv6oARFGQ9/
+# dEcY0b04c3jp/lSK+Nd0v3aY1FeguOnxPz32PHNg/ICygyRG+ivLyHkdLIJrGuIo
+# Te6dAgLgCKcooQ9MVNG2F/gw5tVCYrEOAyNwUxgl7zX7fXVlTAgAE2vxawb8NCeQ
+# f3InGRIkocO3hrEFVlCW58WG0utSkUwzknrkpMEscLEIZwO30gBartqyTajYsi4+
+# vSOTW6CQp2+CvwtDpF4ll40sxPmNbDX7KWkD/OhD8zwxvRpKrkgjIpdzlfzen9uV
+# 70E2UV2JHWVvvdqERRILOQPbSERiPPaPwjjtjWa6HwzF386We4USv+mL4AZhmxgP
+# 4ov0+c6qgVdmjUpTA8Q/RoX6WXHyhvflAsfhX/h0sBtqxhdiqoXtIH6bqAZfSpOq
+# 2GN9KZ2WSppZy2nWeULuSvSwjmahghdAMIIXPAYKKwYBBAGCNwMDATGCFywwghco
+# BgkqhkiG9w0BBwKgghcZMIIXFQIBAzEPMA0GCWCGSAFlAwQCAQUAMHgGCyqGSIb3
+# DQEJEAEEoGkEZzBlAgEBBglghkgBhv1sBwEwMTANBglghkgBZQMEAgEFAAQgnmxA
+# vhfTXC1rhKE1Olq0ip2jyhXJM2BAt3lCUFLFnQkCEQC0R5Uki33yd+oDVBKaPX6T
+# GA8yMDIzMTAwMjEzMjMzMlqgghMJMIIGwjCCBKqgAwIBAgIQBUSv85SdCDmmv9s/
+# X+VhFjANBgkqhkiG9w0BAQsFADBjMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGln
+# aUNlcnQsIEluYy4xOzA5BgNVBAMTMkRpZ2lDZXJ0IFRydXN0ZWQgRzQgUlNBNDA5
+# NiBTSEEyNTYgVGltZVN0YW1waW5nIENBMB4XDTIzMDcxNDAwMDAwMFoXDTM0MTAx
+# MzIzNTk1OVowSDELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJbmMu
+# MSAwHgYDVQQDExdEaWdpQ2VydCBUaW1lc3RhbXAgMjAyMzCCAiIwDQYJKoZIhvcN
+# AQEBBQADggIPADCCAgoCggIBAKNTRYcdg45brD5UsyPgz5/X5dLnXaEOCdwvSKOX
+# ejsqnGfcYhVYwamTEafNqrJq3RApih5iY2nTWJw1cb86l+uUUI8cIOrHmjsvlmbj
+# aedp/lvD1isgHMGXlLSlUIHyz8sHpjBoyoNC2vx/CSSUpIIa2mq62DvKXd4ZGIX7
+# ReoNYWyd/nFexAaaPPDFLnkPG2ZS48jWPl/aQ9OE9dDH9kgtXkV1lnX+3RChG4PB
+# uOZSlbVH13gpOWvgeFmX40QrStWVzu8IF+qCZE3/I+PKhu60pCFkcOvV5aDaY7Mu
+# 6QXuqvYk9R28mxyyt1/f8O52fTGZZUdVnUokL6wrl76f5P17cz4y7lI0+9S769Sg
+# LDSb495uZBkHNwGRDxy1Uc2qTGaDiGhiu7xBG3gZbeTZD+BYQfvYsSzhUa+0rRUG
+# FOpiCBPTaR58ZE2dD9/O0V6MqqtQFcmzyrzXxDtoRKOlO0L9c33u3Qr/eTQQfqZc
+# ClhMAD6FaXXHg2TWdc2PEnZWpST618RrIbroHzSYLzrqawGw9/sqhux7UjipmAmh
+# cbJsca8+uG+W1eEQE/5hRwqM/vC2x9XH3mwk8L9CgsqgcT2ckpMEtGlwJw1Pt7U2
+# 0clfCKRwo+wK8REuZODLIivK8SgTIUlRfgZm0zu++uuRONhRB8qUt+JQofM604qD
+# y0B7AgMBAAGjggGLMIIBhzAOBgNVHQ8BAf8EBAMCB4AwDAYDVR0TAQH/BAIwADAW
+# BgNVHSUBAf8EDDAKBggrBgEFBQcDCDAgBgNVHSAEGTAXMAgGBmeBDAEEAjALBglg
+# hkgBhv1sBwEwHwYDVR0jBBgwFoAUuhbZbU2FL3MpdpovdYxqII+eyG8wHQYDVR0O
+# BBYEFKW27xPn783QZKHVVqllMaPe1eNJMFoGA1UdHwRTMFEwT6BNoEuGSWh0dHA6
+# Ly9jcmwzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNFJTQTQwOTZTSEEy
+# NTZUaW1lU3RhbXBpbmdDQS5jcmwwgZAGCCsGAQUFBwEBBIGDMIGAMCQGCCsGAQUF
+# BzABhhhodHRwOi8vb2NzcC5kaWdpY2VydC5jb20wWAYIKwYBBQUHMAKGTGh0dHA6
+# Ly9jYWNlcnRzLmRpZ2ljZXJ0LmNvbS9EaWdpQ2VydFRydXN0ZWRHNFJTQTQwOTZT
+# SEEyNTZUaW1lU3RhbXBpbmdDQS5jcnQwDQYJKoZIhvcNAQELBQADggIBAIEa1t6g
+# qbWYF7xwjU+KPGic2CX/yyzkzepdIpLsjCICqbjPgKjZ5+PF7SaCinEvGN1Ott5s
+# 1+FgnCvt7T1IjrhrunxdvcJhN2hJd6PrkKoS1yeF844ektrCQDifXcigLiV4JZ0q
+# BXqEKZi2V3mP2yZWK7Dzp703DNiYdk9WuVLCtp04qYHnbUFcjGnRuSvExnvPnPp4
+# 4pMadqJpddNQ5EQSviANnqlE0PjlSXcIWiHFtM+YlRpUurm8wWkZus8W8oM3NG6w
+# QSbd3lqXTzON1I13fXVFoaVYJmoDRd7ZULVQjK9WvUzF4UbFKNOt50MAcN7MmJ4Z
+# iQPq1JE3701S88lgIcRWR+3aEUuMMsOI5ljitts++V+wQtaP4xeR0arAVeOGv6wn
+# LEHQmjNKqDbUuXKWfpd5OEhfysLcPTLfddY2Z1qJ+Panx+VPNTwAvb6cKmx5Adza
+# ROY63jg7B145WPR8czFVoIARyxQMfq68/qTreWWqaNYiyjvrmoI1VygWy2nyMpqy
+# 0tg6uLFGhmu6F/3Ed2wVbK6rr3M66ElGt9V/zLY4wNjsHPW2obhDLN9OTH0eaHDA
+# dwrUAuBcYLso/zjlUlrWrBciI0707NMX+1Br/wd3H3GXREHJuEbTbDJ8WC9nR2Xl
+# G3O2mflrLAZG70Ee8PBf4NvZrZCARK+AEEGKMIIGrjCCBJagAwIBAgIQBzY3tyRU
+# fNhHrP0oZipeWzANBgkqhkiG9w0BAQsFADBiMQswCQYDVQQGEwJVUzEVMBMGA1UE
+# ChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSEwHwYD
+# VQQDExhEaWdpQ2VydCBUcnVzdGVkIFJvb3QgRzQwHhcNMjIwMzIzMDAwMDAwWhcN
+# MzcwMzIyMjM1OTU5WjBjMQswCQYDVQQGEwJVUzEXMBUGA1UEChMORGlnaUNlcnQs
+# IEluYy4xOzA5BgNVBAMTMkRpZ2lDZXJ0IFRydXN0ZWQgRzQgUlNBNDA5NiBTSEEy
+# NTYgVGltZVN0YW1waW5nIENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKC
+# AgEAxoY1BkmzwT1ySVFVxyUDxPKRN6mXUaHW0oPRnkyibaCwzIP5WvYRoUQVQl+k
+# iPNo+n3znIkLf50fng8zH1ATCyZzlm34V6gCff1DtITaEfFzsbPuK4CEiiIY3+va
+# PcQXf6sZKz5C3GeO6lE98NZW1OcoLevTsbV15x8GZY2UKdPZ7Gnf2ZCHRgB720RB
+# idx8ald68Dd5n12sy+iEZLRS8nZH92GDGd1ftFQLIWhuNyG7QKxfst5Kfc71ORJn
+# 7w6lY2zkpsUdzTYNXNXmG6jBZHRAp8ByxbpOH7G1WE15/tePc5OsLDnipUjW8LAx
+# E6lXKZYnLvWHpo9OdhVVJnCYJn+gGkcgQ+NDY4B7dW4nJZCYOjgRs/b2nuY7W+yB
+# 3iIU2YIqx5K/oN7jPqJz+ucfWmyU8lKVEStYdEAoq3NDzt9KoRxrOMUp88qqlnNC
+# aJ+2RrOdOqPVA+C/8KI8ykLcGEh/FDTP0kyr75s9/g64ZCr6dSgkQe1CvwWcZklS
+# UPRR8zZJTYsg0ixXNXkrqPNFYLwjjVj33GHek/45wPmyMKVM1+mYSlg+0wOI/rOP
+# 015LdhJRk8mMDDtbiiKowSYI+RQQEgN9XyO7ZONj4KbhPvbCdLI/Hgl27KtdRnXi
+# YKNYCQEoAA6EVO7O6V3IXjASvUaetdN2udIOa5kM0jO0zbECAwEAAaOCAV0wggFZ
+# MBIGA1UdEwEB/wQIMAYBAf8CAQAwHQYDVR0OBBYEFLoW2W1NhS9zKXaaL3WMaiCP
+# nshvMB8GA1UdIwQYMBaAFOzX44LScV1kTN8uZz/nupiuHA9PMA4GA1UdDwEB/wQE
+# AwIBhjATBgNVHSUEDDAKBggrBgEFBQcDCDB3BggrBgEFBQcBAQRrMGkwJAYIKwYB
+# BQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBBBggrBgEFBQcwAoY1aHR0
+# cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0VHJ1c3RlZFJvb3RHNC5j
+# cnQwQwYDVR0fBDwwOjA4oDagNIYyaHR0cDovL2NybDMuZGlnaWNlcnQuY29tL0Rp
+# Z2lDZXJ0VHJ1c3RlZFJvb3RHNC5jcmwwIAYDVR0gBBkwFzAIBgZngQwBBAIwCwYJ
+# YIZIAYb9bAcBMA0GCSqGSIb3DQEBCwUAA4ICAQB9WY7Ak7ZvmKlEIgF+ZtbYIULh
+# sBguEE0TzzBTzr8Y+8dQXeJLKftwig2qKWn8acHPHQfpPmDI2AvlXFvXbYf6hCAl
+# NDFnzbYSlm/EUExiHQwIgqgWvalWzxVzjQEiJc6VaT9Hd/tydBTX/6tPiix6q4XN
+# Q1/tYLaqT5Fmniye4Iqs5f2MvGQmh2ySvZ180HAKfO+ovHVPulr3qRCyXen/KFSJ
+# 8NWKcXZl2szwcqMj+sAngkSumScbqyQeJsG33irr9p6xeZmBo1aGqwpFyd/EjaDn
+# mPv7pp1yr8THwcFqcdnGE4AJxLafzYeHJLtPo0m5d2aR8XKc6UsCUqc3fpNTrDsd
+# CEkPlM05et3/JWOZJyw9P2un8WbDQc1PtkCbISFA0LcTJM3cHXg65J6t5TRxktcm
+# a+Q4c6umAU+9Pzt4rUyt+8SVe+0KXzM5h0F4ejjpnOHdI/0dKNPH+ejxmF/7K9h+
+# 8kaddSweJywm228Vex4Ziza4k9Tm8heZWcpw8De/mADfIBZPJ/tgZxahZrrdVcA6
+# KYawmKAr7ZVBtzrVFZgxtGIJDwq9gdkT/r+k0fNX2bwE+oLeMt8EifAAzV3C+dAj
+# fwAL5HYCJtnwZXZCpimHCUcr5n8apIUP/JiW9lVUKx+A+sDyDivl1vupL0QVSucT
+# Dh3bNzgaoSv27dZ8/DCCBY0wggR1oAMCAQICEA6bGI750C3n79tQ4ghAGFowDQYJ
+# KoZIhvcNAQEMBQAwZTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IElu
 # YzEZMBcGA1UECxMQd3d3LmRpZ2ljZXJ0LmNvbTEkMCIGA1UEAxMbRGlnaUNlcnQg
-# QXNzdXJlZCBJRCBSb290IENBMB4XDTE2MDEwNzEyMDAwMFoXDTMxMDEwNzEyMDAw
-# MFowcjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UE
-# CxMQd3d3LmRpZ2ljZXJ0LmNvbTExMC8GA1UEAxMoRGlnaUNlcnQgU0hBMiBBc3N1
-# cmVkIElEIFRpbWVzdGFtcGluZyBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC
-# AQoCggEBAL3QMu5LzY9/3am6gpnFOVQoV7YjSsQOB0UzURB90Pl9TWh+57ag9I2z
-# iOSXv2MhkJi/E7xX08PhfgjWahQAOPcuHjvuzKb2Mln+X2U/4Jvr40ZHBhpVfgsn
-# fsCi9aDg3iI/Dv9+lfvzo7oiPhisEeTwmQNtO4V8CdPuXciaC1TjqAlxa+DPIhAP
-# dc9xck4Krd9AOly3UeGheRTGTSQjMF287DxgaqwvB8z98OpH2YhQXv1mblZhJymJ
-# hFHmgudGUP2UKiyn5HU+upgPhH+fMRTWrdXyZMt7HgXQhBlyF/EXBu89zdZN7wZC
-# /aJTKk+FHcQdPK/P2qwQ9d2srOlW/5MCAwEAAaOCAc4wggHKMB0GA1UdDgQWBBT0
-# tuEgHf4prtLkYaWyoiWyyBc1bjAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd
-# 823IDzASBgNVHRMBAf8ECDAGAQH/AgEAMA4GA1UdDwEB/wQEAwIBhjATBgNVHSUE
-# DDAKBggrBgEFBQcDCDB5BggrBgEFBQcBAQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6
-# Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBDBggrBgEFBQcwAoY3aHR0cDovL2NhY2VydHMu
-# ZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNydDCBgQYDVR0f
-# BHoweDA6oDigNoY0aHR0cDovL2NybDQuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNz
-# dXJlZElEUm9vdENBLmNybDA6oDigNoY0aHR0cDovL2NybDMuZGlnaWNlcnQuY29t
-# L0RpZ2lDZXJ0QXNzdXJlZElEUm9vdENBLmNybDBQBgNVHSAESTBHMDgGCmCGSAGG
-# /WwAAgQwKjAoBggrBgEFBQcCARYcaHR0cHM6Ly93d3cuZGlnaWNlcnQuY29tL0NQ
-# UzALBglghkgBhv1sBwEwDQYJKoZIhvcNAQELBQADggEBAHGVEulRh1Zpze/d2nyq
-# Y3qzeM8GN0CE70uEv8rPAwL9xafDDiBCLK938ysfDCFaKrcFNB1qrpn4J6Jmvwmq
-# YN92pDqTD/iy0dh8GWLoXoIlHsS6HHssIeLWWywUNUMEaLLbdQLgcseY1jxk5R9I
-# EBhfiThhTWJGJIdjjJFSLK8pieV4H9YLFKWA1xJHcLN11ZOFk362kmf7U2GJqPVr
-# lsD0WGkNfMgBsbkodbeZY4UijGHKeZR+WfyMD+NvtQEmtmyl7odRIeRYYJu6DC0r
-# baLEfrvEJStHAgh8Sa4TtuF8QkIoxhhWz0E0tmZdtnR79VYzIi8iNrJLokqV2PWm
-# jlIxggKGMIICggIBATCBhjByMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNl
-# cnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMTEwLwYDVQQDEyhEaWdp
-# Q2VydCBTSEEyIEFzc3VyZWQgSUQgVGltZXN0YW1waW5nIENBAhANQkrgvjqI/2BA
-# Ic4UAPDdMA0GCWCGSAFlAwQCAQUAoIHRMBoGCSqGSIb3DQEJAzENBgsqhkiG9w0B
-# CRABBDAcBgkqhkiG9w0BCQUxDxcNMjEwNjI4MTUzMzE1WjArBgsqhkiG9w0BCRAC
-# DDEcMBowGDAWBBTh14Ko4ZG+72vKFpG1qrSUpiSb8zAvBgkqhkiG9w0BCQQxIgQg
-# U63BaTxWvK6IjoVixdUxR2Ka9ngnAWl8TjG38EljW2IwNwYLKoZIhvcNAQkQAi8x
-# KDAmMCQwIgQgsxCQBrwK2YMHkVcp4EQDQVyD4ykrYU8mlkyNNXHs9akwDQYJKoZI
-# hvcNAQEBBQAEggEAmed9c1/5eDuMSWHIIs7oR1RWaY6OR4PjxqCkybJRvoGl8wO1
-# WmUE58PVZfTNtho02cKeP+HNsyohxFp78bBXwObFNC97vbmKR3U7ANBnu3iEE/hD
-# V3M5RD1BN4SE8yzfRlN4DB5H8rgvArWpjO9JedbVrBKrEe4FwtU8vbQhdAyFMGv5
-# ITWLQgiDJOvAOjfC014JKRgnTMgY1JntNHO1ny2dgkYYql7kO7Jbgu3h/lox/lF2
-# 1Sfonu9hDsv1121CatHRMU8B3kDeiF2P9/ifu5e0UULd0mTsMF7CIUs1/TNX0bAp
-# A6DuV3o0VVOjsfOSgQUiz/nMxVmQoWFv2sNc3w==
+# QXNzdXJlZCBJRCBSb290IENBMB4XDTIyMDgwMTAwMDAwMFoXDTMxMTEwOTIzNTk1
+# OVowYjELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZMBcGA1UE
+# CxMQd3d3LmRpZ2ljZXJ0LmNvbTEhMB8GA1UEAxMYRGlnaUNlcnQgVHJ1c3RlZCBS
+# b290IEc0MIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAv+aQc2jeu+Rd
+# SjwwIjBpM+zCpyUuySE98orYWcLhKac9WKt2ms2uexuEDcQwH/MbpDgW61bGl20d
+# q7J58soR0uRf1gU8Ug9SH8aeFaV+vp+pVxZZVXKvaJNwwrK6dZlqczKU0RBEEC7f
+# gvMHhOZ0O21x4i0MG+4g1ckgHWMpLc7sXk7Ik/ghYZs06wXGXuxbGrzryc/NrDRA
+# X7F6Zu53yEioZldXn1RYjgwrt0+nMNlW7sp7XeOtyU9e5TXnMcvak17cjo+A2raR
+# mECQecN4x7axxLVqGDgDEI3Y1DekLgV9iPWCPhCRcKtVgkEy19sEcypukQF8IUzU
+# vK4bA3VdeGbZOjFEmjNAvwjXWkmkwuapoGfdpCe8oU85tRFYF/ckXEaPZPfBaYh2
+# mHY9WV1CdoeJl2l6SPDgohIbZpp0yt5LHucOY67m1O+SkjqePdwA5EUlibaaRBkr
+# fsCUtNJhbesz2cXfSwQAzH0clcOP9yGyshG3u3/y1YxwLEFgqrFjGESVGnZifvaA
+# sPvoZKYz0YkH4b235kOkGLimdwHhD5QMIR2yVCkliWzlDlJRR3S+Jqy2QXXeeqxf
+# jT/JvNNBERJb5RBQ6zHFynIWIgnffEx1P2PsIV/EIFFrb7GrhotPwtZFX50g/KEe
+# xcCPorF+CiaZ9eRpL5gdLfXZqbId5RsCAwEAAaOCATowggE2MA8GA1UdEwEB/wQF
+# MAMBAf8wHQYDVR0OBBYEFOzX44LScV1kTN8uZz/nupiuHA9PMB8GA1UdIwQYMBaA
+# FEXroq/0ksuCMS1Ri6enIZ3zbcgPMA4GA1UdDwEB/wQEAwIBhjB5BggrBgEFBQcB
+# AQRtMGswJAYIKwYBBQUHMAGGGGh0dHA6Ly9vY3NwLmRpZ2ljZXJ0LmNvbTBDBggr
+# BgEFBQcwAoY3aHR0cDovL2NhY2VydHMuZGlnaWNlcnQuY29tL0RpZ2lDZXJ0QXNz
+# dXJlZElEUm9vdENBLmNydDBFBgNVHR8EPjA8MDqgOKA2hjRodHRwOi8vY3JsMy5k
+# aWdpY2VydC5jb20vRGlnaUNlcnRBc3N1cmVkSURSb290Q0EuY3JsMBEGA1UdIAQK
+# MAgwBgYEVR0gADANBgkqhkiG9w0BAQwFAAOCAQEAcKC/Q1xV5zhfoKN0Gz22Ftf3
+# v1cHvZqsoYcs7IVeqRq7IviHGmlUIu2kiHdtvRoU9BNKei8ttzjv9P+Aufih9/Jy
+# 3iS8UgPITtAq3votVs/59PesMHqai7Je1M/RQ0SbQyHrlnKhSLSZy51PpwYDE3cn
+# RNTnf+hZqPC/Lwum6fI0POz3A8eHqNJMQBk1RmppVLC4oVaO7KTVPeix3P0c2PR3
+# WlxUjG/voVA9/HYJaISfb8rbII01YBwCA8sgsKxYoA5AY8WYIsGyWfVVa88nq2x2
+# zm8jLfR+cWojayL/ErhULSd+2DrZ8LaHlv1b0VysGMNNn3O3AamfV6peKOK5lDGC
+# A3YwggNyAgEBMHcwYzELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDkRpZ2lDZXJ0LCBJ
+# bmMuMTswOQYDVQQDEzJEaWdpQ2VydCBUcnVzdGVkIEc0IFJTQTQwOTYgU0hBMjU2
+# IFRpbWVTdGFtcGluZyBDQQIQBUSv85SdCDmmv9s/X+VhFjANBglghkgBZQMEAgEF
+# AKCB0TAaBgkqhkiG9w0BCQMxDQYLKoZIhvcNAQkQAQQwHAYJKoZIhvcNAQkFMQ8X
+# DTIzMTAwMjEzMjMzMlowKwYLKoZIhvcNAQkQAgwxHDAaMBgwFgQUZvArMsLCyQ+C
+# Xc6qisnGTxmcz0AwLwYJKoZIhvcNAQkEMSIEIBa6X0J/pyxEP0qKmxfT51tQm4Im
+# u/63uybfmuePN1UHMDcGCyqGSIb3DQEJEAIvMSgwJjAkMCIEINL25G3tdCLM0dRA
+# V2hBNm+CitpVmq4zFq9NGprUDHgoMA0GCSqGSIb3DQEBAQUABIICAFRAXwhn3az4
+# r+zhZk2K3gibUwGFM4dHGKh1RD383PsnUii90EaBVzixPIppOs7v0iZOER2tce8u
+# xgQ3IZtjRIuQmCh+9I6zWIH59MssGU6igexTAjc0dIfV66UeFlh2aSWWckxmaTI/
+# jXgpqx2sk4dlqJKrR/d084gyevoCkQNerED/FuwJ6bX8omhIikyHdoo6hbL595tK
+# 4ekxek027svbPFC0WbAxZXLq428C5endJaAQV2RTCk0B1vgPFw5bvznldlQnRqMu
+# vcd1GSoSVN16kw5UKWXEyP0e07yiXEPkFoPBSC/c5o7COjidK2VOlVY/gsorVMEA
+# rx/apEwf1F70vD2caiIsUAhrmPzyslFZfU6o2fKXI/vrBTUvbzb5Vz+IGoXlwTH+
+# loWh4loof+pJjbpJJj26GQwssAl3M/m/3BGamnmf97CJShvPrM0w8WOLkXtn6/M4
+# Y15ywECiRhaQX7NUVzRBl1hGDDD0mFv/OHzMer3C4/8I04whBnfvMxelUb4YhlM6
+# e+F6DzvI91OWTrpjsPKOHE3ds9ra+F1yPkV1RMQMRx/xWd0D274R8W2baHxrYgS3
+# 2LYPSAYFMi3cmF6Df84iIG2d0qj0x3ioXDUUk72YTCUO1Xnz9jkHSCU7Bq2GL9uP
+# z4sEyNDU23dEmfGD672vMRuZ6Ua/ks5J
 # SIG # End signature block
diff --git a/env/Scripts/activate b/env/Scripts/activate
index e642fb2e..83d829ce 100644
--- a/env/Scripts/activate
+++ b/env/Scripts/activate
@@ -1,5 +1,5 @@
 # This file must be used with "source bin/activate" *from bash*
-# you cannot run it directly
+# You cannot run it directly
 
 deactivate () {
     # reset old environment variables
@@ -28,6 +28,7 @@ deactivate () {
     fi
 
     unset VIRTUAL_ENV
+    unset VIRTUAL_ENV_PROMPT
     if [ ! "${1:-}" = "nondestructive" ] ; then
     # Self destruct!
         unset -f deactivate
@@ -37,8 +38,15 @@ deactivate () {
 # unset irrelevant variables
 deactivate nondestructive
 
-VIRTUAL_ENV="C:\Users\eldir\OneDrive - UNIVERSITAS INDONESIA\SEMESTER 6\PPL\a4-logistik\env"
-export VIRTUAL_ENV
+# on Windows, a path can contain colons and backslashes and has to be converted:
+if [ "$OSTYPE" = "cygwin" ] || [ "$OSTYPE" = "msys" ] ; then
+    # transform D:\path\to\venv to /d/path/to/venv on MSYS
+    # and to /cygdrive/d/path/to/venv on Cygwin
+    export VIRTUAL_ENV=$(cygpath "D:\PPL\a4-logistik\env")
+else
+    # use the path as-is
+    export VIRTUAL_ENV="D:\PPL\a4-logistik\env"
+fi
 
 _OLD_VIRTUAL_PATH="$PATH"
 PATH="$VIRTUAL_ENV/Scripts:$PATH"
@@ -56,6 +64,8 @@ if [ -z "${VIRTUAL_ENV_DISABLE_PROMPT:-}" ] ; then
     _OLD_VIRTUAL_PS1="${PS1:-}"
     PS1="(env) ${PS1:-}"
     export PS1
+    VIRTUAL_ENV_PROMPT="(env) "
+    export VIRTUAL_ENV_PROMPT
 fi
 
 # This should detect bash and zsh, which have a hash command that must
diff --git a/env/Scripts/activate.bat b/env/Scripts/activate.bat
index 02e10db2..441312f5 100644
--- a/env/Scripts/activate.bat
+++ b/env/Scripts/activate.bat
@@ -8,7 +8,7 @@ if defined _OLD_CODEPAGE (
     "%SystemRoot%\System32\chcp.com" 65001 > nul
 )
 
-set VIRTUAL_ENV=C:\Users\eldir\OneDrive - UNIVERSITAS INDONESIA\SEMESTER 6\PPL\a4-logistik\env
+set VIRTUAL_ENV=D:\PPL\a4-logistik\env
 
 if not defined PROMPT set PROMPT=$P$G
 
@@ -25,6 +25,7 @@ if defined _OLD_VIRTUAL_PATH set PATH=%_OLD_VIRTUAL_PATH%
 if not defined _OLD_VIRTUAL_PATH set _OLD_VIRTUAL_PATH=%PATH%
 
 set PATH=%VIRTUAL_ENV%\Scripts;%PATH%
+set VIRTUAL_ENV_PROMPT=(env) 
 
 :END
 if defined _OLD_CODEPAGE (
diff --git a/env/Scripts/deactivate.bat b/env/Scripts/deactivate.bat
index 1205c618..62a39a75 100644
--- a/env/Scripts/deactivate.bat
+++ b/env/Scripts/deactivate.bat
@@ -17,5 +17,6 @@ if defined _OLD_VIRTUAL_PATH (
 set _OLD_VIRTUAL_PATH=
 
 set VIRTUAL_ENV=
+set VIRTUAL_ENV_PROMPT=
 
 :END
diff --git a/env/Scripts/pip.exe b/env/Scripts/pip.exe
index 6bf27412711b6f0f31603935323f7e96bd3683ed..8c12433cae8225bc3f158cab721375b9a87b84dc 100644
GIT binary patch
delta 29315
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
W3=D2_Bc_+mWBkMnVr0!{bN~P)(KJN>

delta 28157
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
DUxhe&

diff --git a/env/Scripts/pip3.9.exe b/env/Scripts/pip3.9.exe
deleted file mode 100644
index 6bf27412711b6f0f31603935323f7e96bd3683ed..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001

literal 106410
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
W1(gBNJ3bg07#S=X7#Kc-RRRDGix>(3

diff --git a/env/Scripts/pip3.exe b/env/Scripts/pip3.exe
index 6bf27412711b6f0f31603935323f7e96bd3683ed..8c12433cae8225bc3f158cab721375b9a87b84dc 100644
GIT binary patch
delta 29315
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
W3=D2_Bc_+mWBkMnVr0!{bN~P)(KJN>

delta 28157
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
DUxhe&

diff --git a/env/Scripts/python.exe b/env/Scripts/python.exe
index 7885ec4fa9f470f967a2445c36924fecd95b9ca8..71092d0867a15def9214a0470984023b72167726 100644
GIT binary patch
delta 123815
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

literal 543464
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%0De6loq^yzm~gt=
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

diff --git a/env/Scripts/pythonw.exe b/env/Scripts/pythonw.exe
index 5ffbf4dbc0de6fef7706f73f84e6702c5e62a547..4710dd54c335f620716f1c3b2cf5c281cba59992 100644
GIT binary patch
delta 115053
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

literal 542440
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%0Dn<;nW}
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%0D@Z`dgZT*cp<r+oP5uI$KWiokoP_hi%0rLB`C#LI
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
MyvbT{cXtN^0Q&xjMgRZ+

diff --git a/env/pyvenv.cfg b/env/pyvenv.cfg
index 57023682..a82a846c 100644
--- a/env/pyvenv.cfg
+++ b/env/pyvenv.cfg
@@ -1,3 +1,5 @@
-home = C:\Users\eldir\AppData\Local\Programs\Python\Python39
+home = C:\Python312
 include-system-site-packages = false
-version = 3.9.6
+version = 3.12.0
+executable = C:\Python312\python.exe
+command = C:\Python312\python.exe -m venv D:\PPL\a4-logistik\env
diff --git a/project_a4_logistik/urls.py b/project_a4_logistik/urls.py
index 703657ec..69fa3f0e 100644
--- a/project_a4_logistik/urls.py
+++ b/project_a4_logistik/urls.py
@@ -20,5 +20,6 @@ urlpatterns = [
     path('', include('example_app.urls')),
     path('admin/', admin.site.urls),
     path('example_app/', include('example_app.urls')),
-    path('pr/', include('purchase_requisition.urls'))
+    path('pr/', include('purchase_requisition.urls')),
+    path('detail_item/', include('detail_item.urls'))
 ]
-- 
GitLab